




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、课程实验指导五实验5 投影1实验目的:了解透视图投影原理,利用VC+OpenGL实现立方体的一点、两点、三点透视图算法。2实验内容:(1) 理解投影原理;(2) 读懂示范代码;(3) 增加键盘控制,控制一点透视点产生正方体的移动、旋转效果;(4) 实现两点透图效果。3实验原理:本次实验内容为绘制立方体的一点透视图。透视投影按照主灭点的个数分为一点透视、二点透视和三点透视,如下图1所示。灭点灭点灭点灭点灭点灭点 图1 立方体的三类透视其中一点透视情况如图2所示,设z轴上有一观察点(即视点)V(0,0,d),从V点出发将物体上的点P( x, y, z)投影到XOY平面上得到P' (x
2、9;,y',0),由相似三角形可知一点透视变换矩阵为:图2 一点透视示意1 / 8.(1)根据以上,可得一点透视变换的步骤如下:(1)将三维形体平移到适当位置lx、ly、lz;(2)令视点在z轴(0,0,d),利用上述公式(1)进行透视变换;4实验代码:/ Projection.cpp : Defines the entry point for the console application./#include "stdafx.h"#include <GL/glut.h>#include <stdio.h>#include <math.
3、h>struct Matrix double p44; Matrix operator*(Matrix &); Matrix();/单位矩阵;Matrix:Matrix() for(long i=0;i<4;i+) for(long j=0;j<4;j+) if(i=j) pij = 1; else pij = 0; Matrix Multiply(Matrix& m1, Matrix& m2)Matrix m;for(int i=0;i<4;i+)for(int j=0;j<4;j+)for(int k=0;k<4;k+)m.pij
4、+=(m1.pik*m2.pkj);return m;struct Pt2D int x, y;Pt2D()x = 0; y = 0;Pt2D(int px, int py)x = px; y = py;struct Pt3D float x, y, z;Pt3D()x = 0; y = 0; z = 0;Pt3D(float px, float py, float pz)x = px; y = py; z = pz;struct FaceInfo /第一列为每个面的顶点数;其余列为面的顶点编号int num, idx1, idx2, idx3, idx4;FaceInfo()num = 0;
5、 idx1 = 0; idx2 = 0;idx3 = 0; idx4 = 0;FaceInfo(int fnum, int fidx1, int fidx2, int fidx3, int fidx4)num = fnum; idx1 = fidx1; idx2 = fidx2;idx3 = fidx3;idx4 = fidx4;double lx = 480, ly = 460, lz = 240;double phi = 0;double d = -500;Matrix mT, mR, mP, mTemp, mA;Pt3D boxPt8;Pt2D boxPt2d8;FaceInfo fIn
6、fo6;void InitParameter()/初始化参数mT.p30 = lx; mT.p31 = ly;mT.p32 = lz;mR.p00 = cos(phi); mR.p02 = -sin(phi);mR.p20 = sin(phi); mR.p22 = cos(phi);mP.p22 = 0;mP.p23 = -1/d;mTemp = Multiply(mT, mR);mA = Multiply(mTemp, mP);void Project(Pt3D pt, Pt2D &pt2D)/透视变换double ptH4;ptH0=pt.x;/ptH1=pt.y;ptH2=pt.
7、z;ptH3=1;double res4;for(int i=0;i<4;i+)resi = 0;for(i=0;i<4;i+)for(int j=0;j<4;j+)resi+=(ptHj*mA.pji);pt2D = Pt2D(res0/res3, res1/res3);void LineGL(Pt2D pt0, Pt2D pt1)glBegin (GL_LINES);glColor3f (1.0f, 0.0f, 0.0f); glVertex2f (pt0.x,pt0.y);glColor3f (0.0f, 1.0f, 0.0f); glVertex2f (pt1.x,p
8、t1.y);glEnd ();int GetPtIdx(FaceInfo fInfo, int ptIdx)int idx = 0; switch (ptIdx)case 1:idx = fInfo.idx1;break;case 2:idx = fInfo.idx2;break;case 3:idx = fInfo.idx3;break;case 4:idx = fInfo.idx4;break;default:break;return idx;void BoxProject()int ptIdx;Pt2D pt2D;for(int face=0;face<6;face+)int nu
9、m=fInfoface.num;/面的总边数for(int i=0;i<num;i+)/边循环ptIdx = GetPtIdx(fInfoface, i);/面的顶点号Project(boxPtptIdx, pt2D);boxPt2dptIdx = pt2D;void DrawBox()int ptIdx4;for(int face=0;face<4;face+)int num =fInfoface.num;/面的总顶点数for(int i=0;i<num;i+)/循环ptIdxi = GetPtIdx(fInfoface, i+1);/面的顶点号for(int j=0; j
10、<4; j+)int idx0 = ptIdxj;int idx1 = (j= 3) ? ptIdx0:ptIdxj+1);LineGL(boxPt2didx0, boxPt2didx1);void myDisplay()glClear(GL_COLOR_BUFFER_BIT);glColor3f (1.0f, 0.0f, 0.0f); InitParameter();BoxProject();DrawBox();glutSwapBuffers();void Init()glClearColor(0.0, 0.0, 0.0, 0.0);glShadeModel(GL_FLAT);prin
11、tf("Hello Cube!n");void Reshape(int w, int h)glViewport(0, 0, (GLsizei) w, (GLsizei) h);glMatrixMode(GL_PROJECTION);glLoadIdentity();gluOrtho2D(0.0, (GLdouble) w, 0.0, (GLdouble) h);void keyboard(unsigned char key, int x, int y)switch (key)case 'x':break;default:break;void ReadPoin
12、t()/读入8个顶点坐标float bl = 200;/box lengthboxPt0 = Pt3D(-bl/2, -bl/2, -bl/2);boxPt1 = Pt3D(-bl/2, bl/2, -bl/2);boxPt2 = Pt3D(-bl/2, bl/2, bl/2);boxPt3 = Pt3D(-bl/2, -bl/2, bl/2);boxPt4 = Pt3D(bl/2, -bl/2, -bl/2);boxPt5 = Pt3D(bl/2, bl/2, -bl/2);boxPt6 = Pt3D(bl/2, bl/2, bl/2);boxPt7 = Pt3D(bl/2, -bl/2,
13、bl/2);void ReadFace()/读入6个面坐标fInfo0 = FaceInfo(4, 0, 1, 2, 3);fInfo1 = FaceInfo(4, 0, 3, 7, 4);fInfo2 = FaceInfo(4, 4, 5, 6, 7);fInfo3 = FaceInfo(4, 5, 1, 2, 6);fInfo4 = FaceInfo(4, 7, 6, 2, 3);fInfo5 = FaceInfo(4, 4, 5, 1, 0);int main(int argc, char *argv)glutInit(&argc, argv);glutInitDisplayMode(GLUT_RGB | GLUT_DOUBLE);glutInitWindowPosition(100, 100);glutInitWindow
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 稿定设计制作与编辑指南
- 特色农业林业品种繁育合作合同
- 政治与社会2025年公共关系学试题及答案
- 高效学习水利水电工程考试试题及答案
- 工程经济投资风险缓解试题及答案
- 财务部门在战略规划中的角色计划
- 合同范本体育赛事居间合同
- 食堂用餐服务投诉处理协议
- 2025年定制化工程项目管理试题及答案
- 老年劳动力返聘协议
- 2025年乡村振兴战略相关考试试题及答案
- 2024-2025学年全国版图知识竞赛(小学组)考试题库(含答案)
- 2024年广东大亚湾开发区招聘公办学校教师笔试真题
- 江苏交控笔试试题及答案
- 《低压电工实操及考证》全套教学课件
- JJF1033-2023计量标准考核规范
- 颈椎病课件完整版
- 2022-2023学年上海市闵行区八年级(下)期末数学试卷
- 三对三篮球赛记录表
- 被执行人财产线索提供书(模板)
- ASTME213-2014金属管超声检验标准作法
评论
0/150
提交评论