2

調子はどう?

最近、このサイトの助けを借りて、ボタンをクリックするだけでHTML5キャンバスに長方形を描く方法を学びました...それは問題ではありません:)これは問題です...残念ながら、毎回キャンバスをクリックして新しい長方形を作成すると、古い長方形が消えます(またはすぐに消去されます)。また、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> 

どんな助けでも大歓迎です:)

4

1 に答える 1

3

キャンバスをクリアするステートメントがあります

ctx.clearRect(0, 0, canvas.width, canvas.height);
于 2012-06-04T06:44:47.520 に答える