canvas簡易畫畫板(PC端和移動端)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8" />
    <title>Document</title>
    <meta name="viewport" content="width=device-width,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no"/>
    <style type="text/css">
        canvas {
            border: 1px solid #ccc;
        }
        html{
            overflow: hidden;
        }
        *{
            margin: 0px;
            padding: 0px;
        }
    </style>
</head>
<body>
    <input id="colorSelect" type="color" name="" value="" placeholder="">
    <input type="submit" name="" value="清空畫板" onclick="qingkong()">
    <br>
    <canvas width="500" height="500" id="canvas">
        您的瀏覽器不支持
    </canvas>
</body>
<script>
  var selector = document.getElementById("colorSelect");
    // 聲明color的全局變量
    var color = null;
    // 獲取color的顏色
    selector.onchange = function(){
        color = this.value;
    }
    var canvas = document.getElementById("canvas");
    var cxt = canvas.getContext("2d");    
    if(document.documentElement.clientWidth>768){   
           huaD();
           qingkong();
 }else{
        huaS();
        qingkong();
  }
//當(dāng)屏幕發(fā)生變化時(shí)觸發(fā) 
 window.onresize = function(){          
   if(document.documentElement.clientWidth>768){    
           huaD();
           qingkong(); 
 }else{
         huaS();
        qingkong();
 }
}
//pc端觸發(fā)
      function huaD(){
         canvas.onmousedown = function(e){
        // 獲取canvas畫面上的x y 軸
        var x = e.clientX - canvas.offsetLeft;
        var y = e.clientY - canvas.offsetTop;
        cxt.beginPath();
        cxt.moveTo(x,y);
        canvas.onmousemove = function(e){
            var x = e.clientX - canvas.offsetLeft;
            var y = e.clientY - canvas.offsetTop;
            cxt.lineTo(x,y);
            cxt.strokeStyle=color;
            cxt.stroke();
        }
        // 鼠標(biāo)抬起事件 把上一個(gè)的move的事件清空
        canvas.onmouseup = function(){
            canvas.onmousemove = null;
        }
    }
   
  }
//移動端觸發(fā)
  function huaS(){
            canvas.addEventListener("touchstart", function(e){
             var x = e.changedTouches[0].clientX - e.target.offsetLeft;
             var y = e.changedTouches[0].clientY - e.target.offsetTop;
             cxt.beginPath();
             cxt.moveTo(x,y);
 
             canvas.addEventListener("touchmove", function(e){                 
                e.preventDefault(); 
                var x = e.changedTouches[0].clientX - e.target.offsetLeft;
                var y = e.changedTouches[0].clientY - e.target.offsetTop;              
                cxt.lineTo(x,y);
                cxt.strokeStyle=color;
                cxt.stroke();         
            }, false)
        }, false)
  }
//清空畫板
 function qingkong(){
        cxt.clearRect(0,0,500,500);
        console.log(11);
     }

//禁止瀏覽器動來動去
  document.body.addEventListener("touchmove", function(e){
        e.preventDefault();
     })
</script>


</html>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 場景 現(xiàn)在的需求是這樣,在pc端訪問www.one.com和m.one.com都跳轉(zhuǎn)到www.one.com 而...
    阿亮私語閱讀 11,425評論 0 5
  • 冰天雪地的夜里 身邊怎么少了你 無名指上的戒指 緊緊握在手心里 大霧遮住了光遮住前方遮住你的眼 忘了過去忘了未來忘...
    單洛溪閱讀 264評論 0 0
  • 門 文/厲雄(西班牙) 客廳的門,有鑰匙轉(zhuǎn)動的聲音 一圈一圈,夾雜著整串鑰匙的環(huán)佩聲 急迫的,潛藏著危機(jī) 多少回,...
    厲雄閱讀 158評論 0 0
  • 兩歲十一個(gè)月。 爸爸媽媽和朋友們聚會,帶著他一起玩。晚上要去吃飯,爸爸用小車推著他,邊走邊和大家聊天。說起地鐵早高...
    不離不染閱讀 224評論 2 1

友情鏈接更多精彩內(nèi)容