1曲线与曲面(CurvesandSurfaces)2本章目标曲线的表示方法重点掌握Bezier曲线学会使用OpenGL的函数为什么要研究曲线与曲面计算机图形学两大基本任务建模绘制3为什么要研究曲线与曲面建立复杂模型一个球面复杂曲面电话人脸赛车4Rzyx222为什么要研究曲线与曲面5为什么要研究曲线与曲面使用曲面曲线的好处控制物体形状建模修改保证光滑与连续性可导性易于绘制67主要内容参数曲线基础参数多项式曲线三次Hermite曲线Bezier曲线Bezier曲面OpenGL相关函数8参数曲线基础曲线的表示形式非参数表示和参数表示非参数表示显式表示坐标间建立函数关系不能建立多值曲线隐式表示看做是两曲面的交坐标变量间可以多对1)()(xgzxfy0922zyx0),,(0),,(zyxgzyxf9曲线的表示形式参数表示参数方程参数表示的矢量表示t规范到[0,1]:矢量表示:P=[x,y,z]T,P(t)=[x(t),y(t),z(t)]Tt可以表示时间、角度等量],[,)()()(battzztyytxxabatt]1,0[)(ttPP10曲线的表示形式如:直线方程的矢量表示如:圆]1,0[)()(]1,0[)(010010010ttyyyytxxxxttPPPPP0P1P(t)01t010xxxxtt反映了P在P0P1间的相对位置010xxxxt]360,0[sincos0RyRxθ反映了半径与X轴的夹角P(θ)11曲线的表示形式参数表示的优点容易确定曲线边界。由参数区间确定表示形式不变性。不依赖于坐标系的选取表示能力强。利于控制点来控制曲线形状,如后面将要学到的Bezier曲线12切矢量、法矢量、曲率和绕率位置矢量矢量表示:P=P(t),0≤t≤1参数方程导数正则点:k=1时,对t=t0,P'(t0)≠0正则曲线:所有点是正则点]1,0[,)()()(ttzztyytxx,,,])(,)(,)([)()()(10ddddddddTkttzttyttxttPtPkkkkkkkkk13切矢量、法矢量、曲率和绕率切矢量(tangentvector)参数t递增一个单位时三个坐标变量的变化量弧长对正则曲线,定义弧长:)(')(')(')()('tztytxdttdPtP222011d)(dd)(dd)(dd)(ddd)(dlim)(lim)(ttzttyttxttPtttPPPnLtstniiinn=其中14切矢量、法矢量、曲率和绕率弧长参数表示)()()()(0d)(ddd)(d0sPPtPPtssttssttPdtdstttPst可以用弧长参数表示为曲线存在反函数的单调函数是关于参数15切矢量、法矢量、曲率单位切矢量记T(s)为P=P(s)上任意一点的切矢量。则T(s)为单位切矢量1)(dd/d)(d/))(()(d)(ddd)(d0tPtttPdsdtdttsdPdssdPttPdtdstttPstdssdPsT)(][16切矢量、法矢量、曲率和绕率法矢量对等式两边求导后有与垂直主法矢量(normal)副法矢量(binormal)1|)(|dddddd)(2sTtPtPsttPsPsT|)(|)()(sssTTN02sTsTsTsT|)(|)(')(sssNNB法矢量(normalvector)密切平面(osculatingplane)T、N构成切平面(tangentplane)B、T构成法平面(normalplane)N、B构成切矢量、法矢量、曲率和绕率17|)()(|)()(ttttPPPPB)(|)()(|)()()(ttttttPPPPPPN切平面切矢量、法矢量、曲率和绕率1819切矢量、法矢量、曲率和绕率曲率(curvature)曲线的弯曲程度曲率半径sskslim)(0)(1)(skspP(s)点处的曲率切矢量、法矢量、曲率和绕率绕率(Torsion)对两边求导对两边求导B'与N平行度量曲线的扭曲程度200ssssTBTB0ssTB0ssTB02sB02ssBBB'与T垂直B'与B垂直ssNBssslim)(0切矢量、法矢量、曲率和绕率两边求导后Frenet–Serret公式21sssTBNsssBTN22参数连续性与几何连续性参数连续性传统的、严格的连续性曲线P=P(t)在t=t0处n阶参数连续,如果它在t0处n阶左右导数存在,并且满足记为CnnkdttPddttPdttkkttkk,,1,0,)()(0023参数连续性与几何连续性几何连续性直观的、易于交互控制的连续性0阶几何连续称曲线P=P(t)在t=t0处0阶几何连续,如果它在t0处位置连续,即记为:G01阶几何连续称曲线P=P(t)在t=t0处1阶几何连续,如果它在t0处GC0,并且切矢量方向连续,即记为:G1)()(00tPtP任一常数为0)(')('00tPtP参数曲面曲面参数表示曲面上的点曲面上的切向量曲面上的法向量角点24]1,0[]1,0[,,),(),(),(vuvuzzvuyyvuxx),(00vuP),(00vuuP),(00vuvP),(),(),(000000vuvuvuvuPPN)0,1(),1,1(),1,0(),0,0(PPPP25参数连续性与几何连续性几何连续性(续)2阶几何连续*称曲线P=P(t)在t=t0处2阶几何连续,如果它在t0处(1)G1(2)副法矢量方向连续(3)曲率连续)()(00tBtB)()(00tktk26曲线与曲面参数曲线基础参数多项式曲线三次Hermite曲线Bezier曲线Bezier曲面OpenGL相关函数27参数多项式曲线为什么采用参数多项式曲线?表示最简单理论和应用最成熟n次多项式曲线],[)()()(10101010ttztzztztytyytytxtxxtxnnnnnn28参数多项式曲线矩阵表示矢量表示加权和形式缺点Pi没有明显的几何意义Pi与曲线的关系不明确,导致曲线的形状控制困难CTttzzzyyyxxxtztytxtPnnnn1)()()()(101010]1,0[)(10tPttPPCTtPnnFergusoncurve29参数多项式曲线参数多项式曲线的矩阵表示矩阵表示矩阵分解几何矩阵G=[G0G1…Gn]控制顶点Gi基矩阵M:MT确定了一组基函数TGΜGΜC)(tP]1,0[)(0ttBtiniiGCTPtBi30参数多项式曲线参数多项式曲线的矩阵表示(续)例子:直线段的矩阵表示GMT]1,0[11011)1()(1010ttPPtPtPtPP0P1控制顶点:P0;P0+P1基函数:1-t;ttMT31参数多项式曲面矩阵表示矢量表示形式CVUT10101100010011)()()()(nmnmmnnmvvGGGGGGGGGuutztytxtP1,01,0,,)(00TvuvuPtPminjjiijCVU32参数多项式曲线参数多项式曲面的矩阵表示矩阵表示矩阵分解几何矩阵控制顶点GijMUU、MVV分别确定了两组基函数mnmmnnGGGGGGGGG101011000100VVUVUtPGΜΜUGΜΜCTTT)(1,01,0,,),(00,,TvuvBuBGvuPminjnjmiijCVUvBuBnjmi,,33参数多项式曲线生成方法流程:P(t)=P0+P1t+…+Pntn]1,0[t参数离散nit0计算型值点折线niP0连接型值点计算一个型值点的运算量乘法:n(n+1)/2次加法:n次34参数多项式曲线参数多项式曲线的生成(续)Horner迭代算法)()(0,2,1,)()()(01tRtPnnkPttRtRPtRkkknn结果:令n次乘法和n次加法35曲线与曲面参数曲线基础参数多项式曲线三次Hermite曲线Bezier曲线Bezier曲面OpenGL相关函数369.3三次Hermite曲线三次Hermite曲线的定义给定4个矢量P0,P1,R0,R1,称满足下列条件的三次多项式曲线P(t)为Hermite曲线1010)1(',)0(')1(,)0(RPRPPPPPP0P1R0R137Hermite曲线矩阵表示]1,0[)(tTMGtP1T10T01T10T03210|'0010|'1111|0001|RMGTMGRMGTMGPMGTMGPMGTMGHHtHHHHtHHHHtHHHHtHHCTttzzzyyyxxxtztytxtPnnnn1)()()()(101010n次多项式参数方程389.3三次Hermite曲线合并解(不唯一)HHHGRRPPMG取][301020101110001110101100121023002301301020101110001130102010111000111HHHHMGMG39三次Hermite曲线基矩阵与基函数(调和函数))()()()(223231111001210230023011010323232332tHtHtGtGttttttttttttTMHP(t)=P0G0(t)+P1G1(t)+R0H0(t)+R1H1(t)基函数为权:G0(t);G1(t);H0(t);H1(t)Hermite曲线上的点为P0、P1、R0、R1的加权和40三次Hermite曲线形状控制改变端点位置矢量P0,P1调节切矢量R0,R1的方向改变切矢量R0,R1的长度41三次Hermite曲线几何变换仿射不变性:对曲线的几何变换等价于对P0,P1,R0,R1做几何变换曲线生成取型值点:ti对每个ti,计算P(ti)42曲线与曲面参数曲线基础参数多项式曲线三次Hermite曲线Bezier曲线Bezier曲面OpenGL相关函数PierreÉtienneBézier(1910-1999)法国工程师机械工程学位电子工程学位雷诺公司并非发明Bézier曲线PauldeCasteljau4344Bezier曲线Bezier曲线几何造型的基本工具目前在很多图形软件中广泛应用(如