Javascript 为什么我的HTML5/JS应用程序不能在我的iPhone上运行?
你们过得怎么样 最近,在这个网站的帮助下,我学会了如何在HTML5画布上点击按钮画一个矩形。。。这不是问题:问题是这个。。。不幸的是,当我尝试在iPhone上使用它时,它根本不起作用。。。为什么: 这是我的密码: JAVASCRIPT:Javascript 为什么我的HTML5/JS应用程序不能在我的iPhone上运行?,javascript,iphone,html,Javascript,Iphone,Html,你们过得怎么样 最近,在这个网站的帮助下,我学会了如何在HTML5画布上点击按钮画一个矩形。。。这不是问题:问题是这个。。。不幸的是,当我尝试在iPhone上使用它时,它根本不起作用。。。为什么: 这是我的密码: JAVASCRIPT: // "Rectangle" Button function rect() { var canvas = document.getElementById('canvasSignature'), ctx = canvas.getContext('2d'),
// "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 ;
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>
任何帮助都将不胜感激:首先,您的代码中有一个错误 你是这个明星吗
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();