设为首页 加入收藏

TOP

基于OpenGL实现的多段Bezier曲线拼接(二)
2014-11-24 00:35:28 来源: 作者: 【 】 浏览:9
Tags:基于 OpenGL 实现 Bezier 曲线 拼接
Vector[vertexNum-2];
glVertex3dv(v1.getValue());
glVertex3dv(v2.getValue());
} glEnd();
}glDisable(GL_LINE_STIPPLE);
}


//////////////////////////////////////////////////////////////////////////
//if ( !_check() )
// return;


//rendering bezier cells...
system("CLS");
for (int i=0; i {
int pos = i * 3;
if ( (pos+3) < vertexNum )
renderBezierCell( BezierCell(pos, pos+1, pos+2, pos+3) );
}
//////////////////////////////////////////////////////////////////////////
}


// 3次bezier曲线经过vetex0和vextex3
void renderBezierCell(const BezierCell& cell)
{
double *pBuffer = new double[Bezier3CtrlPnt * 3];


cout << "----------------------------------------------------" << endl;


cout << "Vertex number : " << vertexNum << endl;
cout << "Cell number : " << cellNum << endl;
cout << "The render cell: " << cell[0] << " " << cell[1] << " " << cell[2] << " " << cell[3] << endl;


for (int i = 0, bg = 0; i<4; i++)
{
Vec3d v = vertexVector[ cell[i] ];
pBuffer[bg++] = v.x();
pBuffer[bg++] = v.y();
pBuffer[bg++] = v.z();

cout << v.x() << " " << v.y() << " " << v.z() << endl;
}cout << "----------------------------------------------------" << endl;


glMap1d(GL_MAP1_VERTEX_3, 0.0, 1.0, 3, Bezier3CtrlPnt, pBuffer);
glBegin(GL_LINE_STRIP);
{
for (int i = 0; i <= 30; i++)
gleva lCoord1f((GLfloat) i/30.0f);
} glEnd();


delete pBuffer; pBuffer = 0;
}


void clear()
{
cellNum = 0;
vertexNum = 0;


isFirstRender = true;


vertexVector.clear();
}
protected:
bool _check() { vertexNum =vertexVector.size();
return vertexNum == (cellNum - 1) * 3 + 4; }
void _updateVertexNum() { vertexNum=vertexVector.size();}


int cellNum; //单元个数
int vertexNum; //顶点个数


bool isFirstRender; //首次标志
std::vector vertexVector; //顶点数组


class cellRenderImple
{
public:
enum RenderStep
{
Push = 0,
Change = 1
};
cellRenderImple(){ setPush(); }
bool operator()(void) { return flag; }
void setPush() { flag = Push; }
void setChange() { flag = Change; }


RenderStep flag; //cell的渲染状态
} cellRenderState;
};


测试程序如下:


#include
#include
#include


#include "BezierCurve.h"


using namespace std;


enum WindowSize{
WinWidth = 1024,
WinHeight = 768
};


int g_Viewport[4];
double g_ModelMatrix[16];
double g_ProjMatrix[16];
BezierCurve myBezier;


//////////////////////////////////////////////////////////////////////////
void init();
void display();
void reshape(int w, int h);
void keyboard(unsigned char key, int x, int y);
void mouse(int button, int state, int x, int y);
void motion(int x, int y);


int main(int argc, char** argv)
{
glutInit(&argc, argv);
glutInitDisplayMode (GLUT_DOUBLE | GLUT_RGB);
glutInitWindowSize (WinWidth, WinHeight);
glutInitWindowPosition (100, 100);
glutCreateWindow (argv[0]);


init ();
glutDisplayFunc(display);
glutReshapeFunc(reshape);
glutKeyboardFunc (keyboard);
glutMouseFunc(mouse);
glutMotionFunc(motion);


glutMainLoop();


return 0;
}


void init(void)
{
glClearColor(0.0, 0.0, 0.0, 0.0);
glShadeModel(GL_SMOOTH);


myBezier.begin();
}


void display(void)
{
glClear(GL_COLOR_BUFFER_BIT);


glColor3f(1.0, 1.0, 0.0);
glPointSize(5.0);


glPushMatrix();
{
myBezier.renderCurve();
}glPopMatrix();


glutSwapBuffers();
}


void reshape(int w, int h)
{
glViewport(0, 0, (GLsizei) w, (GLsizei) h);
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
if (w <= h)
glOrtho(-5.0, 5.0, -5.0*(GLfloat)h/(GLfloat)w,
5.0*(GLfloat)h/(GLfloat)w, -5.0, 5.0);
else
glOrtho(-5.0*(GLfloat)w/(GLfloat)h,
5.0*(GLfloat)w/(GLfloat)h, -5.0, 5.0, -5.0, 5.0);
glMatrixMode(GL_MODELVIEW);
glLoadIdentity();
}


void keyboard(unsigned char key, int x, int y)
{
switch (key) {
case 27:
exit(0);
break;
}
}


void mouse(int button, int state, int x, int y)
{
double vertex[3];


//获取矩阵信息
glGetIntegerv(GL_VIEWPORT,

首页 上一页 1 2 3 下一页 尾页 2/3/3
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Android NDK中结合汇编分析Crash.. 下一篇OpenGL 投影矩阵的理解

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: