我想在画布的底部画一个重复的草图案。图像确实重复,但它是垂直移动的。
该模式基于192x50图像:
我注意到如果我从y坐标50,100,150等进行绘制,则图案会正确显示。它在其他坐标处不起作用。
生成的画布具有垂直移动的草图案:
我不知道为什么会这样转移。
以下是我的代码。
HTML:
<canvas id="myCanvas" style="display: block;">
</canvas>
JavaScript的:
canvas.height = window.innerHeight;
canvas.width = window.innerWidth;
// Grass Background Image
var bgReady = false;
var bgImage = new Image();
bgImage.onload = function () {
bgReady = true;
};
bgImage.src = "img/grass.png";
我在循环中执行以下操作:
if (bgReady) {
ctx.drawImage(bgImage,0, canvas.height -50,192,50);
var ptrn = ctx.createPattern(bgImage, "repeat"); // Create a pattern with this image, and set it to repeat".
ctx.fillStyle = ptrn;
ctx.fillRect(0,canvas.height - bgImage.height,canvas.width, 50); // context.fillRect(x, y, width, height);
}
答案 0 :(得分:0)
我尝试将您的代码放在jsFiddle中,它似乎按预期工作:
var canvas = document.getElementById('myCanvas');
canvas.height = window.innerHeight;
canvas.width = window.innerWidth;
// Grass Background Image
var bgImage = new Image();
bgImage.onload = function () {
var ctx = canvas.getContext("2d");
ctx.drawImage(bgImage,0, canvas.height -50,192,50);
var ptrn = ctx.createPattern(bgImage, "repeat"); // Create a pattern with this image, and set it to repeat".
ctx.fillStyle = ptrn;
ctx.fillRect(0,canvas.height - bgImage.height,canvas.width, 50); // context.fillRect(x, y, width, height);
};
bgImage.src = "";
https://jsfiddle.net/or68kcpc/
错误必须在其他地方。
答案 1 :(得分:-1)
问题是从画布的左上角开始计算模式。如果从画布y坐标开始绘制,该坐标不是图像高度的整数倍,则图案的可见部分不会从图像顶部开始。
要解决此问题,请在使用图案绘制之前将绘图上下移动,然后在向上移动的位置绘制图案,然后将上下文重新移回:
var shiftY = canvas.height % image.height;
context.translate(0, shiftY);
context.fillRect(0, canvas.height - image.height - shiftY,
canvas.width, image.height);
context.translate(0, -shiftY);
运行下面的代码段以查看演示。画布高度为120,这意味着我们从y坐标开始绘画120 - 50 = 70,这不是50的倍数。
为了纠正这个问题,我们将上下文向下移动120%50 = 20,然后将绘制位置向上移动20个。这样,模式在y坐标(70 - 20)上的移位上下文上绘制= 50,这是图像高度的倍数。
var canvas = document.getElementById('myCanvas'),
context = canvas.getContext('2d');
canvas.height = 120;
canvas.width = 500;
var image = new Image();
image.src = 'http://i.stack.imgur.com/2bfPb.png';
image.onload = function () {
var pattern = context.createPattern(image, "repeat");
context.fillStyle = pattern;
var shiftY = canvas.height % image.height;
context.translate(0, shiftY);
context.fillRect(0, canvas.height - image.height - shiftY,
canvas.width, image.height);
context.translate(0, -shiftY);
};
#myCanvas {
border: 1px solid #666;
}
<canvas id="myCanvas"></canvas>
让我再做一次观察。代码中的循环效率低下,bgReady
标志是不必要的,因为您可以在image.onload
函数中运行绘制代码,就像我在代码片段中所做的那样。