如何计算三次贝塞尔曲线的长度

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何计算三次贝塞尔曲线的长度相关的知识,希望对你有一定的参考价值。

在图形图像编程时,我们常常需要根据一系列已知点坐标来确定一条光滑曲线。其中有些曲线需要严格地通过所有的已知点,而有些曲线却不一定需要。在后者中,比较有代表性的一类曲线是贝塞尔曲线(Bézier Splines)。
  网友们可能注意到,贝塞尔曲线广泛地应用于很多图形图像软件中,例如Flash、Illstrator、CoralDRAW和Photoshop等等。什么是贝塞尔曲线呢?

贝塞尔曲线就是这样的一条曲线,它是依据四个位置任意的点坐标绘制出的一条光滑曲线。我们不妨把这四对已知点坐标依次定义成(x0,y0)、 (x1,y1)、(x2,y2)和(x3,y3)。贝塞尔曲线必定通过首尾两个点,称为端点;中间两个点虽然未必要通过,但却起到牵制曲线形状路径的作用,称作控制点。
  在历史上,研究贝塞尔曲线的人最初是按照已知曲线参数方程来确定四个点的思路设计出这种矢量曲线绘制法。涕淌为了向大家介绍贝塞尔曲线的公式,也故意把问题的已知和所求颠倒了一下位置:如果已知一条曲线的参数方程,系数都已知,并且两个方程里都含有一个参数t,它的值介于 0、1之间,表现形式如下所示:
  x(t) = ax * t ^ 3 + bx * t ^ 2 + cx * t + x0
  y(t) = ay * t ^ 3 + by * t ^ 2 + cy * t + y0
由于这条曲线的起点(x0,y0)是已知的,我们可以用以下的公式来求得剩余三个点的坐标:
  x1 = x0 + cx / 3
  x2 = x1 + ( cx + bx ) / 3
  x3 = x0 + cx + bx + ax
  y1 = y0 + cy / 3
  y2 = y1 + ( cy + by ) / 3
  y3 = y0 + cy + by + ay
  你细细观察一下就知道了,无论方程的已知和所求是什么,总是有六个未知数,并且我们总能找到六个等式(记住(x0,y0)总是已知的),也就是说,上面的方法是完全可逆的,因此我们可以根据四个已知点坐标来反求曲线参数公式的系数。稍微一变换就得到了下面这组公式:
cx = 3 * ( x1 - x0 )
  bx = 3 * ( x2 - x1 ) - cx
  ax = x3 - x0 - cx - bx
  cy = 3 * ( y1 - y0 )
  by = 3 * ( y2 - y1 ) - cy
  ay = y3 - y0 - cy - by
所以说,对于坐标任意的四个已知点,你总能创建一条贝塞尔曲线。
参考技术A 楼主!typedefstructfloatx;floaty;Point2D;/*cp在此是3个元素的数组:cp[0]为起点,或上图中的P0cp[1]为第一控制点,或上图中的P1cp[2]为第二控制点,或上图中的P2t为参数值,0*/voidComputeBezier(Point2D*cp,intnumberOfPoints,Point2D*curve)floatdt;inti;dt=1.0/(numberOfPoints-1);for(i=0;i

css 自定义三次贝塞尔曲线

transition: transform 333ms cubic-bezier(1, .06, .08, 1);
/*网址: cubic-bezier.com*/

以上是关于如何计算三次贝塞尔曲线的长度的主要内容,如果未能解决你的问题,请参考以下文章

计算单元化三次贝塞尔曲线的多项式系数

贝塞尔曲线公式 求详细解释

三次贝塞尔曲线描边轮廓

如何使用三次贝塞尔曲线进行滚动

三次方贝塞尔曲线的绘制

贝塞尔曲线