前言

画曲线要用到二次贝塞尔曲线或三次贝塞尔曲线。贝塞尔曲线是计算机图形学中相当重要的参数曲线,在一些比较成熟的位图软件中也有贝塞尔曲线工具,如 PhotoShop。

二次贝塞尔曲线

二次贝塞尔曲线在一个平面中有三个点构成,P0、P1 和 P2。如下图,黑色的点与绿色线段的两端同时运动画出贝塞尔曲线,P0 是贝塞尔曲线的起始点,P1 是贝塞尔曲线的控制点,P2 是贝塞尔曲线的结束点

在 Canvas 中绘制二次贝塞尔曲线是 quadraticCurveTo(cpx, cpy, x, y) 函数,函数中有四个参数:

  1. cpx:贝塞尔控制点的 x 坐标,图中 P1 在画布中的 x 坐标;
  2. cpy:贝塞尔控制点的 y 坐标,图中 P1 在画布中的 y 坐标;
  3. x:结束点的 x 坐标,图中 P2 在画布中的 x 坐标;
  4. y:结束点的 y 坐标,图中 P2 在画布中的 y 坐标。
let canvas = document.getElementById('canvas');
let ctx = canvas.getContext('2d'); ctx.beginPath();
ctx.moveTo(10, 200); // P0 的起始坐标
ctx.quadraticCurveTo(60, 80, 200, 200);
ctx.lineWidth = 2;
ctx.strokeStyle = '#ff0000';
ctx.stroke();

确定路径的起始点,也就是moveTo(10, 200)。用二次贝塞尔曲线绘制曲线,前两个参数是贝塞尔曲线的控制点,也就是 P1;后两个参数是贝塞尔曲线最终运动的结束点,也就是 P2。

三次贝塞尔曲线

三次贝塞尔曲线在一个平面中有四个点构成,P0、P1、P2 和 P3。如下图,P0 是贝塞尔曲线的起始点,P1 和 P2 是贝塞尔曲线的控制点,P3 是贝塞尔曲线的结束点。黑色的点与绿色线段的两端同时运动画出贝塞尔曲线。

在 Canvas 中绘制二次贝塞尔曲线是 quadraticCurveTo(cp1x, cp1y, cp2x, cp2y, x, y) 函数,函数中有六个参数:

  1. cp1x:贝塞尔控制点的 x 坐标,图中 P1 在画布中的 x 坐标;
  2. cp1y:贝塞尔控制点的 y 坐标,图中 P1 在画布中的 y 坐标;
  3. cp2x:贝塞尔控制点的 x 坐标,图中 P2 在画布中的 x 坐标;
  4. cp2y:贝塞尔控制点的 y 坐标,图中 P2 在画布中的 y 坐标;
  5. x:结束点的 x 坐标,图中 P3 在画布中的 x 坐标;
  6. y:结束点的 y 坐标,图中 P3 在画布中的 y 坐标。
let canvas = document.getElementById('canvas');
let ctx = canvas.getContext('2d');
ctx.beginPath();
ctx.moveTo(30, 250);
ctx.bezierCurveTo(20, 120, 150, 120, 250, 250);
ctx.lineWidth = 2;
ctx.strokeStyle = '#FF0000';
ctx.stroke();

最终效果图如下:

最新文章

  1. CF460D Little Victor and Set (找规律)
  2. 编写windows7 bat运行脚本
  3. EXCEL datatable 根据列名自动写入到相应属性、字段或列中
  4. [Hadoop 周边] 浅谈大数据(hadoop)和移动开发(Android、IOS)开发前景【转】
  5. 【POJ】【3164】Commond Network
  6. JMS基础(1)
  7. python学习——DAY1
  8. Arduino入门学习
  9. 使用canvas实现擦除效果
  10. COGS 1299. bplusa【听说比a+b还要水的大水题???】
  11. ubuntu自动登录tty1(shell,text)配置
  12. css多类选择器
  13. python类的两种创建方式
  14. 我的SSH框架实例(附源码)
  15. 快速部署私人git服务--基于docker化Gogs
  16. poj2185 kmp求最小覆盖矩阵,好题!
  17. HDU 1160:FatMouse's Speed(LIS+记录路径)
  18. linux 磁盘挂载及查看磁盘
  19. 在vue-cli搭建的项目中在后台mock接口中支持req.body和req.cookies
  20. LeetCode CombinationSum II

热门文章

  1. Spring框架之IOC入门
  2. base64解析爬取糗百
  3. Redis的数据被删除,占用内存咋还那么大?
  4. 前端Ui设计常用WEB框架
  5. 常用的渗透测试工具——SQLMap安装
  6. json提取器和beanshell处理器组合,将提取的所有id以数组返回
  7. 【运维笔录】局域网实现HTTPS访问,只需Nginx + mkcert
  8. [cocos2d-x]从源码角度思考convertToWorldSpace()与convertToWorldSpaceAR()坐标系的转换
  9. group by 语句怎么优化?
  10. 从历代GC算法角度刨析ZGC