最近怎么样?
最近,在本网站的帮助下,我学会了如何通过单击按钮在 HTML5 Canvas 上绘制矩形...这不是问题:) 问题是这个...不幸的是,每次我单击 Canvas 创建一个新矩形时,旧矩形就会消失(或立即被删除)。当我尝试在 iPod 上使用它时,它也根本不起作用...为什么:(?
这是我的代码:
JavaScript:
// "Rectangle" Button
function rect()
{
var canvas = document.getElementById('canvasSignature'),
ctx = canvas.getContext('2d'),
rect = {},
drag = false;
function init() {
canvas.addEventListener('mousedown', mouseDown, false);
canvas.addEventListener('mouseup', mouseUp, false);
canvas.addEventListener('mousemove', mouseMove, false);
}
function mouseDown(e) {
rect.startX = e.pageX - this.offsetLeft;
rect.startY = e.pageY - this.offsetTop;
drag = true;
}
function mouseUp() {
drag = false;
}
function mouseMove(e) {
if (drag) {
rect.w = (e.pageX - this.offsetLeft) - rect.startX;
rect.h = (e.pageY - this.offsetTop) - rect.startY ;
ctx.clearRect(0,0,canvas.width,canvas.height);
draw();
}
}
function draw() {
ctx.fillRect(rect.startX, rect.startY, rect.w, rect.h);
}
init();
}
HTML5:
<div id="canvasDiv">
<canvas id="canvasSignature" width="580px" height="788px" style="border:2px solid #000; background: #FFF;"></canvas>
</div>
<div id="rect">
<p><button onclick="rect();">Rectangle</button></p>
</div>
任何帮助都将不胜感激:)
最佳答案
您有一个清除 Canvas 的声明
ctx.clearRect(0, 0, canvas.width, canvas.height);
关于javascript - HTML5 Canvas(绘图(矩形)不断消失),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10877222/