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>
相关推荐
Larcher31 分钟前
新手也能学会,100行代码玩AI LOGO
前端·llm·html
徐子颐43 分钟前
从 Vibe Coding 到 Agent Coding:Cursor 2.0 开启下一代 AI 开发范式
前端
小月鸭1 小时前
如何理解HTML语义化
前端·html
jump6801 小时前
url输入到网页展示会发生什么?
前端
诸葛韩信1 小时前
我们需要了解的Web Workers
前端
brzhang1 小时前
我觉得可以试试 TOON —— 一个为 LLM 而生的极致压缩数据格式
前端·后端·架构
yivifu2 小时前
JavaScript Selection API详解
java·前端·javascript
这儿有一堆花2 小时前
告别 Class 组件:拥抱 React Hooks 带来的函数式新范式
前端·javascript·react.js
十二春秋2 小时前
场景模拟:基础路由配置
前端
六月的可乐2 小时前
实战干货-Vue实现AI聊天助手全流程解析
前端·vue.js·ai编程