中文亚洲精品无码_熟女乱子伦免费_人人超碰人人爱国产_亚洲熟妇女综合网

當(dāng)前位置: 首頁 > news >正文

通達(dá)oa 做網(wǎng)站企業(yè)培訓(xùn)權(quán)威機(jī)構(gòu)

通達(dá)oa 做網(wǎng)站,企業(yè)培訓(xùn)權(quán)威機(jī)構(gòu),上海搭建工廠,外貿(mào)網(wǎng)站在哪做外鏈?zhǔn)謾C(jī)上的效果圖 需要注意&#xff0c;手機(jī)觸摸和鼠標(biāo)不是一個(gè)事件&#xff0c;不能通用&#xff0c;上一篇是關(guān)于使用鼠標(biāo)的樣例 相關(guān)代碼 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewpo…

手機(jī)上的效果圖

image

需要注意,手機(jī)觸摸和鼠標(biāo)不是一個(gè)事件,不能通用,上一篇是關(guān)于使用鼠標(biāo)的樣例

相關(guān)代碼

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.buttons {margin-top: 10px;}</style>
</head><body><div><canvas id="signatureCanvas" width="500" height="200" style="border:solid;"></canvas><button onclick="clearSignature()">清除</button><button onclick="undoLast()">清除上一步</button><button onclick="saveSignature()">保存</button></div><script>const canvas = document.getElementById('signatureCanvas');const ctx = canvas.getContext('2d');let isDrawing = false;let lastX, lastY;let strokes = []; // 用于存儲(chǔ)每一步的繪制操作// 觸摸開始事件function handleTouchStart(e) {e.preventDefault(); // 阻止默認(rèn)的觸摸事件isDrawing = true;[lastX, lastY] = [e.touches[0].clientX - canvas.offsetLeft, e.touches[0].clientY - canvas.offsetTop];strokes.push([]); // 開始新的筆畫}// 觸摸移動(dòng)事件function handleTouchMove(e) {e.preventDefault(); // 阻止默認(rèn)的觸摸事件if (!isDrawing) return; // 如果沒有觸摸,則退出函數(shù)const x = e.touches[0].clientX - canvas.offsetLeft;const y = e.touches[0].clientY - canvas.offsetTop;ctx.beginPath();ctx.moveTo(lastX, lastY);ctx.lineTo(x, y);ctx.stroke();strokes[strokes.length - 1].push({ x: lastX, y: lastY, x2: x, y2: y }); // 記錄當(dāng)前筆畫[lastX, lastY] = [x, y];}// 觸摸結(jié)束事件function handleTouchEnd(e) {e.preventDefault(); // 阻止默認(rèn)的觸摸事件isDrawing = false;}// 清除簽名function clearSignature() {ctx.clearRect(0, 0, canvas.width, canvas.height);strokes = []; // 清空所有筆畫記錄}// 撤銷上一步function undoLast() {strokes.pop(); // 移除最后一個(gè)筆畫redraw(); // 重新繪制畫布}// 重新繪制畫布function redraw() {ctx.clearRect(0, 0, canvas.width, canvas.height); // 清空畫布strokes.forEach(stroke => {stroke.forEach(line => {ctx.beginPath();ctx.moveTo(line.x, line.y);ctx.lineTo(line.x2, line.y2);ctx.stroke();});});}// 保存簽名function saveSignature() {const imgData = ctx.getImageData(0, 0, canvas.width, canvas.height);// 將圖片數(shù)據(jù)轉(zhuǎn)換成 base64 格式const base64ImageData = canvas.toDataURL();console.log(base64ImageData);}// 綁定事件canvas.addEventListener('touchstart', handleTouchStart);canvas.addEventListener('touchmove', handleTouchMove);canvas.addEventListener('touchend', handleTouchEnd);canvas.addEventListener('touchcancel', handleTouchEnd);</script>
</body></html>
http://www.risenshineclean.com/news/5793.html

相關(guān)文章:

  • 恐怖小說網(wǎng)站怎么做小廣告模板
  • 新媒體公司網(wǎng)站怎么做2345網(wǎng)址導(dǎo)航瀏覽器下載
  • 仿網(wǎng)站建設(shè)免費(fèi)b2b網(wǎng)站有哪些
  • 汕頭人才招聘網(wǎng)最新招聘信息北京seo全網(wǎng)營銷
  • 用c 做的網(wǎng)站怎么打開域名免費(fèi)注冊0元注冊
  • 攝影師簽約有哪些網(wǎng)站線上宣傳渠道
  • 成都娛樂場所關(guān)閉最新消息武漢建站優(yōu)化廠家
  • 中糧網(wǎng)站是哪個(gè)公司做的上海高端seo公司
  • 長春二道網(wǎng)站建設(shè)百度明星搜索量排行榜
  • 響應(yīng)式網(wǎng)站wordpress攝影家居seo整站優(yōu)化方案
  • 網(wǎng)站開發(fā)量計(jì)算百度一下你就知道移動(dòng)官網(wǎng)
  • 如何做商業(yè)推廣網(wǎng)站提高關(guān)鍵詞排名的軟文案例
  • 網(wǎng)站站點(diǎn)文件夾權(quán)限設(shè)置青島網(wǎng)站關(guān)鍵詞優(yōu)化公司
  • 中國做網(wǎng)站推廣哪家好武漢外包seo公司
  • 浦東新區(qū)消息今天淘寶seo什么意思
  • 網(wǎng)站怎么做三級(jí)的游戲優(yōu)化大師
  • 建行網(wǎng)站登錄不了荊門網(wǎng)絡(luò)推廣
  • 深圳網(wǎng)站制作必選祥奔科技域名訪問網(wǎng)站怎么進(jìn)入
  • 長沙理財(cái)網(wǎng)站建設(shè)魔方優(yōu)化大師官網(wǎng)
  • 網(wǎng)站做推廣頁需要什么軟件注冊公司
  • 在putty上怎樣安裝wordpress刷關(guān)鍵詞優(yōu)化排名
  • 如何給網(wǎng)站做301重定向搜索引擎有哪幾個(gè)網(wǎng)站
  • 一個(gè)公司做兩個(gè)網(wǎng)站的好處seo上海培訓(xùn)
  • 自助建站系統(tǒng)源碼下載大慶網(wǎng)絡(luò)推廣
  • 錦州做網(wǎng)站廣州做網(wǎng)站的公司哪家好
  • 獨(dú)立網(wǎng)站優(yōu)化廣告寧波seo網(wǎng)絡(luò)推廣渠道介紹
  • 統(tǒng)一社會(huì)信用代碼查詢廈門網(wǎng)站seo哪家好
  • 做網(wǎng)站怎么兼職網(wǎng)絡(luò)公司網(wǎng)絡(luò)營銷推廣方案
  • 青浦區(qū)網(wǎng)站建設(shè)費(fèi)用企業(yè)營銷策略
  • 網(wǎng)站建設(shè)技術(shù)交流免費(fèi)發(fā)外鏈