- 1、本文档共3页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
正八面体正交投影
1.旋转变换:
void CTransform::RotateX(double beta)
{
//绕X轴旋转
Identity();
double angle = beta*PI/180;
T[1][1] = cos(angle);
T[1][2] = sin(angle);
T[2][1] = -sin(angle);
T[2][2] = cos(angle);
MultiplyMatrix();
}
void CTransform::RotateY(double beta)
{
//绕Y轴旋转
Identity();
double angle = beta*PI/180;
T[0][0] = cos(angle);
T[0][2] = -sin(angle);
T[2][0] = sin(angle);
T[2][2] = cos(angle);
MultiplyMatrix();
}
void CTransform::RotateZ(double beta)
{
//绕Z轴旋转
Identity();
double angle = beta*PI/180;
T[0][0] = cos(angle);
T[0][1] = sin(angle);
T[1][0] = -sin(angle);
T[1][1] = cos(angle);
MultiplyMatrix();
}
2.读取点表、面表:
void CTestView::ReadPoint()
{
//正八面体顶点表
double a=200;
P[0].x=0; P[0].y=a; P[0].z=0;
P[1].x=0; P[1].y=0; P[1].z=a;
P[2].x=a; P[2].y=0; P[2].z=0;
P[3].x=0; P[3].y=0; P[3].z=-a;
P[4].x=-a;P[4].y=0; P[4].z=0;
P[5].x=0; P[5].y=-a;P[5].z=0;
}
void CTestView::ReadFace()
{//面的边数、面的顶点编号
F[0].En=3;F[0].v[0]=0;F[0].v[1]=1;F[0].v[2]=2;
F[2].En=3;F[1].v[0]=0;F[1].v[1]=2;F[1].v[2]=3;
F[3].En=3;F[2].v[0]=0;F[2].v[1]=3;F[2].v[2]=4;
F[4].En=3;F[3].v[0]=0;F[3].v[1]=4;F[3].v[2]=1;
F[5].En=3;F[5].v[0]=5;F[5].v[1]=3;F[5].v[2]=2;
F[6].En=3;F[6].v[0]=5;F[6].v[1]=4;F[6].v[2]=3;
F[7].En=3;F[7].v[0]=5;F[7].v[1]=1;F[7].v[2]=4;
}
3.绘制正八面体
void CTestView::DrawObject(CDC *pDC)
{
//绘制正八面体
CPen NewPen,*OldPen;
NewPen.CreatePen(PS_SOLID,2,RGB(255,255,255));
OldPen = pDC-SelectObject(NewPen);
C2DP P1,P2;
for(int nFace=0; nFace8; nFace++)//绘制各个面
{
for(int n=0; nF[nFace].m_nVertex; n++)
{
P1 = P[F[nFace].v[n]];
if(n==0)
{
pDC-MoveTo(P1.x,P1.y);
P2=P1;
}
else
pDC-LineTo(P1.x,P1.y);
}
pDC-LineTo(P2.x,P2.y);
}
}
在OnTimer中:
void CTestView::OnTimer(UINT nIDEvent)
{
alpha=5;
beta=5;
transform.RotateX(alpha);
transform.RotateY(beta);
Invalidate(FALSE);
CView::OnTimer(nIDEvent);
}
5.双缓冲,并将坐标原点固定于屏幕中心
void CTestView::DoubleBuffer()
{
//双缓冲绘图
CDC* pDC=GetDC();
CRect rect;//定义客户区
GetClientRect(rect);//获得客户区的大小
p
您可能关注的文档
- 初二上Unit 1-3练习.doc
- 功夫熊猫13句经典台词.doc
- 北京2011年成人英语模拟题1~9.docx
- 北京获得2022年冬奥会主办权(双语).docx
- 医学词根词缀大全.docx
- 初三年级 英语课件.ppt
- 双语:为什么要娶一个情感丰富的女人.docx
- 各种题目的德语作文.doc
- 合同履行中的问题及部分规定.doc
- 历年语法填空真题.doc
- 四川省德阳市罗江中学2025届高三考前热身化学试卷含解析.doc
- 山东省枣庄现代实验学校2025届高三下学期第五次调研考试化学试题含解析.doc
- 吉林省长春市十一高中等九校教育联盟2025届高三一诊考试生物试卷含解析.doc
- 2025届江苏省盐城市伍佑中学高考仿真模拟化学试卷含解析.doc
- 2025届广西贺州中学高考冲刺押题(最后一卷)生物试卷含解析.doc
- 安徽省池州市贵池区2025届高三第一次模拟考试生物试卷含解析.doc
- 宁夏银川一中2025届高三(最后冲刺)化学试卷含解析.doc
- 广东省广州市增城区四校联考2025届高考压轴卷化学试卷含解析.doc
- 2025届邯郸市第一中学高考生物必刷试卷含解析.doc
- 2025届安徽省安庆市石化第一中学高考仿真卷化学试卷含解析.doc
文档评论(0)