1

首先,正方形画得很好并且确实有效,但仍然存在一些问题。我有两个问题......第一个是当我绘制正方形时,如果你让你的正方形太大,它就无法自行折叠到一个点(并变小)。第二个问题是,当我绘制正方形时,它显示在我手指下方约一厘米处,而不是直接在手指下方。

谁能帮我解决这些问题?


这是代码:

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);
  ctx.fillStyle = "orange";
}

init();
}

谢谢,沃登克里夫

4

1 回答 1

1

第一个问题是由于您没有清除画布引起的。除非您将其清除,否则先前的数据将保留在画布中,因此先前绘制的矩形将保留。您可以像这样清除画布:

ctx.clearRect(0, 0, canvas.width, canvas.height);

我假设您的第二个问题是您正在使用相对于页面的 X 和 Y,并期望它是相对于画布的 X 和 Y。除非画布的左上角与文档的上角相同,否则情况并非如此左手角。您可以在较新的浏览器中将页面 X 和 Y 转换为画布 X 和 Y,如下所示:

var clientRect = canvas.getBoundingClientRect();
var canvasX = touch.pageX - clientRect.left - window.pageXOffset,
    canvasY = touch.pageY - clientRect.top  - window.pageYOffset;

如果画布位于带有滚动条的元素中,则需要进一步调整。

于 2012-06-09T23:01:33.083 回答