在HTML5画布上使用触摸事件绘制正方形

4

我有一个问题,我正在尝试使用触摸事件在画布上绘制一个正方形,但它不起作用,有人可以帮我找出原因吗?


这是我的代码:

JAVASCRIPT:

// "Draw Rectangle" Button
function rect(){
var canvas = document.getElementById('canvasSignature'), ctx = canvas.getContext('2d'), rect = {}, drag = false;

function init() {
  canvas.addEventListener("touchstart", touchHandler, false);
  canvas.addEventListener("touchmove", touchHandler, false);
  canvas.addEventListener("touchend", touchHandler, false);
}


function touchHandler(event) {
  if (event.targetTouches.length == 1) { //one finger touche
    var touch = event.targetTouches[0];

    if (event.type == "touchstart") {
      rect.startX = touch.pageX;
      rect.startY = touch.pageY;
      drag = true;
    } else if (event.type == "touchmove") {
      if (drag) {
        rect.w = touch.pageX - rect.startX;
        rect.h = touch.pageY - rect.startY ;
        draw();
      }
    } else if (event.type == "touchend" || event.type == "touchcancel") {
      drag = false;
    }
  }
}

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>  

再次感谢, Wardenclyffe


你在哪些设备上测试这个? - kevin628
我已经在我的iPhone上进行了测试... - Wardenclyffe
1个回答

1

在Chrome中测试了模拟的触摸事件,使用此jsFiddle可以正常工作。问题似乎在于您绑定点击事件的方式。我只是使用了jQuery。

或者不使用jQuery:只需普通的addEventListener


那么我应该如何解决呢?我不确定我理解了。我之前在 jsFiddle 上尝试过,但无法运行。 - Wardenclyffe

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接