这篇文章主要讲解了OpenGL如何绘制Bezier曲线,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
目前创新互联公司已为上千多家的企业提供了网站建设、域名、网络空间、网站托管维护、企业网站设计、荷塘网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。项目要求:
– 使用鼠标在屏幕中任意设置控制点,并生成曲线
– 使用鼠标和键盘的交互操作实现对曲线的修改。
项目总体介绍
本项目利用Bezier曲线生成算法生成可由用户自定义的曲线。可实现核心功能如下:
1、用户用鼠标左击屏幕任意处产生记录点。
2、鼠标右击屏幕任意处由先前的任意个数记录点和其先后关系生成Bezier曲线。
另有辅助输入功能:
1、按键盘‘C'键可清除所有记录点。
2、按键盘‘R'键可清除上一个记录点。
3、按键盘‘Q'键可推出程序。
项目设计思路
1、Bezier曲线介绍:
贝塞尔曲线就是这样的一条曲线,它是依据四个位置任意的点坐标绘制出的一条光滑曲线。在历史上,研究贝塞尔曲线的人最初是按照已知曲线参数方程来确定四个点的思路设计出这种矢量曲线绘制法。1962年,法国数学家Pierre Bézier第一个研究了这种矢量绘制曲线的方法,并给出了详细的计算公式,因此按照这样的公式绘制出来的曲线就用他的姓氏来命名是为贝塞尔曲线。
2、生成公式:
(1)线性公式(只有两个点情况)
给定点P0、P1,线性贝兹曲线只是一条两点之间的直线。这条线由下式给出:
且其等同于线性插值。
(2)二次方公式(三个点组成)
二次方贝兹曲线的路径由给定点P0、P1、P2的函数B(t)追踪:
TrueType字型就运用了以贝兹样条组成的二次贝兹曲线。
(3)三次方公式(四个点)
P0、P1、P2、P3四个点在平面或在三维空间中定义了三次方贝兹曲线。曲线起始于P0走向P1,并从P2的方向来到P3。一般不会经过P1或P2;这两个点只是在那里提供方向资讯。P0和P1之间的间距,决定了曲线在转而趋进P3之前,走向P2方向的“长度有多长”。
曲线的参数形式为:
现代的成象系统,如PostScript、Asymptote和Metafont,运用了以贝兹样条组成的三次贝兹曲线,用来描绘曲线轮廓。
(4)一般参数公式(n个点)
阶贝兹曲线可如下推断。给定点P0、P1、…、Pn,其贝兹曲线即:
N阶的贝兹曲线,即N-1阶贝兹曲线之间的插值。
#include#include #include #include //定义控制点数目的大值 #define MAX_CPTX 25 int ncpts=0;//实际控制点个数 static int width=600,height=600;//窗口大小 typedef struct { GLfloat x,y; } POINT; POINT cpts[MAX_CPTX];//存储控制点坐标 //求n! int JieCheng(int n) { if(n==1||n==0) { return 1; } else { return n*JieCheng(n-1); } } //求组合排列 double C(int n,int i) { return ((double)JieCheng(n))/((double)(JieCheng(i)*JieCheng(n-i))); } //求一个数u的num次方 double N(double u,int n) { double sum=1.0; if (n==0) { return 1; } for(int i=0;i 另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
名称栏目:OpenGL如何绘制Bezier曲线-创新互联
分享URL:http://njwzjz.com/article/csdipe.html