首页 > HTML & CSS > canvas 入门教程 > 绘制二次贝塞尔曲线

绘制二次贝塞尔曲线

1. 前言

Bézier curve(贝塞尔曲线)于1959年,由法国物理学家与数学家 Paul de Casteljau 所发明,于1962年,由法国工程师皮埃尔·贝塞尔(Pierre Bézier)所广泛发表,并用于汽车的车身设计。贝赛尔曲线为计算机矢量图形学奠定了基础,它的主要意义在于无论是直线或曲线都能在数学上予以描述。

贝塞尔曲线分为两种:二次贝塞尔曲线和三次贝塞尔曲线。本节我们主要介绍二次贝塞尔曲线。

2. 二次贝塞尔曲线

二次贝塞尔曲线是一种二次曲线,它只能向一个方向弯曲,由三个点来定义:两个锚点及一个控制点,控制点用来控制曲线的形状。

我们先看一下二次贝塞尔曲线的绘制过程的:

二次贝塞尔曲线也可以用三个特征切线定义,曲线的第一部分与上下文点和控制点形成的虚线相切,曲线的顶部与 midpoint 1 和 midpoint 2 形成的虚线相切,曲线的最后部分与控制点和终点形成的虚线相切。如图所示:

在 canvas 中,绘制二次贝塞尔曲线和我们前面学过的 lineTo 方法类似,都需要在当前上下文中存在一个已有路径的终点作为贝塞尔曲线的起点,既然起点是已知的,那么只需知道控制点和终点,就能唯一确定一条二次贝塞尔曲线。

具体绘制方法为:

ctx.quadraticCurveTo(cpx,cpy,x,y);

先看整体案例:

运行结果:

这样我们就绘制了一条二次贝塞尔曲线。

3. 方法整理

本小节中我们使用到一个新的方法 quadraticCurveTo()

3.1 quadraticCurveTo() 方法

quadraticCurveTo 方法作用是绘制一条二次贝塞尔曲线。

变量说明:

变量名 类型 是否必须 说明
cpx Number 控制点位置的X坐标。
cpy Number 控制点位置的Y坐标。
x Number 终点位置的X坐标。
y Number 终点位置的Y坐标。

4. 总结

本小节我们主要学习了利用 quadraticCurveTo 方法绘制一条二次贝塞尔曲线,这个方法有四个参数,分别是控制点和终点的坐标。我们下一节开始学习三次贝塞尔曲线。

本文来自互联网用户投稿,不拥有所有权,该文观点仅代表作者本人,不代表本站立场。
访问者可将本网站提供的内容或服务用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯本网站及相关权利人的合法权利。
本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站,邮箱:80764001@qq.com,予以删除。
© 2023 PV138 · 站点地图 · 免责声明 · 联系我们 · 问题反馈