【问题标题】:<canvas> Go/Baduk/Weiqi Game Board<canvas> 围棋/Baduk/围棋棋盘
【发布时间】:2010-02-20 06:39:49
【问题描述】:

我正在尝试使用新标签,我已经遇到了我的第一个障碍。我想我会通过实现经典棋盘游戏 Go/Baduk/Weiqi 的一个版本开始涉足。

我已经使用 moveTo() 和 lineTo() 绘制了 xy 网格,并且我使用 fillRect() 绘制了一个木质背景,当然它需要在那个 XY 网格“下方”。

但是,这就是我的问题。 fillRect() 背景被绘制在网格的顶部——因此遮蔽了网格。

我该如何扭转这种情况?这是我正在使用的:

        var boardSize = 19;                 
        var gridSpacing = 25;
        var gridSize = boardSize * gridSpacing;

        var xStart = (window.innerWidth / 2) - (gridSize / 2) + 0.5;
        var yStart = (window.innerHeight / 2) - (gridSize / 2) + 0.5;
        var xEnd = xStart + gridSize;
        var yEnd = yStart + gridSize;


        var gridContext = canvas.getContext("2d");

        gridContext.beginPath();

        // Draw the board x lines
        for (var x = xStart; x <= xEnd; x += gridSpacing)
        {
            gridContext.moveTo(x, yStart);
            gridContext.lineTo(x, yEnd);
        }

        // Draw the board y lines
        for (var y = yStart; y <= yEnd; y += gridSpacing)
        {
            gridContext.moveTo(xStart, y);
            gridContext.lineTo(xEnd, y);
        }

        gridContext.strokeStyle = "#000000";
        gridContext.stroke();

        // Create new image object to use as pattern
        var img = new Image();
        img.src = 'bg_wood.jpg';
        img.onload = function()
        {
            var boardBG = gridContext.createPattern(img, 'repeat');
            gridContext.fillStyle = boardBG;
            gridContext.fillRect(xStart, yStart, gridSize, gridSize);
        }

【问题讨论】:

  • 你似乎是先画线,然后是背景 - 反过来试试
  • 请为您选择的正确答案投票(如果您认为值得投票,正如您在本例中所做的那样)。

标签: javascript html canvas baduk


【解决方案1】:

【讨论】:

  • 工作得非常漂亮!我之前在搞乱 globalCompositeOperation 但看起来我只尝试了“source-”变体。谢谢!注意到我的代码还有什么可疑之处吗?我不得不承认我并不完全理解画布绘图堆栈 - 或者如何使用 save() 和 restore()。或者我是否应该使用 closePath()。返回文档!
  • 我似乎遇到了一个新问题,但情况相同。我正在尝试在板本身上绘制板件(当然!),但我遇到了相同的“分层”/合成问题。我添加了以下块: var stone = new Image();石头.src = "b.png"; stone.onload = function() { gridContext.drawImage(stone, xStart - 30, yStart - 30); };什么给了?
  • @MrMatt 在绘图时将globalCompositeOperation改回source-over
  • 工作...但现在网格线已经消失了。
  • @MrMatt:见pastie.org/835165。问题是onload不会在您定义它的同时执行。所以你之前的所有复合操作在执行onload时都不会生效。您只能在onload 期间更改它。
猜你喜欢
  • 1970-01-01
  • 2023-04-08
  • 2023-04-01
  • 1970-01-01
  • 1970-01-01
  • 2015-02-09
  • 2011-04-05
  • 2011-12-23
  • 1970-01-01
相关资源
最近更新 更多