當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript RectRenderer.create函數代碼示例

本文整理匯總了TypeScript中RectRenderer.create函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript create函數的具體用法?TypeScript create怎麽用?TypeScript create使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了create函數的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: Array2D

const pointSize = 2;

const width = Math.floor(window.innerWidth / pointSize) - 12;
const height = Math.floor(window.innerHeight / pointSize) - 12;

const canvasElement = document.createElement("canvas");
canvasElement.width = width * pointSize;
canvasElement.height = height * pointSize;

const ctx = canvasElement.getContext("2d")!;

ctx.fillStyle = `rgb(${String(0)}, ${String(0)}, ${String(0)})`;

document.getElementById("content")!.appendChild(canvasElement);

const renderer = RectRenderer.create(ctx, pointSize);

let currentWorld = new Array2D(height, width, false);
let nextWorld = new Array2D(height, width, false);

for (let row = 0; row < height; row++) {
    for (let column = 0; column < width; column++) {
        currentWorld.set(row, column, Math.random() < 0.5001);
    }
}

const transformer = GameOfLifeTransformer.create(survival, birth);

setInterval(() => {
    renderer.render(currentWorld);
開發者ID:cfuehrmann,項目名稱:GameOfLife,代碼行數:30,代碼來源:World.ts

示例2: TestContext

QUnit.test(name("ContextCallSequence"), assert => {
    // PREPARE

    const context = new TestContext();
    const pointSize = 4;
    const renderer = RectRenderer.create(context, pointSize);
    const width = 5;
    const height = 3;
    const world = new Array2D(height, width, false);

    world.set(0, 0, true);
    world.set(0, 1, false);
    world.set(0, 2, true);
    world.set(0, 3, false);
    world.set(0, 4, true);

    world.set(1, 0, false);
    world.set(1, 1, true);
    world.set(1, 2, false);
    world.set(1, 3, true);
    world.set(1, 4, false);

    world.set(2, 0, true);
    world.set(2, 1, false);
    world.set(2, 2, true);
    world.set(2, 3, false);
    world.set(2, 4, true);

    // ACT

    renderer.render(world);

    // ASSERT 

    // The first call must be clearRect with the proper parameters:
    assert.ok(context.calls[0].match({
        clearRect: (x, y, w, h) => x === 0 && y === 0 &&
            w === width * pointSize && h === height * pointSize,
        fillRect: () => false
    }));

    // The subsequent calls must be fillRects with proper parameters.
    // In particular, each fillRect call must correspond to coordinates
    // where "world" is true, and no such coordinates must occur twice:
    for (let i = 1; i < context.calls.length; i++) {
        context.calls[i].match({
            clearRect: () => assert.ok(false),
            fillRect: (x, y, w, h) => {
                checkInt("x", x);
                checkInt("y", y);
                assert.ok(x >= 0);
                assert.ok(y >= 0);
                assert.strictEqual(w, pointSize);
                assert.strictEqual(h, pointSize);
                const row = Math.floor(y / pointSize);
                const column = Math.floor(x / pointSize);
                assert.ok(world.get(row, column));
                world.set(row, column, false);
            }
        });
    }

    // The calls to fillRect must exhaust all coordinates where world is true:
    for (let row = 0; row < height; row++) {
        for (let column = 0; column < width; column++) {
            assert.strictEqual(world.get(row, column), false);
        }
    }
});
開發者ID:cfuehrmann,項目名稱:GameOfLife,代碼行數:69,代碼來源:RectRenderer_test.ts

示例3:

 (context: RectRenderingContext) => RectRenderer.create(context, 1))
開發者ID:cfuehrmann,項目名稱:GameOfLife,代碼行數:1,代碼來源:RectRenderer_test.ts


注:本文中的RectRenderer.create函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。