loop 细分,结合openGL


刚刚接触曲面细分
资源截图
代码片段和文件信息
// 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  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个文件信息

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件举报,一经查实,本站将立刻删除。

发表评论

评论列表(条)