javascript - 如何聚合onMouse和onTouch,使canvas可以在鼠标和ipad上使用?

标签 javascript canvas touch-event onmousemove

我有一个关于如何将 ontouch 放入我的代码中的困惑,因为我希望它在 ipad 上运行,下面是我的代码

    <script language="javascript">
function sig1()
{
    if(sig == null)
    {
        xclear('myCanvas');
    }
}

清除 Canvas 中线条的代码

<body id="main_body" class="no_guidelines" onload="sig1()" onmouseup="bodyonmouseup">

让 Canvas 具有fillstyle颜色和功能

<canvas border=1 id="myCanvas" height=200 width=400 onmousedown="onmousedown()" onmouseup="onmouseup()" onmousemove="onmousemove()">Your browser does not support the application</canvas>

可以像签名一样画线的 Canvas

var sig = null;
      var ele;
      function bodyonmouseup(e)
{
    var ele;
    ele = document.getElementById('myCanvas');
    ele.isDown = false;
}
function onmousedown(e)
{
    var ele,p;
    if (!e) e = window.event;
    ele = (e.srcElement);
    if (! ele) ele = e.target;
    ele.isDown = true; 
    ele.context = ele.getContext("2d");
    ele.context.lineWidth = 1;
    ele.context.beginPath();   
    ele.context.moveTo(e.offsetX,e.offsetY);
    sig.line = new Array();

    p = new Object();
    p.x = e.offsetX;
    p.y = e.offsetY;

    sig.p = p;
    sig.line[sig.line.length] = p;
    sig.lines[sig.lines.length] = sig.line;
}
function onmousemove(e)
{
    var ele,dx,dy,p;
    if (!e) e = window.event;
    ele = (e.srcElement);
    if (! ele) ele = e.target;
    if (! ele.isDown) return;
    ele.context.lineTo(e.offsetX,e.offsetY);
    ele.context.stroke();
    dx = e.offsetX - sig.p.x;
    dy = e.offsetY - sig.p.y;
    if (dx == 0 && dy == 0) return;
    sig.p = new Object();
    sig.p.x = e.offsetX;
    sig.p.y = e.offsetY;
    sig.line[sig.line.length] = sig.p;
}

所以我想知道我是否想同时保留onMouse和ontouch,我如何放置ontouch以便可以在ipad上绘制 Canvas ?请帮忙,很紧急

最佳答案

使用这个js。你的手指将成为你的鼠标。他们正在将所有触摸事件转换为鼠标事件。

jquery-ui-touch-punch

关于javascript - 如何聚合onMouse和onTouch,使canvas可以在鼠标和ipad上使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11132318/

相关文章:

php - 防止直接/在 facebook 之外访问 facebook canvas 应用程序

android - 在 RelativeLayout > ontouch 中使用 ScrollView 的 fragment 不起作用

javascript - 处理 draggables/droppables 的 iPad 触摸事件(未定义的 changedTouches)

java - Android 监听触摸释放

javascript - 将 css 应用到 Youtube 框架中或修复拇指

Javascript 命名空间/原型(prototype)问题

css - 我的 Canvas 有 2 个边框而不是一个

javascript - 分区和动画

javascript - 为什么此代码以前工作时不起作用并为随机值添加按钮

javascript - 穿过带有文本/无图像的 Canvas 元素