我猜这篇文章的标题可能需要编辑,但目前我不知道问题在哪里。我在这里和其他地方读过类似问题的页面和答案。一个堆栈溢出的答案特别接近,但我不明白。
我需要一个函数,在画布上以所需的坐标绘制多边形,并用从文件加载的一些背景图像填充它们(足够大,不需要平铺)。三角形可以做测试。显然,我应该使用drawImage和clip,为了给多边形一个边界,我可以重新绘制剪辑和笔划的相同路径。显然我应该遵守
- define path
- save
- clip
- drawImage
- restore
- stroke.
也可以在某个地方阅读,只要加载一次图像就足够了。(如果uou想让我引用所有这些假设的来源,我会寻找我看到它们的地方。大多数都在Stack Overflow上)
HTML为空
<body onload = "main ();"></body>
第一种方法,假装浏览器将等待图片加载:
var ctx, img;
var image_path = 'bg.jpg';
function main () {
var CANVAS_SIZE = 600;
var view_field_cnv = document.createElement ('canvas');
view_field_cnv.width = CANVAS_SIZE;
view_field_cnv.height = CANVAS_SIZE;
view_field_cnv.style.border = "1px solid";
document.body.appendChild (view_field_cnv);
ctx = view_field_cnv.getContext ('2d');
img = document.createElement ('img');
img.src = image_path;
place_triangle (0, 0);
place_triangle (300, 300);
place_triangle (500, 500);
place_triangle (0, 0);
}
function place_triangle (x, y) {
console.log (x, y);
ctx.beginPath ();
ctx.moveTo (x + 10, y);
ctx.lineTo (x + 110, y);
ctx.lineTo (x + 60, y + 40);
ctx.closePath ();
img = document.createElement ('img');
img.src = image_path;
ctx.save ();
ctx.clip ();
ctx.drawImage (img, x, y);
ctx.restore ();
ctx.stroke ();
}
这将绘制所有三个三角形,但没有剪裁图像。
第二次尝试,在image.onload中使用drawImage:
var ctx;
var image_path = 'bg.jpg';
function main () {
var CANVAS_SIZE = 600;
var view_field_cnv = document.createElement ('canvas');
view_field_cnv.width = CANVAS_SIZE;
view_field_cnv.height = CANVAS_SIZE;
view_field_cnv.style.border = "1px solid";
document.body.appendChild (view_field_cnv);
ctx = view_field_cnv.getContext ('2d');
place_triangle (0, 0);
place_triangle (300, 300);
place_triangle (500, 500);
place_triangle (0, 0);
}
function place_triangle (x, y) {
console.log (x, y);
var img;
ctx.beginPath ();
ctx.moveTo (x + 10, y);
ctx.lineTo (x + 110, y);
ctx.lineTo (x + 60, y + 40);
ctx.closePath ();
img = document.createElement ('img');
img.src = image_path;
img.onload = function () {
ctx.save ();
ctx.clip ();
ctx.drawImage (img, x, y);
ctx.restore ();
ctx.stroke ();
}
}
这张确实画出了裁剪的图像,但只有一个三角形,最后一个。仅仅注释保存和恢复并没有帮助。
所以,我不理解加载图像、保存、恢复以及可能的一百万其他事情。虫子在哪里?