canvas的简单使用

2017-06-02  本文已影响0人  郭钰涛

Canvas 画布

canvas用途

兼容性

IE9以上和其他浏览器

canvas 标签

属性

方法

注意

css设置的宽高跟width/height设置的宽高 不同

Context环境

通过 getContext方法获取绘图环境(绘图上下文)(对象)
绘制图形通过该对象提供的方法/属性

基本绘图

路径

路径的开始和关闭

描边 stroke()

填充

快速矩形工具

圆形(圆弧)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        
        canvas{
            position: relative;
            border:1px solid #ccc;
        }
        /*#box{
            width: 20px;
            height: 20px;
            background: red;
            position: absolute;
            top: 0;
            left: 0;
        }*/
    </style>
</head>
<body>
    <canvas id="mycanvas">您的破浏览器不兼容</canvas>
    <input type="color" id="color">
    <button id="cl">清除</button> 
    <button id="eraser">橡皮擦</button>
    <div id="box">
        
    </div>  

    <script>
        var btn = document.getElementById("cl");
        var canvas = document.getElementById("mycanvas");
        var color = document.getElementById("color");
        var eraser = document.getElementById("eraser");
        var box = document.getElementById("box");
        //设置宽高
        canvas.width = 500;
        canvas.height = 500;

        //获取绘图环境
        var cxt = canvas.getContext("2d");

        canvas.onmousedown = function(e){
            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.stroke();
                cxt.strokeStyle = color.value;
                cxt.lineWidth = 100;
                cxt.stroke();
            }
        }
        canvas.onmouseup = function(){
            canvas.onmousemove=null;
        }

        
        btn.onclick = function(){
            cxt.clearRect(0,0,500,500);
        }

        eraser.onclick=function(){
            
            
            canvas.onmousedown=function(e){
                var x = e.clientX - canvas.offsetLeft;
                var y = e.clientY - canvas.offsetTop;
                console.log(x,y)
                cxt.clearRect(x-10,y-10,20,20);

                canvas.onmousemove =function(e){
                var x = e.clientX - canvas.offsetLeft;
                var y = e.clientY - canvas.offsetTop;
                console.log(x,y)
                cxt.clearRect(x-10,y-10,20,20);

                }
            }
            canvas.onmouseup=function(){
                canvas.onmousemove=null;
            }
        }
    </script>
</body>
</html>


 




上一篇 下一篇

猜你喜欢

热点阅读