【canvas绘制图形】


一、绘制圆形

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        #cav{
            border: 1px solid #ccc;
        }
    </style>
</head>
<body>
    <!-- 推荐在canvas标签上去写宽和高
    宽高比 2 :1 -->
    <canvas id="cav" width="600px" height="300px"></canvas>
    <script>
        let cav = document.getElementById('cav');
        let c = cav.getContext('2d');
        /* c.arc(x, y, radius, starAngle,endAngle, anticlockwise) */
        /*   x和y	圆心的x坐标和y坐标
            radius	圆形的半径
            starAngle和endAngle	开始的角度和结束的角度
            anticlockwise	逆时针(true),顺时针(false) */
        c.beginPath();
        /* Math.PI表示180度 */
        /* 圆多大是由半径控制的 */
        c.arc(150,150,100,0,Math.PI*3/2,false)
        c.fillStyle = 'blue'
        c.fill()
        c.closePath();
    </script>
</body>
</html>

二、绘制三角形

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        #cav{
            border: 1px solid #ccc;
        }
    </style>
</head>
<body>
    <!-- 推荐在canvas标签上去写宽和高
    宽高比 2 :1 -->
    <canvas id="cav" width="600px" height="300px"></canvas>
    <script>
        let cav = document.getElementById('cav');
        let c = cav.getContext('2d');
        c.beginPath();//开始创建路径
        c.moveTo(10,10)
        c.lineTo(100,150)
        c.lineTo(200,10)
        c.lineTo(10,10)
        //设置线条的颜色值
        c.strokeStyle = 'red'
        //设置线条的粗细
        c.lineWidth = "5"
        //填充颜色
        c.fillStyle = 'blue'
        //填充
        c.fill();
        c.closePath();
        c.stroke();

        /* 如果需要闭合路径,开始新的起点路径时,都需要创建和关闭路径 */
        c.beginPath();//开始创建路径
        c.moveTo(210,10)
        c.lineTo(250,150)
        c.lineTo(300,10)
        c.lineTo(210,10)
        //设置线条的颜色值
        c.strokeStyle = 'blue'
        //设置线条的粗细
        c.lineWidth = "5"
        c.fillStyle = 'yellow'
        c.fill();
        c.closePath();
        c.stroke();
    </script>
</body>
</html>

三、 绘制矩形

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        #cav{
            border: 1px solid #ccc;
        }
    </style>
</head>
<body>
    <!-- 推荐在canvas标签上去写宽和高
    宽高比 2 :1 -->
    <canvas id="cav" width="600px" height="300px"></canvas>
    <script>
        let cav = document.getElementById('cav');
        let c = cav.getContext('2d');

        c.fillStyle='red'
        //填充矩形
        c.fillRect(20,20,200,100)

        //绘制矩形边框
        c.lineWidth = '10'
        c.strokeStyle = "pink";
        c.strokeRect(20,20,200,100)

       
        
        cav.onmousedown = function(e){
            let event = e||window.event;
            console.log(event.clientX);
            console.log(event.clientY);
             /* 清除矩形内的一块区域 */
            c.clearRect(event.clientX,event.clientY,300,200)
        }
    </script>
</body>
</html>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值