在OpenGL中实现橡皮筋技术,并学会简单的鼠标键盘交互式设备的使用以及交互式绘图技术的实现
发布时间:2011-06-29 00:33:00
发布时间:2011-06-29 00:33:00
计算机图形学实验报告
1、 实验目的和要求
在OpenGL中实现橡皮筋技术,并学会简单的鼠标键盘交互式设备的使用以及交互式绘图技术的实现。
2、 实验内容
橡皮筋技术的关键在于控制图形随着用户的操作而不断发生变化,此时要擦除原有的图形而形成新的图形。因此在本实验中要学习这种方法。
3、 实验步骤
1) 相关算法及原理描述
鼠标响应函数: void MousePlot
在OpenGL程序中,使用鼠标的方法是注册一个鼠标响应函数,对鼠标在窗口范围内的按键按下或松开事件进行处理,其中MousePlot函数是鼠标响应函数,它包含四个参数:
void MousePlot (Glint Button,Glint xMouse,GLint action ,Glint yMouse)
此外GLUT还提供了两用于处理鼠标移动的注册函数
GluMotionfunc(MouseMove)
GluPassiveMotionFunc(PassiveMouseMove)
2) 程序调试、测试与运行结果分析
运行结果如下图,程序调试成功,并且能正常显示,唯一不足之处:由于编程水平有限,不会把直线和矩形橡皮筋的两个程序合并在一起进行处理,因此直接就做了两个程序。
4、 实验总结
通过本次试验,进一步认识和理解了橡皮筋算法的基本算法思想,同时也对双缓存技术有了一些了解,以前以为双缓存技术有多么神秘莫测,这次试验后才发现自己原来也可以搞一搞双缓存技术,虽然这只是一点点皮毛,但了解一点总比不知道好。
5、附录
带注释的源程序
#include
int iPointNum = 0; //已确定点的数目
int x1=0,x2=0,y1=0,y2=0; //确定的点坐标
int winWidth = 400, winHeight = 300; //窗口的宽度和高度
void Initial(void)
{
glClearColor(1.0f, 1.0f, 1.0f, 1.0f);
}
void ChangeSize(int w, int h)
{
winWidth = w; winHeight = h;
glViewport(0, 0, w, h); //指定窗口显示区域
glMatrixMode(GL_PROJECTION); //设置投影参数
glLoadIdentity();
gluOrtho2D(0.0,winWidth,0.0,winHeight);
}
void Display(void)
{
glClear(GL_COLOR_BUFFER_BIT);
glColor3f(1.0f, 0.0f, 0.0f);
if(iPointNum >= 1) {
glBegin(GL_LINES); //绘制直线段
glVertex2i(x1,y1);
glVertex2i(x2,y2);
glEnd();
}
glutSwapBuffers(); //交换缓冲区
}
void MousePlot(GLint button, GLint action, GLint xMouse, GLint yMouse)
{
if(button == GLUT_LEFT_BUTTON && action == GLUT_DOWN) {
if(iPointNum == 0 || iPointNum == 2)
{
iPointNum = 1;
x1 = xMouse; y1 = winHeight - yMouse;
}
else {
iPointNum = 2;
x2 = xMouse; y2 = winHeight - yMouse;
glutPostRedisplay(); //指定窗口重新绘制
}
}
if(button == GLUT_RIGHT_BUTTON && action == GLUT_DOWN){
iPointNum = 0;
glutPostRedisplay();
}
}
void PassiveMouseMove (GLint xMouse, GLint yMouse)
{
if(iPointNum == 1) {
x2 = xMouse;
y2 = winHeight - yMouse;
glutPostRedisplay();
}
}
void Key(unsigned char key, int x, int y)
{
switch(key){
case 'p':
if(iPointNum == 0 || iPointNum == 2) {
iPointNum = 1;
x1 = x; y1 = winHeight - y;
}
else {
iPointNum = 2;
x2 = x; y2 = winHeight - y;
glutPostRedisplay();
}
break;
default: break;
}
}
int main(int argc, char* argv[])
{
glutInit(&argc, argv);
glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB); //使用双缓存及RGB模型
glutInitWindowSize(400,300);
glutInitWindowPosition(100,100);
glutCreateWindow("何智龙的橡皮筋技术");
glutDisplayFunc(Display);
glutReshapeFunc(ChangeSize); //指定窗口在整形回调函数
glutMouseFunc(MousePlot); //指定鼠标响应函数
glutPassiveMotionFunc(PassiveMouseMove); //指定鼠标移动响应函数
Initial();
glutMainLoop();
void Key(unsigned char key, int x, int y);
return 0;
}
上交邮箱:hf_inf@sina.com