问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

HTML5添加ONTouchEvent事件

发布网友 发布时间:2022-04-19 23:38

我来回答

2个回答

热心网友 时间:2022-04-20 01:08

实际上,拿canvas2D绘制,只是把image渲染到 canvas(画布上).而实际的事件,就不能像标签那么处理,应该对canvas的事件做处理.
实现逻辑是这样:
1,添加事件监听,比如说,鼠标按下 做什么,滑动 做什么,弹起做什么.一般鼠标事件都是判断弹起的位置
2,判断有效坐标,在事件中判断坐标位置是否在图片位置,也就是图片在canvas的位置.

ex:
//some code...
canvas.width=400;
canvas.height=400;

var context2d = canvas.getContext("2d");

var img =new Image();
img.src="xxx/xxx.png";
img.onload=function(){
context2d.drawImage(img,X,Y,WIDTH,HEIGTH);
//X=0,Y=0,W=50,H=50
canvas.addEventListener("mouseup", keyUp, false);
}

function keyUp(evt){
Event_UpX = evt.offsetX;
Event_UpY = evt.offsetY;
if(Event_UpX>=绘制坐标X&&Event_UpX<=图片宽度){
if(Event_UpY>=绘制坐标Y&&Event_UpY<=图片高度){
//do something
}
}
}

热心网友 时间:2022-04-20 02:26

HTML5添加ONTouchEvent事件主要是以下三种:
1、onTouchStart 触摸开始
2、onTouchMove 触摸滑动
3、onTouchEnd 触摸结束
html代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"></p> <p><html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Canvas</title>
<meta name = "viewport" content = "width = device-width, user-scalable = no">
</head>
<body>
<canvas id="canvas" ></canvas>
<script type="text/javascript" src="canvasScript.js" charset="utf-8"></script>
</body>
</html>
js代码如下:
//get canvas
var canvas = document.getElementById("canvas");
//full screen
canvas.width=window.innerWidth;
canvas.height=window.innerHeight;
//是否支持触摸
var touchable = 'createTouch' in document;
if (touchable) {
canvas.addEventListener('touchstart', onTouchStart, false);
canvas.addEventListener('touchmove', onTouchMove, false);
}
else
{
alert("touchable is false !");
}
//上一次触摸坐标
var lastX;
var lastY;</p> <p>var ctx =canvas.getContext("2d");
ctx.lineWidth=10;//画笔粗细
ctx.strokeStyle="#FF0000";//画笔颜色</p> <p>//触摸开始事件
function onTouchStart(event) {
event.preventDefault();
lastX=event.touches[0].clientX;
lastY=event.touches[0].clientY;
drawRound(lastX,lastY);</p> <p>}
//触摸滑动事件
function onTouchMove(event) {
try
{
event.preventDefault();
drawLine(lastX,lastY,event.touches[0].clientX,event.touches[0].clientY);
lastX=event.touches[0].clientX;
lastY=event.touches[0].clientY;
}
catch(err){
alert( err.description);
}</p> <p>}</p> <p>//画圆
function drawRound(x,y)
{
ctx.fillStyle="#FF0000";
ctx.beginPath();
ctx.arc(x,y,5,0,Math.PI*2,true);
ctx.closePath();
ctx.fill();
}
//画线
function drawLine(startX,startY,endX,endY)
{
ctx.beginPath();
ctx.lineCap="round";
ctx.moveTo(startX,startY);
ctx.lineTo(endX,endY);
ctx.stroke();
}
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
关于海贼王的碟 海贼王852什么时候更新的最新相关信息 买个1G或2G的U盘要多少钱 请问1G的金士顿U盘的价格是多少? 低血糖可能另有隐情 “假性低血糖”需警惕 自发性血糖过低症[治疗] 2020年 巨蟹座到几月几日才能20岁? 1991年出生的20岁巨蟹座的女生是怎么样的 手机安全气囊发明背景 手机安全气囊简介 iphone6的相机自拍出来为什么左右是反的能调回来吗? &quot;电脑开机显示【不支持的16位应用程序: 由于与64位版本的windows不兼容,此程序或功能&#92;&quot;_百度问一问 如何计算一个CPU的MIPS 人体感应灯范围过大,怎么让它小一点 CPU 的计算速度MIPS的全称 是什么啊? 农村户口买城镇养老保险有没有补贴 2020年国家对65岁以上农村老年人没有上农保的每人每月补多少养老补贴? 棘洪滩居民交养老保险有补贴吗 养老金属于政府补助不? 秋天到了作文100字写田野,果园写 社会养老保险有那些补贴 居民养老保险退休拿工资后有没有老年补贴? 太阳的外部是什么? 太阳从内到外按结构层次划分可以分为多少个层次,那层进行核聚变,表面进行的是什么 win10 打开浏览器后选择每一段文字老是会出现搜索和复制的按钮 劳动合同签订时间 员工入职多久签劳动合同 新入职一般多久签合同才合适 入职合同一般是几年 眼睛望远处看不清怎么回事。 金融行业能使用电子合同吗? 金志文的《我们结婚吧》,歌曲链接 我们结婚吧插曲 那一年 给我个 我们结婚吧 金志文的歌曲链接空间用的 华硕笔记本电脑的品质怎么样 ? 余额宝有一万转出到银行卡需要多少手续费 为什么余额宝提现10000元要手续费 说好普通话的内容? 星火云雾街哪年拍的,什么时间播出 星火云雾街剧情分集介绍 星火云雾街徐营长的结局 星火云雾街薜茶花扮演者 星火云雾街拼音怎么写 致敬经典,从《亮剑》到《星火云雾街》,为什么说我们需要这样的电视剧? 星火云雾街的拼音怎么写 电视剧星火云雾街片尾歌名叫什么 素炒黄豆芽怎么炒才好吃 小报内容:说普通话,写规范字 星火云雾街和娘亲舅大是同一导演吗? 星火云雾街欣兰是好是坏