正八面体正交投影.doc

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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

文档评论(0)

xcs88858 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档