1

まず、四角形は問題なく描画され、機能しますが、まだいくつかの問題があります。私には 2 つの問題があります...最初の 1 つは、正方形を描くときに、正方形を大きくしすぎると、元の 1 点に戻る (そして小さくなる) ことができないことです。2 つ目の問題は、正方形を描くと、指の真下ではなく、指の約 1 センチ下に表示されることです。

誰でもこれらの問題で私を助けることができますか?


コードは次のとおりです。

ジャバスクリプト

// "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);

2番目の問題は、ページ相対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 に答える