成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

canvas橡皮筋式線條繪圖的方法是什么

小編給大家分享一下canvas橡皮筋式線條繪圖的方法是什么,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯公司成立于2013年,是專業(yè)互聯網技術服務公司,擁有項目成都網站建設、網站設計網站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元硯山做網站,已為上家服務,為硯山各地企業(yè)和個人服務,聯系電話:13518219792

什么叫橡皮筋式

指畫圖時橡皮筋一樣伸縮自如。。  
例子如下

canvas橡皮筋式線條繪圖的方法是什么

思路

思路很簡單,只有橡皮筋式繪制功能要注意,以下總結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í)行這兩個方法就會出現以下的效果

canvas橡皮筋式線條繪圖的方法是什么

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)新互聯

成都網站建設
积石山| 拉萨市| 大庆市| 尚义县| 福清市| 福清市| 福清市| 黄龙县| 潮州市| 泰州市| 会宁县| 乃东县| 延津县| 连云港市| 锦州市| 广南县| 灌南县| 澄城县| 莲花县| 积石山| 淮北市| 新龙县| 治多县| 邢台县| 晋城| 绥棱县| 安庆市| 广饶县| 田林县| 大足县| 耒阳市| 吉林省| 穆棱市| 扎赉特旗| 克东县| 托克托县| 左云县| 镇宁| 溆浦县| 文水县| 陕西省|