canvas画布中beginPath和closePath的作用要点

1.画笔画完一个图案后,立即又回到了原点,所以下次如果没有beginPath,就会从原点重新开始

2.beginPath相当于让画笔从原点抬起,重新开始一个新路径,不重复走之前的路径,所以不会覆盖之前的路径

3.closePath相当于让画笔以最近的直线回到原点位置,会有路径

以下案例是画三条不一样的直线:

但是结果却出现了三条一样宽度的直线:宽度都是30

出现这种情况的原因:没有使用beginPath()

使用beginPath后的效果:

使用beginPath的代码:

html 复制代码
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Document</title>
    </head>
    <body>
        <div>画三个不一样的直线</div>
        <canvas id="myCanvas" width="500" height="500"> </canvas>
    </body>
    <script>
        var canvas = document.getElementById('myCanvas')
        var ctx = canvas.getContext('2d')
        // lineWidth是改变线条的粗细,默认是一个像素
        ctx.moveTo(20, 50)
        ctx.lineTo(200, 50)
        ctx.lineWidth = 5
        ctx.stroke()
        // ctx.closePath()
        // 1.画笔画完一个图案后,立即又回到了原点,所以下次如果没有beginPath,就会从原点重新开始
        // 2.beginPath相当于让画笔从原点抬起,重新开始一个新路径,不重复走之前的路径,所以不会覆盖之前的路径
        // 3.closePath相当于让画笔以最近的直线回到原点位置,会有路径
        ctx.beginPath()
        ctx.moveTo(20, 100)
        ctx.lineTo(200, 100)
        ctx.lineWidth = 10
        ctx.stroke()
        // ctx.closePath()

        ctx.beginPath()
        ctx.moveTo(20, 150)
        ctx.lineTo(200, 150)
        ctx.lineWidth = 30
        ctx.stroke()
        // ctx.closePath()
    </script>
</html>
相关推荐
灵感__idea3 小时前
Hello 算法:让前端人真正理解算法
前端·javascript·算法
向葭奔赴♡3 小时前
CSS是什么?—— 网页的“化妆师”
前端·css
黑犬mo3 小时前
在Edge、Chrome浏览器上安装uBlock Origin插件
前端·edge
excel3 小时前
🧩 Vue 3 watch 源码详解(含完整注释)
前端·javascript·vue.js
大前端helloworld3 小时前
前端梳理体系从常问问题去完善-网络篇
前端·面试
excel4 小时前
🌿 一文看懂 Vue 3 的 watch 源码:从原理到流程
前端
繁依Fanyi4 小时前
让工具说话:我在 Inspira Board 里用 AI 把“能用、好用、可复用”落成了日常
前端
weixin_456904275 小时前
C# 中的回调函数
java·前端·c#
kura_tsuki5 小时前
[Web网页] LAMP 架构与环境搭建
前端·架构
yinuo6 小时前
UniApp+Vue3多分包引入同一 npm 库被重复打包至 vendor 的问题分析与解决
前端