刚刚接触曲面细分
代码片段和文件信息
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 79079 2008-12-22 13:16 ZfxOpenGlLoopSubdivisionDebugLoop.obj
文件 30657 2008-12-22 13:16 ZfxOpenGlLoopSubdivisionDebugLoop.sbr
文件 18320 2008-12-23 01:19 ZfxOpenGlLoopSubdivisionDebugMainFrm.obj
文件 25600 2008-12-23 00:42 ZfxOpenGlLoopSubdivisionDebugMainFrm.pdb
文件 3238 2008-12-23 01:19 ZfxOpenGlLoopSubdivisionDebugMainFrm.sbr
文件 107473 2008-12-21 16:33 ZfxOpenGlLoopSubdivisionDebugStdAfx.obj
文件 1400461 2008-12-21 16:33 ZfxOpenGlLoopSubdivisionDebugStdAfx.sbr
文件 361472 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugvc60.idb
文件 380928 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugvc60.pdb
文件 3793920 2008-12-22 00:28 ZfxOpenGlLoopSubdivisionDebugfxOpenGlframe.bsc
文件 2211986 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugfxOpenGlframe.exe
文件 2613600 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugfxOpenGlframe.ilk
文件 22896 2008-12-21 18:56 ZfxOpenGlLoopSubdivisionDebugfxOpenGlframe.obj
文件 4260864 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugfxOpenGlframe.pdb
文件 14644 2008-12-21 16:29 ZfxOpenGlLoopSubdivisionDebugfxOpenGlframe.res
文件 0 2008-12-21 18:56 ZfxOpenGlLoopSubdivisionDebugfxOpenGlframe.sbr
文件 14412 2008-12-21 16:33 ZfxOpenGlLoopSubdivisionDebugfxOpenGlframeDoc.obj
文件 0 2008-12-21 16:33 ZfxOpenGlLoopSubdivisionDebugfxOpenGlframeDoc.sbr
文件 56779 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugfxOpenGlframeView.obj
文件 28748 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugfxOpenGlframeView.sbr
文件 8011 2008-12-22 13:16 ZfxOpenGlLoopSubdivisionLoop.cpp
文件 2997 2008-12-21 18:56 ZfxOpenGlLoopSubdivisionLoop.h
文件 2678 2008-12-23 01:19 ZfxOpenGlLoopSubdivisionMainFrm.cpp
文件 3413 2008-12-23 00:42 ZfxOpenGlLoopSubdivisionMainFrm.dsp
文件 539 2008-12-23 00:43 ZfxOpenGlLoopSubdivisionMainFrm.dsw
文件 1581 2008-09-10 10:18 ZfxOpenGlLoopSubdivisionMainFrm.h
文件 33792 2008-12-23 00:43 ZfxOpenGlLoopSubdivisionMainFrm.ncb
文件 48640 2008-12-23 00:43 ZfxOpenGlLoopSubdivisionMainFrm.opt
文件 1082 2008-12-23 00:42 ZfxOpenGlLoopSubdivisionMainFrm.plg
文件 4503 2008-09-10 10:18 ZfxOpenGlLoopSubdivisionReadMe.txt
............此处省略37个文件信息
// Loop.cpp: implementation of the Loop class.
//
//////////////////////////////////////////////////////////////////////
#include “stdafx.h“
#include “ZfxOpenGlframe.h“
#include “Loop.h“
#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif
#define PI 3.1415926
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
// 查找本三角形是否有偶点e1 e2
// 若有 则返回则两个偶点对应的奇点的下标
// 若无 则返回-2
int Triangle::FindTwoEven(int e1 int e2)
{
int differ = GetEvenSum()-e1-e2;
if(differ == even[0])
{
TwoTwoCmp(12)
}
else if(differ == even[1])
{
TwoTwoCmp(02)
}
else if(differ == even[2])
{
TwoTwoCmp(01)
}
else
{
return -2;
}
}
// 查找三角形中除偶点e1 e2外的另一个偶点(不做这两个偶点是否在这三角形中的检查)
int Triangle::FindOtherEven(int e1 int e2)
{
return GetEvenSum()-e1-e2;
}
// 将细分成的4个三角形插入pArrTriangle中
void Triangle::Subdivision(CArray *pArrTriangle)
{
// 为了保证光照效果 三个点的顺序必须是同一个方向
pArrTriangle->Add(Triangle(even[0] odd[1] odd[2]));
pArrTriangle->Add(Triangle(odd[1] even[1] odd[0]));
pArrTriangle->Add(Triangle(odd[2] odd[0] even[2]));
pArrTriangle->Add(Triangle(odd[1] odd[0] odd[2]));
}
// 返回其偶点的和
int Triangle::GetEvenSum()
{
return even[0]+even[1]+even[2];
}
/////////////////////////////////////////////////////////////////////
Loop::Loop()
{
m_pArrTriangle = new CArray();
m_pArrTriangle->RemoveAll();
m_pNewArrTriangle = new CArray();
m_pNewArrTriangle->RemoveAll();
m_pArrPoint = new CArray();
m_pArrPoint->RemoveAll();
m_pNewArrPoint = new CArray();
m_pNewArrPoint->RemoveAll();
}
Loop::~Loop()
{
}
// 将多面体进行一次细分
void Loop::Subdivision()
{
m_pNewArrTriangle->RemoveAll();
m_pNewArrPoint->RemoveAll();
m_pNewArrPoint->Append(*m_pArrPoint);
// 1.计算所有奇点
for(int i=0; iGetSize(); i++)
{
// 计算下标为i的三角形中的三个奇点
EvenToOdd(0 1 i);
EvenToOdd(1 2 i);
EvenToOdd(2 0 i);
// 保存每个三角形细分成的四个小三角形
Triangle triangle = m_pArrTriangle->GetAt(i);
triangle.Subdivision(m_pNewArrTriangle);
}
// 2.计算所有偶点
for(int j=0; jGetSize(); j++)
{
// 将下标为pointIndex对应偶点转化为偶点
EvenToEven(j);
}
// 保存新生成的面
m_pArrTriangle->RemoveAll();
m_pArrTriangle->Append(*m_pNewArrTriangle);
//保存新生成的点
m_pArrPoint->RemoveAll();
m_pArrPoint->Append(*m_pNewArrPoint);
}
// 计算下标为triangleIndex的三角形中的两个偶点对应的奇点
void Loop::EvenToOdd(int evenIndex1 int evenIndex2 int triangleIndex)
{
// 先赋两个无效值
int triangleIndex1 = -1;
int triangleIndex2 = -1;
Triangle triangle = m_pArrTriangle->GetAt(triangleIndex);
// 获取以这两个有点所组成的边为公共边的两个三角形的下标
int oddIndex = FindTwoTriangle(triangle.even[evenIndex1]
triangle.even[evenIndex2]
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 79079 2008-12-22 13:16 ZfxOpenGlLoopSubdivisionDebugLoop.obj
文件 30657 2008-12-22 13:16 ZfxOpenGlLoopSubdivisionDebugLoop.sbr
文件 18320 2008-12-23 01:19 ZfxOpenGlLoopSubdivisionDebugMainFrm.obj
文件 25600 2008-12-23 00:42 ZfxOpenGlLoopSubdivisionDebugMainFrm.pdb
文件 3238 2008-12-23 01:19 ZfxOpenGlLoopSubdivisionDebugMainFrm.sbr
文件 107473 2008-12-21 16:33 ZfxOpenGlLoopSubdivisionDebugStdAfx.obj
文件 1400461 2008-12-21 16:33 ZfxOpenGlLoopSubdivisionDebugStdAfx.sbr
文件 361472 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugvc60.idb
文件 380928 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugvc60.pdb
文件 3793920 2008-12-22 00:28 ZfxOpenGlLoopSubdivisionDebugfxOpenGlfr
文件 2211986 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugfxOpenGlfr
文件 2613600 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugfxOpenGlfr
文件 22896 2008-12-21 18:56 ZfxOpenGlLoopSubdivisionDebugfxOpenGlfr
文件 4260864 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugfxOpenGlfr
文件 14644 2008-12-21 16:29 ZfxOpenGlLoopSubdivisionDebugfxOpenGlfr
文件 0 2008-12-21 18:56 ZfxOpenGlLoopSubdivisionDebugfxOpenGlfr
文件 14412 2008-12-21 16:33 ZfxOpenGlLoopSubdivisionDebugfxOpenGlfr
文件 0 2008-12-21 16:33 ZfxOpenGlLoopSubdivisionDebugfxOpenGlfr
文件 56779 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugfxOpenGlfr
文件 28748 2008-12-23 01:39 ZfxOpenGlLoopSubdivisionDebugfxOpenGlfr
文件 8011 2008-12-22 13:16 ZfxOpenGlLoopSubdivisionLoop.cpp
文件 2997 2008-12-21 18:56 ZfxOpenGlLoopSubdivisionLoop.h
文件 2678 2008-12-23 01:19 ZfxOpenGlLoopSubdivisionMainFrm.cpp
文件 3413 2008-12-23 00:42 ZfxOpenGlLoopSubdivisionMainFrm.dsp
文件 539 2008-12-23 00:43 ZfxOpenGlLoopSubdivisionMainFrm.dsw
文件 1581 2008-09-10 10:18 ZfxOpenGlLoopSubdivisionMainFrm.h
文件 33792 2008-12-23 00:43 ZfxOpenGlLoopSubdivisionMainFrm.ncb
文件 48640 2008-12-23 00:43 ZfxOpenGlLoopSubdivisionMainFrm.opt
文件 1082 2008-12-23 00:42 ZfxOpenGlLoopSubdivisionMainFrm.plg
文件 4503 2008-09-10 10:18 ZfxOpenGlLoopSubdivisionReadMe.txt
............此处省略37个文件信息
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件举报,一经查实,本站将立刻删除。
评论列表(条)