// "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();
}
감사
자바 스크립트 :
여기에 코드입니다. 이전 데이터는 사용자가 지우지 않는 한 캔바스에 남아 있으므로 이전에 그려진 사각형은 그대로 유지됩니다.
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;
.