- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验五-投影
课程实验指导五
实验5 投影
1.实验目的:
了解透视图投影原理,利用VC+OpenGL实现立方体的一点、两点、三点透视图算法.
2.实验内容:
理解投影原理;
读懂示范代码;
增加键盘控制,控制一点透视点产生正方体的移动、旋转效果;
实现两点透图效果.
3.实验原理:
本次实验内容为绘制立方体的一点透视图.
透视投影按照主灭点的个数分为一点透视、二点透视和三点透视,如下图1所示.
其中一点透视情况如图2所示,设z轴上有一观察点(即视点)V(0,0,d),从V点出发将物体上的点P( x, y, z)投影到XOY平面上得到P (x,y,0),由相似三角形可知一点透视变换矩阵为:
图2 一点透视示意
…………………………….(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.h
struct Matrix
{
double p[4][4];
Matrix operator*(Matrix );
Matrix();//单位矩阵
};
Matrix::Matrix()
{
for(long i=0;i4;i++){
for(long j=0;j4;j++){
if(i==j) p[i][j] = 1;
else p[i][j] = 0;
}
}
}
Matrix Multiply(Matrix m1, Matrix m2)
{
Matrix m;
for(int i=0;i4;i++)
for(int j=0;j4;j++)
for(int k=0;k4;k++)
m.p[i][j]+=(m1.p[i][k]*m2.p[k][j]);
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; 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 boxPt[8];
Pt2D boxPt2d[8];
FaceInfo fInfo[6];
void InitParameter()//初始化参数
{
mT.p[3][0] = lx; mT.p[3][1] = ly;mT.p[3][2] = lz;
mR.p[0][0] = cos(phi); mR.p[0][2] = -sin(phi);mR.p[2][0] = sin(phi); mR.p[2][2] = cos(phi);
mP.p[2][2] = 0;
mP.p[2][3] = -1/d;
mTemp = Multiply(mT, mR);
mA = Multiply(mTemp, mP);
}
void Project(Pt3D pt, Pt2D pt2D)//透视变换
{
double ptH[4];
ptH[0]=pt.x;//
ptH[1]=pt.y;
ptH[2]=pt.z;
ptH[3]=1;
double res[4];
for(int i=0;i4;i++)
res[i] = 0;
您可能关注的文档
- 外研版新标准初一下册随堂测Module.doc
- 声波测井研究.doc
- 外研英语七上教案ModuleAtriptothezoo全模块-.doc
- 外经贸历考试题.doc
- 外文翻译汽车差速器.doc
- 夏晓东毕业论文二次版.doc
- 外研版八下学期单元卷Module++Feelings+and+impressions.doc
- 多功能电子钟的设计与实现—硬件部分.doc
- 多功能电子钟的设计与实现--软件设计.doc
- 多泵之DG锅炉泵.doc
- 浙江省温州市浙南名校联盟2025-2026学年高一上学期期中联考数学试题含解析.docx
- 26高考数学提分秘诀重难点34圆锥曲线中的定点、定值、定直线问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点35概率与统计的综合问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点31圆锥曲线中的切线与切点弦问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点30圆锥曲线中的弦长问题与长度和、差、商、积问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点29巧解圆锥曲线的离心率问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点28直线与圆的综合(举一反三专项训练)(全国通用)(含解析).docx
- 寡核苷酸药物重复给药毒性研究技术指南.docx
- 重组溶瘤腺病毒生产质量管理标准.docx
- 26高考数学提分秘诀重难点27直线与圆中常考的最值与范围问题(举一反三专项训练)(全国通用)(含解析).docx
最近下载
- 充电桩采购安装项目供货方案.pdf VIP
- VA ONE用户手册目录.pdf VIP
- 皮类药材栽培技术杜仲栽培技术_培训课件.ppt VIP
- 2023年军队文职考试《数学2+物理》真题及答案.docx VIP
- (高清版)DB50∕T 646-2015 大黄绿色种植技术规程 .pdf VIP
- 充电桩采购安装应急预案.pdf
- 成人脓毒症患者医学营养治疗指南(2025版).pptx VIP
- 《输气管道工程设计规范》(GB 50251-2015).docx VIP
- 2024-2025学年上海七宝中学高一上学期数学月考试卷及答案(2024.12).docx VIP
- 中国旺旺控股有限公司环境、社会及管治报告 2022、2023.pdf VIP
原创力文档


文档评论(0)