国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - 原生canvas中如何獲取到觸摸事件的canvas內(nèi)坐標(biāo)?

瀏覽:90日期:2022-12-06 14:22:18

問題描述

canvas在響應(yīng)mousedown事件時(shí),可以通過event.offsetX和offsetY來提取元素內(nèi)坐標(biāo),那我換成了touchstart后沒有offsetX和offsetY.該在哪里找到元素內(nèi)坐標(biāo)呢?

問題解答

回答1:

在我的 canvas 地圖庫 Sinomap 中處理的算法是這樣的(有改動(dòng)):

// 注意這里是為 canvas 的 DOM 元素增加 Listener 而非 canvas 的 ctxdocument .getElementById(’my-canvas’) .addEventListener(’click’, updateHandler, false)function updateHandler (e) { // canvas 為你的 canvas ctx 變量 const box = canvas.getBoundingClientRect() const mouseX = (e.clientX - box.left) * canvas.width / box.width const mouseY = (e.clientY - box.top) * canvas.height / box.height console.log([mouseX, mouseY])}回答2:

touch事件 你需要 獲取 e.touches[0].pageX 或者其他坐標(biāo),至于touchend 的話,為了兼容性考慮,最好用e.changedTouches

回答3:

javascript - 原生canvas中如何獲取到觸摸事件的canvas內(nèi)坐標(biāo)?javascript - 原生canvas中如何獲取到觸摸事件的canvas內(nèi)坐標(biāo)?javascript - 原生canvas中如何獲取到觸摸事件的canvas內(nèi)坐標(biāo)?

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 庄浪县| 新疆| 舟山市| 冷水江市| 延吉市| 榆树市| 鹿泉市| 南漳县| 榆林市| 福清市| 长汀县| 耒阳市| 西华县| 泽普县| 龙陵县| 内江市| 江川县| 上饶县| 正宁县| 龙口市| 芦溪县| 衡阳市| 赤水市| 旺苍县| 吉林省| 广平县| 福鼎市| 于都县| 大渡口区| 裕民县| 阿克苏市| 桃源县| 兴城市| 平凉市| 永顺县| 什邡市| 剑川县| 瓦房店市| 和田县| 万山特区| 宝山区|