<!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>
canvas簡易畫畫板(PC端和移動端)
最后編輯于 :
?著作權(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ù)。
【社區(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 而...