计算机图形学 实验8 《复杂图形绘制-Bezier曲面及其纹理》

一、实验目的

学习样条曲面绘制技术。

二、实验内容

1、绘制Bezier曲面;
2、将纹理图像映射到曲面。

三、实验方法

Bezier曲面的几种表现形式:
1、双一次Bezier曲面

2、双二次Bezier曲面

该曲面的四条边界是抛物线。

3、双三次Bezier曲面

该曲面的四条边界都是三次Bezier曲线:可通过控制内部的四个控制顶点P11,P12,P21,P22来控制曲面形状。

四、实验步骤

1、准备好Bezier曲面的控制点,存储在数组中;
2、绘制Bezier曲面;
3、刷新到显示区进行显示。

五、实验结果

实验输出图:

1、Bezier曲面:

2、Bezier曲面纹理贴图:

六、实验结论

1、Bezier曲面的绘制

代码:

#include <GL/glut.h>
#include <stdlib.h>GLfloat ctrlpoints[4][4][3] = {{{-1.5, -1.5, 4.0}, {-0.5, -1.5, 2.0}, {0.5, -1.5, -1.0}, {1.5, -1.5, 2.0}}, {{-1.5, -0.5, 1.0}, {-0.5, -0.5, 3.0}, {0.5, -0.5, 0.0}, {1.5, -0.5, -1.0}}, {{-1.5, 0.5, 4.0}, {-0.5, 0.5, 0.0}, {0.5, 0.5, 3.0}, {1.5, 0.5, 4.0}}, {{-1.5, 1.5, -2.0}, {-0.5, 1.5, -2.0}, {0.5, 1.5, 0.0}, {1.5, 1.5, -1.0}}
};void display(void)
{int i, j;glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);glColor3f(1.0, 1.0, 1.0);glPushMatrix ();glRotatef(85.0, 1.0, 1.0, 1.0);for (j = 0; j <= 8; j++) {glBegin(GL_LINE_STRIP);for (i = 0; i <= 30; i++)glEvalCoord2f((GLfloat)i/30.0, (GLfloat)j/8.0);glEnd();glBegin(GL_LINE_STRIP);for (i = 0; i <= 30; i++)glEvalCoord2f((GLfloat)j/8.0, (GLfloat)i/30.0);glEnd();}glPopMatrix ();glFlush();
}void init(void)
{glClearColor (0.0, 0.0, 0.0, 0.0);glMap2f(GL_MAP2_VERTEX_3, 0, 1, 3, 4,0, 1, 12, 4, &ctrlpoints[0][0][0]);glEnable(GL_MAP2_VERTEX_3);//glMapGrid2f(20, 0.0, 1.0, 20, 0.0, 1.0);glEnable(GL_DEPTH_TEST);glShadeModel(GL_FLAT);
}void reshape(int w, int h)
{glViewport(0, 0, (GLsizei) w, (GLsizei) h);glMatrixMode(GL_PROJECTION);glLoadIdentity();if (w <= h)glOrtho(-4.0, 4.0, -4.0*(GLfloat)h/(GLfloat)w, 4.0*(GLfloat)h/(GLfloat)w, -4.0, 4.0);elseglOrtho(-4.0*(GLfloat)w/(GLfloat)h, 4.0*(GLfloat)w/(GLfloat)h, -4.0, 4.0, -4.0, 4.0);glMatrixMode(GL_MODELVIEW);glLoadIdentity();
}void keyboard(unsigned char key, int x, int y)
{switch (key) {case 27:exit(0);break;}
}int main(int argc, char** argv)
{glutInit(&argc, argv);glutInitDisplayMode (GLUT_SINGLE | GLUT_RGB | GLUT_DEPTH);glutInitWindowSize (500, 500);glutInitWindowPosition (100, 100);glutCreateWindow (argv[0]);init ();glutDisplayFunc(display);glutReshapeFunc(reshape);glutKeyboardFunc(keyboard);glutMainLoop();return 0;
}

2、Bezier曲面纹理贴图:

代码:

#include <GL/glut.h>
#include <stdlib.h>
#include <math.h>#ifdef __APPLE__
#include <glut/glut.h>
#else
#define FREEGLUT_STATIC
#include <GL/glut.h>
#endifGLfloat ctrlpoints[4][4][3] = {{{ -1.5, -1.5, 4.0}, { -0.5, -1.5, 2.0},{0.5, -1.5, -1.0}, {1.5, -1.5, 2.0}},{{ -1.5, -0.5, 1.0}, { -0.5, -0.5, 3.0},{0.5, -0.5, 0.0}, {1.5, -0.5, -1.0}},{{ -1.5, 0.5, 4.0}, { -0.5, 0.5, 0.0},{0.5, 0.5, 3.0}, {1.5, 0.5, 4.0}},{{ -1.5, 1.5, -2.0}, { -0.5, 1.5, -2.0},{0.5, 1.5, 0.0}, {1.5, 1.5, -1.0}}
};GLfloat texpts[2][2][2] = { {{0.0, 0.0}, {0.0, 1.0}},{{1.0, 0.0}, {1.0, 1.0}} };void display(void)
{glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);glColor3f(1.0, 1.0, 1.0);glEvalMesh2(GL_FILL, 0, 20, 0, 20);//glMapGrid2f()均匀产生坐标值,这里执行绘制glFlush();
}#define imageWidth 64
#define imageHeight 64
GLubyte image[3 * imageWidth * imageHeight];
//纹理数据
void makeImage(void)
{int i, j;float ti, tj;for (i = 0; i < imageWidth; i++) {ti = 2.0 * 3.14159265 * i / imageWidth;for (j = 0; j < imageHeight; j++) {tj = 2.0 * 3.14159265 * j / imageHeight;image[3 * (imageHeight * i + j)] = (GLubyte)127 * (1.0 + sin(ti));image[3 * (imageHeight * i + j) + 1] = (GLubyte)127 * (1.0 + cos(2 * tj));image[3 * (imageHeight * i + j) + 2] = (GLubyte)127 * (1.0 + cos(ti + tj));}}
}void init(void)
{//定义了两个求值器程序glMap2f(GL_MAP2_VERTEX_3, 0, 1, 3, 4,0, 1, 12, 4, &ctrlpoints[0][0][0]);glMap2f(GL_MAP2_TEXTURE_COORD_2, 0, 1, 2, 2,0, 1, 4, 2, &texpts[0][0][0]);glEnable(GL_MAP2_TEXTURE_COORD_2);glEnable(GL_MAP2_VERTEX_3);glMapGrid2f(20, 0.0, 1.0, 20, 0.0, 1.0);//均匀产生坐标//纹理属性设置makeImage();glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_DECAL);glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT);glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT);glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, imageWidth, imageHeight, 0, GL_RGB, GL_UNSIGNED_BYTE, image);glEnable(GL_TEXTURE_2D);glEnable(GL_DEPTH_TEST);glShadeModel(GL_FLAT);
}void reshape(int w, int h)
{glViewport(0, 0, (GLsizei)w, (GLsizei)h);glMatrixMode(GL_PROJECTION);glLoadIdentity();if (w <= h)glOrtho(-4.0, 4.0, -4.0 * (GLfloat)h / (GLfloat)w,4.0 * (GLfloat)h / (GLfloat)w, -4.0, 4.0);elseglOrtho(-4.0 * (GLfloat)w / (GLfloat)h,4.0 * (GLfloat)w / (GLfloat)h, -4.0, 4.0, -4.0, 4.0);glMatrixMode(GL_MODELVIEW);glLoadIdentity();glRotatef(85.0, 1.0, 1.0, 1.0);
}void keyboard(unsigned char key, int x, int y)
{switch (key) {case 27:exit(0);break;}
}int main(int argc, char** argv)
{glutInit(&argc, argv);glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB | GLUT_DEPTH);glutInitWindowSize(500, 500);glutInitWindowPosition(100, 100);glutCreateWindow(argv[0]);init();glutDisplayFunc(display);glutReshapeFunc(reshape);glutKeyboardFunc(keyboard);glutMainLoop();return 0;
}

七、实验小结

贝塞尔曲面是对贝塞尔曲线多一个维度的扩展,其公式依然是贝塞尔曲线的公式,之所以由曲线变成曲面,是将顶点横向连了再纵向连,相当于是形成了一张网。通过本次实验,结合上一个实验(即绘制贝塞尔曲线)的探索,自己对样条曲线法绘制曲线有了更加深入的了解,不仅仅了解了如何绘制,更了解了为什么要这么绘制,对自己对图形学的认识很有帮助。

计算机图形学 实验8 《复杂图形绘制-Bezier曲面及其纹理》相关推荐

  1. 计算机图形学实验报告 裁剪,计算机图形学-实验报告三-图形裁剪算法

    <计算机图形学-实验报告三-图形裁剪算法>由会员分享,可在线阅读,更多相关<计算机图形学-实验报告三-图形裁剪算法(9页珍藏版)>请在人人文库网上搜索. 1.图形裁剪算法1. ...

  2. 计算机图形学 实验3 《图形变换》

    计算机图形学 实验3 <图形变换> 一.实验目的 学习图形的基本几何变换. 二.实验内容 1.投影变换: 2.视口变换: 3.旋转.平移和缩放. 三.实验方法 本次实验将投影变换.视口变换 ...

  3. 计算机图形学五角星c语言,计算机图形学实验——利用OpenGL函数绘制五角星

    一.实验名称:五角星的绘制 二.实验目的:了解 OpenGL 程序设计结构,掌握编程环 三.境的设置,掌握绘制线段的方法. 四.实验内容: 1.在 VC++ 环境下 ,练习利用 OpenGL 绘制三角 ...

  4. 安大计算机图形学实验——二维图形变换

    实验原理 1.本次实验着重学习以下常用函数,在实验报告中的实验原理部分对下列函数进行参数介绍和用法介绍. glLoadIdentity(): 变换矩阵: glRotatef(theta, vx, vy ...

  5. 计算机图形学 实验7 《复杂图形绘制-Bezier曲线与Hermite曲线》

    计算机图形学 实验7 <复杂图形绘制-Bezier曲线与Hermite曲线> 一.实验目的 学习样条曲线的绘制. 二.实验内容 1.绘制Bezier曲线: 2.绘制Hermite曲线. 三 ...

  6. 计算机图形学实验一(二维图形绘制)

    计算机图形学实验一(二维图形绘制) 一.实验内容 二.实验环境 三.问题分析 四.算法设计 五.源代码 六.程序运行结果 一.实验内容 (1)绘制金刚石图案 金刚石图案的成图规则是:把一个圆周等分成n ...

  7. TIT 计算机图形学 实验三 使用重心坐标算法绘制颜色渐变的正六面体

    TIT 计算机图形学 实验三 使用重心坐标算法绘制颜色渐变的正六面体 前言 参考视频计算机图形学全套算法讲解和C++编码实现(共23讲配套源码),计算机图形学案例视频讲解以及主页相关算法.孔老师是我的 ...

  8. 计算机图形学二维图形基本变换实验原理,计算机图形学实验:二维图形变换.docx...

    计算机图形学实验:二维图形变换.docx (9页) 本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦! 19.90 积分 实验三 二维图形变换一.实验任务1. 通 ...

  9. 计算机图形学 | 实验四:绘制一个球体

    计算机图形学 | 实验四:绘制一个球体 计算机图形学 | 实验四:绘制一个球体 封装Shader 为什么要封装Shader 如何使用 绘制球模型 球面顶点遍历 构造三角形图元 开启线框模式 开启面剔除 ...

最新文章

  1. 一个ASP.NET中使用的MessageBox类
  2. delphi xe 文件服务器,DelphiXE7中创建WebService(服务端+客户端)
  3. 程序员在囧途之做私活小记
  4. hive导数据到mysql 自增主键出错_老大问我:“建表为啥还设置个自增 id ?用流水号当主键不正好么?”...
  5. 一个基于特征向量的近似网页去重算法——term用SVM人工提取训练,基于term的特征向量,倒排索引查询相似文档,同时利用cos计算相似度...
  6. c# 扩展方法奇思妙用高级篇六:WinForm 控件选择器
  7. C++ 命名空间 实战(一)
  8. WP8.1开发中关于如何显示.gif格式动态格式图片方法
  9. c++ 如何获取系统时间
  10. 斐波那契数列(二)--矩阵优化算法
  11. Rancher Kubernetes Engine(RKE)正式发布:闪电般的Kubernetes安装部署体验
  12. zookeeper配置与使用
  13. ASP.NET运行模式
  14. python导入dat数据_Kaggle影评数据集,Python数据分析小例子14
  15. linux安装中文输入法
  16. CSFB和SRVCC
  17. jQuery 已经落幕了~
  18. iCloud照片在哪看?如何查看iCloud里的照片
  19. 一文看懂 webpack 的所有 source map !
  20. 业务、数据和组织:阿里巴巴的中台不只是技术战略

热门文章

  1. 试用74LS194加必要的门电路实现4位环形计数器(要求能自启动, 电路越简单越好). 要求它的有效循环状态Q0Q1Q2Q3为 1000-0100-0010-0001-1000
  2. Mq测试仪c语言版,mq? - 作业部落 Cmd Markdown 编辑阅读器
  3. 星系模拟器开发日志(一) 如何科学地用C++画图
  4. 从小白到架构师的飞升——HTML 多视窗框架
  5. python 基础笔记
  6. 01-ECU和域控制器(摘)
  7. 云杰恒指:6.11恒指期货早盘思路
  8. 机器学习 | LR逻辑回归模型
  9. TYD--mac 生成 ssh keys
  10. 浅谈 SurfaceView、TextureView、GLSurfaceView、SurfaceTexture