小編給大家分享一下canvas橡皮筋式線條繪圖的方法是什么,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯公司成立于2013年,是專業(yè)互聯網技術服務公司,擁有項目成都網站建設、網站設計網站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元硯山做網站,已為上家服務,為硯山各地企業(yè)和個人服務,聯系電話:13518219792
什么叫橡皮筋式
指畫圖時橡皮筋一樣伸縮自如。。
例子如下
思路
思路很簡單,只有橡皮筋式繪制功能要注意,以下總結mousedown,mousemove,mouseup三個階段的思路
mousedown:記錄start位置,drag(記錄是否處于拖動狀態(tài))設置為true,getImageData(橡皮筋效果關鍵1)
mousemove:獲取拖動時的位置pos,putImageData(對應getImageData,橡皮筋效果關鍵2),根據pos與start畫直線
mouseup:drag恢復為false
關鍵就在于putImageData()與getImageData()這兩個canvas的方法,putImageData()記錄了鼠標點下時的圖像,getImageData()對應還原。如果沒有執(zhí)行這兩個方法就會出現以下的效果
putImageData()相當于把“掃描”出來的線都擦掉
代碼
<canvas id="canvas" width="600" height="400" style="border: 1px solid black;"> </canvas> <script type="text/javascript"> let canvas = document.getElementById('canvas'), ctx = canvas.getContext('2d'), canvasLeft = canvas.getBoundingClientRect().left, //getBoundingClientRect()獲取元素位置 canvasTop = canvas.getBoundingClientRect().top; let imageData; //記錄圖像數據 let start = new Map([['x',null],['y',null]]); let drag = false;//記錄是否處于拖動狀態(tài) canvas.onmousedown = function (e) { let pos = positionInCanvas(e, canvasLeft, canvasTop); start.set('x', pos.x); start.set('y', pos.y); drag = true; //記錄imageData imageData = ctx.getImageData(0,0,canvas.width,canvas.height); } canvas.onmousemove = function (e) { if(drag === true){ let pos = positionInCanvas(e, canvasLeft, canvasTop); //相當于把掃描出來的線都擦掉,重新畫 ctx.putImageData(imageData, 0, 0); ctx.beginPath(); ctx.moveTo(start.get('x'), start.get('y')); ctx.lineTo(pos.x, pos.y); ctx.stroke(); } } canvas.onmouseup = function (e) { drag = false; } function positionInCanvas (e, canvasLeft, canvasTop) {//獲取canvas中鼠標點擊位置 return { x:e.clientX - canvasLeft, y:e.clientY - canvasTop } } </script>
以上是“canvas橡皮筋式線條繪圖的方法是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯行業(yè)資訊頻道!
分享題目:canvas橡皮筋式線條繪圖的方法是什么
本文URL:http://jinyejixie.com/article46/ghhghg.html
成都網站建設公司_創(chuàng)新互聯,為您提供網頁設計公司、品牌網站制作、網站建設、企業(yè)網站制作、網站內鏈、標簽優(yōu)化
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯