亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > Canvas高級路徑操作之拖拽對象的實現(xiàn)

Canvas高級路徑操作之拖拽對象的實現(xiàn)

熱門標簽:黃石ai電銷機器人呼叫中心 智能電銷機器人被禁用了么 電話機器人技術 高德地圖標注商戶怎么標 惡搞電話機器人 欣鼎電銷機器人 效果 ok電銷機器人 地圖標注軟件打印出來 如何查看地圖標注

為了追蹤所畫內(nèi)容,諸如畫圖應用程序、計算機輔助設計系統(tǒng)(computer-aided design system 簡稱CAD系統(tǒng))以及游戲等許多應用程序,都會維護一份包含當前顯示對象的列表。通常來說,這些應用程序都允許用戶對當前顯示在屏幕上的物體進行操作。比方說,在CAD應用程序中,我們可以對設計中的元素進行選擇、移動、縮放等操作

——《HTML5 Canvas核心技術》

在Canvas中 實現(xiàn)拖拽 也同樣如此,Canvas提供了一個名為 isPointInPath(x, y) 的API,判斷 點(x, y) 是否在路徑之中。如果在路徑之中,則返回true。于是我們可以有如下思路:

維護一個可以描述各個路徑的 數(shù)組 ,通過 ispointInPath(x, y) 判斷點擊位置是否在某一個路徑之中,如果在此路徑之中,選中此路徑,進行操作(移動、縮放等),再繪制圖形

此文我以 多邊形拖拽為例進行說明 ,Demo如下(后面的印子是錄屏軟件的原因:japanese_ogre:):

 

CodePen打開

Demo中的多邊形如何繪制之前做過總結,不再贅述:ghost::Canvas多邊形繪制

思路說明

下圖給了大致的說明及偽代碼,思路并不難,但有部分細節(jié)需要處理

 

代碼結構說明

此處列舉代碼結構及標注其思路,更詳細的代碼注釋已在CodePen之中

因為本文重點在拖拽(drag),所以對繪圖部分描述會較少

//繪制多邊形路徑函數(shù)
function drawPolygonPath

//多邊形類定義
class Polygon{ 
   ...
}

//根據(jù)點擊事件返回在canvas中的位置
function positoinInCanvas

//獲取兩點間直線距離
function getDistance

//開始階段,記錄拖拽對象
canvas.onmousedown

//拖拽階段,畫路徑,描邊
canvas.onmousemove

//結束階段,更新拖拽對象位置
canvas.onmouseup

關鍵部分說明

接下來開始代碼中的關鍵部分及細節(jié)處理

如何維護拖拽對象數(shù)組

在程序初始化時,我們定義一個polygonArray數(shù)組

polygonArray = []

在每次畫一個新的多邊形之后,都會new一個多邊形對象推入數(shù)組中進行維護

const polygon = new Polygon(mouseStart.get('x'), mouseStart.get('y'), sideNum, radius);
polygonArray.push(polygon);//記錄路徑對象

在后續(xù)點擊操作時,需要根據(jù)對應信息確定點擊位置是否在路徑之中

點擊時,如何選取要拖拽的對象

首先獲取點擊時在 canvas中 的對應位置,我的代碼用 mouseStart 記錄 xy
接著遍歷 polygonArray 中的 polygon ,遍歷中調(diào)用 polygon.createPath() ,通過 isPointInPath() 判斷點擊位置是否有路徑,有的話 draggingPolygon = polygon 結束函數(shù)

const pos = positionInCanvas(e, canvasLeft, canvasTop);//獲取在canvas中的像素位置
//記錄鼠標起始點s
mouseStart.set('x', pos.x);
mouseStart.set('y', pos.y);
...
for (let polygon of polygonArray) {
                polygon.createPath();
                if (ctx.isPointInPath(mouseStart.get('x'), mouseStart.get('y'))) {
                    draggingPolygon = polygon;
                    return;
                }
            }

拖拽時的計算

這部分要完全理解推薦大家根據(jù)Demo中兩個 console.log(draggingPolygon) 及代碼進行調(diào)試,因為我們是在 mousemove 階段,這個階段觸發(fā)函數(shù)非常頻繁

我盡量用語言表達清楚

首先計算 move 時與 mouseStart 的距離,記為diff,有x軸上的 offsetX ,也有y軸上的 offsetY

const
    pos = positionInCanvas(e, canvasLeft, canvasTop),
    diff = new Map([
      ['offsetX', pos.x - mouseStart.get('x')],
      ['offsetY', pos.y - mouseStart.get('y')]
    ]);

接著記錄當前拖拽對象的 centerXcenterY ,記為temp

let
    tempCenterX = draggingPolygon.centerX,
    tempCenterY = draggingPolygon.centerY;

這里就是難理解的點,為什么要記錄?繼續(xù)往下看,后面會使用到。

根據(jù) diff 中的offset,設置draggingPolygon新的中心位置

draggingPolygon.centerX += diff.get('offsetX');
draggingPolygon.centerY += diff.get('offsetY');

接著清空畫布進行繪制新的路徑和描邊

ctx.clearRect(0, 0, canvas.width, canvas.height);
for (let polygon of polygonArray) {
    drawPolygonPath(polygon.sideNum, 
        polygon.radius, 
        polygon.centerX, 
        polygon.centerY, ctx);
    ctx.stroke();
}

最后使用到上文中的 tempCenterXtempCenterY

draggingPolygon.centerX = tempCenterX;
draggingPolygon.centerY = tempCenterY;

為什么需要這么做呢?

因為我們的拖拽是 基于多邊形的原位置 ,而 mousemove 階段并 不能確定函數(shù)的最終位置 ,如果這時沒有復原的話,會出現(xiàn) "漂移" ,我把這兩行代碼注釋掉,效果如下:

 

如果我沒說清楚,墻裂推薦大家對代碼進行修改和調(diào)試

拖拽后的處理

拖拽完成后是處于 mouseup 階段,此時我們已經(jīng)確定dragginPolygon的最終位置,進行更新即可,最后置為null,排除 在沒有拖拽多邊形情況下,鼠標在畫布上移動觸發(fā)對應代碼

const
    pos = positionInCanvas(e, canvasLeft, canvasTop),
    offsetMap = new Map([
        ['offsetX', pos.x - mouseStart.get('x')],
        ['offsetY', pos.y - mouseStart.get('y')]
    ]);
draggingPolygon.centerX += offsetMap.get('offsetX');
draggingPolygon.centerY += offsetMap.get('offsetY');
draggingPolygon = null;

結語

其實這個功能實現(xiàn)并不難,關鍵是了解一個概念:通過維護當前顯示對象的列表及isPointInPath進行判斷來實現(xiàn)追蹤
最后歡迎大家交流學學習

參考資料

《HTML5 Canvas核心技術》

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:聊城 赤峰 金昌 綏化 阿壩 盤錦 萍鄉(xiāng) 中山

巨人網(wǎng)絡通訊聲明:本文標題《Canvas高級路徑操作之拖拽對象的實現(xiàn)》,本文關鍵詞  Canvas,高級,路徑,操作,之拖,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Canvas高級路徑操作之拖拽對象的實現(xiàn)》相關的同類信息!
  • 本頁收集關于Canvas高級路徑操作之拖拽對象的實現(xiàn)的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    国产不卡精品一区二区三区| 欧美激情一区二区三区在线 | 99热视热频这里只有精品| 欧美国产日韩久久久| 成人免费观看的视频黄页| 国产视频一区二区在线播放| 日韩在线观看免费| 高清一级做a爱过程不卡视频| 成人免费一级毛片在线播放视频| 一 级 黄 中国色 片| 高清一级做a爱过程不卡视频| 国产一级强片在线观看| 成人高清视频免费观看| 午夜在线亚洲男人午在线| 天天做人人爱夜夜爽2020毛片| 99久久精品国产免费| 久久精品道一区二区三区| 高清一级做a爱过程不卡视频| 中文字幕一区二区三区 精品| 精品视频免费在线| 精品国产一区二区三区精东影业| 成人a大片高清在线观看| 日韩中文字幕一区| 国产网站在线| 欧美另类videosbestsex视频| 欧美a级片免费看| 成人影视在线观看| 欧美激情一区二区三区中文字幕| 国产一区免费在线观看| 青青青草影院| 国产一区二区精品久久| 国产福利免费观看| 一级女性大黄生活片免费| 久久国产精品自由自在| 日韩免费在线视频| 美女免费精品高清毛片在线视| 欧美一级视| 美女免费精品高清毛片在线视| 午夜精品国产自在现线拍| 国产欧美精品午夜在线播放| 国产一区二区精品| 成人免费福利片在线观看| 国产成人精品一区二区视频| 国产亚洲免费观看| 国产高清视频免费观看| 999久久久免费精品国产牛牛| 国产精品1024永久免费视频| 亚洲 欧美 成人日韩| 国产亚洲精品aaa大片| 午夜在线亚洲男人午在线| 成人免费观看的视频黄页| 91麻豆高清国产在线播放| 欧美一级视频免费| 国产网站在线| 亚洲女初尝黑人巨高清在线观看| 国产视频一区二区在线播放| 色综合久久天天综合绕观看| 日日夜夜婷婷| 欧美激情一区二区三区在线 | 国产视频在线免费观看| 午夜久久网| 欧美爱色| 亚欧成人乱码一区二区| 日韩中文字幕在线观看视频| 黄色福利片| 欧美α片无限看在线观看免费| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 高清一级片| 亚洲精品影院一区二区| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 天天做人人爱夜夜爽2020毛片| 成人免费网站视频ww| 久久久久久久免费视频| 精品在线观看一区| 精品国产三级a∨在线观看| 欧美一级视| 可以在线看黄的网站| 精品在线观看一区| 四虎影视久久久| 成人影视在线观看| 欧美一级视| 欧美激情一区二区三区在线播放| 午夜欧美成人香蕉剧场| 色综合久久天天综合绕观看| 国产视频一区在线| 亚洲第一色在线| 黄视频网站在线免费观看| 国产a一级| 精品在线观看一区| 成人a大片高清在线观看| 高清一级片| 国产成人精品一区二区视频| 91麻豆精品国产片在线观看| 精品国产一区二区三区免费 | 成人a级高清视频在线观看| 国产成a人片在线观看视频| 国产一区二区精品| 欧美α片无限看在线观看免费| 国产一级强片在线观看| 成人免费观看的视频黄页| 一级毛片看真人在线视频| 成人影视在线观看| 成人高清视频免费观看| 久久国产精品自由自在| 亚洲精品中文一区不卡| 欧美日本免费| 欧美大片a一级毛片视频| 国产国语在线播放视频| a级毛片免费全部播放| 精品视频在线观看一区二区三区| 成人影院一区二区三区| 精品视频在线观看一区二区三区| 欧美激情在线精品video| 欧美激情一区二区三区视频| 欧美激情一区二区三区在线播放| 天天色色色| 一级毛片视频免费| 日本在线不卡视频| 深夜做爰性大片中文| 日本在线不卡视频| 国产高清视频免费观看| 日韩专区一区| 亚欧乱色一区二区三区| 国产麻豆精品视频| 日韩中文字幕在线观看视频| 精品视频在线观看视频免费视频| 99久久精品国产免费| 中文字幕97| 91麻豆国产福利精品| 成人免费观看的视频黄页| 青青青草影院| 色综合久久天天综合绕观看| 青青久久网| 精品在线观看一区| 色综合久久久久综合体桃花网| 91麻豆精品国产片在线观看| 色综合久久久久综合体桃花网| 二级特黄绝大片免费视频大片| 国产网站免费观看| 日本伦理黄色大片在线观看网站| 国产视频一区二区在线播放| 青青青草影院| 精品在线观看一区| 成人a级高清视频在线观看| 国产a一级| 国产一区免费在线观看| 韩国三级香港三级日本三级la | 欧美日本国产| 欧美大片a一级毛片视频| 国产精品1024永久免费视频| 亚洲第一色在线| 999久久久免费精品国产牛牛| 国产a视频| 国产精品123| 四虎影视久久久| 99久久精品费精品国产一区二区| 国产不卡在线看| 一级女性大黄生活片免费| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 久久精品人人做人人爽97| 国产伦久视频免费观看视频| 99久久网站| 国产视频一区在线| 美女免费精品高清毛片在线视| 久久久成人影院| 国产福利免费观看| 国产亚洲精品aaa大片| 九九久久99| 一 级 黄 中国色 片| 可以在线看黄的网站| 久久精品免视看国产明星| 日韩女人做爰大片| 中文字幕97| 天天做人人爱夜夜爽2020毛片| 欧美a级v片不卡在线观看| 一级女性大黄生活片免费| 99久久精品国产免费| 91麻豆国产福利精品| 黄色福利片| 亚洲精品影院一区二区| 日韩在线观看免费| 精品国产三级a∨在线观看| 欧美α片无限看在线观看免费| 日韩中文字幕在线播放| 国产视频一区二区在线播放| 日韩中文字幕一区| 欧美日本国产| 日日夜夜婷婷| 国产成人精品一区二区视频| 欧美激情一区二区三区在线 | 精品国产三级a∨在线观看| 天堂网中文在线| 亚洲 欧美 成人日韩| 国产网站在线| 国产精品123| 91麻豆高清国产在线播放| 成人a级高清视频在线观看| 九九久久99| 国产麻豆精品免费密入口| 成人a级高清视频在线观看|