📄 mlr_i_c_dt_pmesh.cpp
字号:
//===========================================================================//
// Copyright (C) Microsoft Corporation. All rights reserved. //
//===========================================================================//
#include "MLRHeaders.hpp"
#if defined(TRACE_ENABLED) && defined(MLR_TRACE)
BitTrace *MLR_I_C_DT_PMesh_Clip;
#endif
//#############################################################################
//###### MLRIndexedPolyMesh with color but no lighting two texture layers ####$
//#############################################################################
MLR_I_C_DT_PMesh::ClassData*
MLR_I_C_DT_PMesh::DefaultData = NULL;
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
void
MLR_I_C_DT_PMesh::InitializeClass()
{
Verify(!DefaultData);
Verify(gos_GetCurrentHeap() == StaticHeap);
DefaultData =
new ClassData(
MLR_I_C_DT_PMeshClassID,
"MidLevelRenderer::MLR_I_C_DT_PMesh",
MLR_I_DT_PMesh::DefaultData,
(MLRPrimitiveBase::Factory)&Make
);
Register_Object(DefaultData);
#if defined(TRACE_ENABLED) && defined(MLR_TRACE)
MLR_I_C_DT_PMesh_Clip = new BitTrace("MLR_I_C_DT_PMesh_Clip");
Register_Object(MLR_I_C_DT_PMesh_Clip);
#endif
}
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
void
MLR_I_C_DT_PMesh::TerminateClass()
{
Unregister_Object(DefaultData);
delete DefaultData;
DefaultData = NULL;
#if defined(TRACE_ENABLED) && defined(MLR_TRACE)
Unregister_Object(MLR_I_C_DT_PMesh_Clip);
delete MLR_I_C_DT_PMesh_Clip;
#endif
}
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
MLR_I_C_DT_PMesh::MLR_I_C_DT_PMesh(
ClassData *class_data,
MemoryStream *stream,
int version
):
MLR_I_DT_PMesh(class_data, stream, version)
{
Check_Pointer(this);
Check_Pointer(stream);
Verify(gos_GetCurrentHeap() == Heap);
switch(version)
{
case 1:
case 2:
{
STOP(("This class got created only after version 2 !"));
}
break;
default:
{
#if COLOR_AS_DWORD
MemoryStreamIO_Read(stream, &colors);
#else
Stuff::DynamicArrayOf<DWORD> smallColors;
MemoryStreamIO_Read(stream, &smallColors);
int i, len = smallColors.GetLength();
colors.SetLength(len);
DWORD theColor;
for(i=0;i<len;i++)
{
theColor = smallColors[i];
colors[i].blue = (theColor & 0xff) * One_Over_256;
theColor = theColor>>8;
colors[i].green = (theColor & 0xff) * One_Over_256;
theColor = theColor>>8;
colors[i].red = (theColor & 0xff) * One_Over_256;
theColor = theColor>>8;
colors[i].alpha = (theColor & 0xff) * One_Over_256;
}
#endif
}
break;
}
}
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
MLR_I_C_DT_PMesh::MLR_I_C_DT_PMesh(ClassData *class_data):
MLR_I_DT_PMesh(class_data), colors(0)
{
Verify(gos_GetCurrentHeap() == Heap);
Check_Pointer(this);
}
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
MLR_I_C_DT_PMesh::~MLR_I_C_DT_PMesh()
{
Check_Object(this);
}
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
MLR_I_C_DT_PMesh*
MLR_I_C_DT_PMesh::Make(
MemoryStream *stream,
int version
)
{
Check_Object(stream);
gos_PushCurrentHeap(Heap);
MLR_I_C_DT_PMesh* mesh = new MLR_I_C_DT_PMesh(DefaultData, stream, version);
gos_PopCurrentHeap();
return mesh;
}
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
void
MLR_I_C_DT_PMesh::Save(MemoryStream *stream)
{
Check_Object(this);
Check_Object(stream);
MLR_I_DT_PMesh::Save(stream);
#if COLOR_AS_DWORD
MemoryStreamIO_Write(stream, &colors);
#else
Stuff::DynamicArrayOf<DWORD> smallColors;
int i, len = colors.GetLength();
const Stuff::RGBAColor *data = colors.GetData();
smallColors.SetLength(len);
for(i=0;i<len;i++)
{
smallColors[i] = GOSCopyColor(data+i);
}
MemoryStreamIO_Write(stream, &smallColors);
#endif
}
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
void
MLR_I_C_DT_PMesh::TestInstance() const
{
Verify(IsDerivedFrom(DefaultData));
}
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
void
MLR_I_C_DT_PMesh::SetColorData(
#if COLOR_AS_DWORD
const DWORD *data,
#else
const RGBAColor *data,
#endif
int dataSize
)
{
Check_Object(this);
Check_Pointer(data);
Verify(coords.GetLength() == 0 || dataSize == coords.GetLength());
// Verify(texCoords.GetLength() == 0 || dataSize == texCoords.GetLength());
colors.AssignData(data, dataSize);
}
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
void
MLR_I_C_DT_PMesh::GetColorData(
#if COLOR_AS_DWORD
DWORD **data,
#else
RGBAColor **data,
#endif
int *dataSize
)
{
Check_Object(this);
*data = colors.GetData();
*dataSize = colors.GetLength();
}
//
void
MLR_I_C_DT_PMesh::PaintMe(
#if COLOR_AS_DWORD
const DWORD *paintMe
#else
const RGBAColor *paintMe
#endif
)
{
Check_Object(this);
// original color is lost !!!;
int k, len = colors.GetLength();
#if COLOR_AS_DWORD
DWORD argb = GOSCopyColor(paintMe);
for(k=0;k<len;k++)
{
colors[k] = argb;
}
#else
for(k=0;k<len;k++)
{
colors[k] = *paintMe;
}
#endif
}
#define I_SAY_YES_TO_DUAL_TEXTURES
#define I_SAY_YES_TO_COLOR
#undef I_SAY_YES_TO_LIGHTING
#define CLASSNAME MLR_I_C_DT_PMesh
#if defined(TRACE_ENABLED) && defined(MLR_TRACE)
#define SET_MLR_PMESH_CLIP() MLR_I_C_DT_PMesh_Clip->Set()
#define CLEAR_MLR_PMESH_CLIP() MLR_I_C_DT_PMesh_Clip->Clear()
#else
#define SET_MLR_PMESH_CLIP()
#define CLEAR_MLR_PMESH_CLIP()
#endif
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
// This include contains follwing functions:
// void MLR_I_C_DT_PMesh::TransformNoClip(Matrix4D*, GOSVertexPool*);
// int MLR_I_C_DT_PMesh::Clip(MLRClippingState, GOSVertexPool*);
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
#include <MLR\MLRPrimitiveClipping.hpp>
#undef I_SAY_YES_TO_DUAL_TEXTURES
#undef I_SAY_YES_TO_COLOR
#undef CLASSNAME
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
MLR_I_C_DT_PMesh*
MidLevelRenderer::CreateIndexedCube_Color_NoLit_2Tex(
Scalar half,
RGBAColor *eightColors,
MLRState *state,
MLRState *state1
)
{
gos_PushCurrentHeap(Heap);
MLR_I_C_DT_PMesh *ret = new MLR_I_C_DT_PMesh;
Register_Object(ret);
Point3D *coords = new Point3D [8];
Register_Pointer(coords);
coords[0] = Point3D( half, -half, half);
coords[1] = Point3D(-half, -half, half);
coords[2] = Point3D( half, -half, -half);
coords[3] = Point3D(-half, -half, -half);
coords[4] = Point3D(-half, half, half);
coords[5] = Point3D( half, half, half);
coords[6] = Point3D( half, half, -half);
coords[7] = Point3D(-half, half, -half);
unsigned char *lengths = new unsigned char [6];
Register_Pointer(lengths);
int i;
for(i=0;i<6;i++)
{
lengths[i] = 4;
}
ret->SetSubprimitiveLengths(lengths, 6);
ret->SetCoordData(coords, 8);
unsigned short *index = new unsigned short [6*4];
Register_Pointer(index);
index[0] = 0;
index[1] = 2;
index[2] = 6;
index[3] = 5;
index[4] = 0;
index[5] = 5;
index[6] = 4;
index[7] = 1;
index[8] = 5;
index[9] = 6;
index[10] = 7;
index[11] = 4;
index[12] = 2;
index[13] = 3;
index[14] = 7;
index[15] = 6;
index[16] = 1;
index[17] = 4;
index[18] = 7;
index[19] = 3;
index[20] = 0;
index[21] = 1;
index[22] = 3;
index[23] = 2;
ret->SetIndexData(index, 6*4);
ret->FindFacePlanes();
if(eightColors!=NULL)
{
#if COLOR_AS_DWORD
DWORD *dwColor = new DWORD [8];
Register_Object(dwColor);
for(i=0;i<8;i++)
{
dwColor[i] = GOSCopyColor(eightColors+i);
}
ret->SetColorData(dwColor, 8);
Unregister_Pointer(dwColor);
delete [] dwColor;
#else
ret->SetColorData(eightColors, 8);
#endif
}
Vector2DScalar *texCoords = new Vector2DScalar[16];
Register_Pointer(texCoords);
for(i=0;i<16;i++)
{
texCoords[i] = Vector2DScalar(0.0f, 0.0f);
}
if(state != NULL)
{
ret->SetReferenceState(*state);
if(state->GetTextureHandle() > 0)
{
texCoords[0] = Vector2DScalar(0.0f, 0.0f);
texCoords[1] = Vector2DScalar(1.0f, 0.0f);
texCoords[2] = Vector2DScalar(0.25f, 0.25f);
texCoords[3] = Vector2DScalar(0.75f, 0.25f);
texCoords[4] = Vector2DScalar(1.0f, 1.0f);
texCoords[5] = Vector2DScalar(0.0f, 1.0f);
texCoords[6] = Vector2DScalar(0.25f, 0.75f);
texCoords[7] = Vector2DScalar(0.75f, 0.75f);
}
ret->SetReferenceState(*state1, 1);
if(state1->GetTextureHandle() > 0)
{
texCoords[8] = texCoords[0];
texCoords[9] = texCoords[1];
texCoords[10] = texCoords[2];
texCoords[11] = texCoords[3];
texCoords[12] = texCoords[4];
texCoords[13] = texCoords[5];
texCoords[14] = texCoords[6];
texCoords[15] = texCoords[7];
}
}
ret->SetTexCoordData(texCoords, 16);
Unregister_Pointer(texCoords);
delete [] texCoords;
Unregister_Pointer(lengths);
delete [] lengths;
Unregister_Pointer(index);
delete [] index;
Unregister_Pointer(coords);
delete [] coords;
gos_PopCurrentHeap();
return ret;
}
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
MLRShape*
MidLevelRenderer::CreateIndexedIcosahedron_Color_NoLit_2Tex(
IcoInfo& icoInfo,
MLRState *state,
MLRState *state2
)
{
gos_PushCurrentHeap(Heap);
MLRShape *ret = new MLRShape(20);
Register_Object(ret);
int i, j, k;
long nrTri = (long) ceil (icoInfo.all * pow (4.0f, icoInfo.depth));
Point3D v[3];
if(3*nrTri >= Limits::Max_Number_Vertices_Per_Mesh)
{
nrTri = Limits::Max_Number_Vertices_Per_Mesh/3;
}
unsigned char *lengths = new unsigned char [nrTri];
Register_Pointer(lengths);
for(i=0;i<nrTri;i++)
{
lengths[i] = 3;
}
Point3D *coords = new Point3D [nrTri*3];
Register_Pointer(coords);
Point3D *collapsedCoords = NULL;
if(icoInfo.indexed==true)
{
collapsedCoords = new Point3D [nrTri*3];
Register_Pointer(collapsedCoords);
}
unsigned short *index = new unsigned short [nrTri*3];
Register_Pointer(index);
Vector2DScalar *texCoords = new Vector2DScalar[2*nrTri*3];
Register_Pointer(texCoords);
RGBAColor *colors = new RGBAColor[nrTri*3];
Register_Pointer(colors);
int uniquePoints = 0;
for (k=0;k<20;k++)
{
MidLevelRenderer::triDrawn = 0;
MLR_I_C_DT_PMesh *mesh = new MLR_I_C_DT_PMesh();
Register_Object(mesh);
// setup vertex position information
for (j=0;j<3;j++)
{
v[j].x = vdata[tindices[k][j]][0];
v[j].y = vdata[tindices[k][j]][1];
v[j].z = vdata[tindices[k][j]][2];
}
subdivide (coords, v[0], v[1], v[2], icoInfo.depth, nrTri, icoInfo.radius);
mesh->SetSubprimitiveLengths(lengths, nrTri);
if(icoInfo.indexed==true)
{
uniquePoints = 1;
collapsedCoords[0] = coords[0];
index[0] = 0;
for(i=1;i<nrTri*3;i++)
{
for(j=0;j<uniquePoints;j++)
{
if(coords[i] == collapsedCoords[j])
{
break;
}
}
if(j==uniquePoints)
{
collapsedCoords[uniquePoints++] = coords[i];
}
index[i] = static_cast<unsigned short>(j);
}
mesh->SetCoordData(collapsedCoords, uniquePoints);
}
else
{
uniquePoints = nrTri*3;
for(i=0;i<nrTri*3;i++)
{
index[i] = static_cast<unsigned short>(i);
}
mesh->SetCoordData(coords, nrTri*3);
}
mesh->SetIndexData(index, nrTri*3);
mesh->FindFacePlanes();
if(state == NULL)
{
for(i=0;i<2*uniquePoints;i++)
{
texCoords[i] = Vector2DScalar(0.0f, 0.0f);
}
}
else
{
mesh->SetReferenceState(*state);
if(state->GetTextureHandle() > 0)
{
if(icoInfo.indexed==true)
{
for(i=0;i<uniquePoints;i++)
{
texCoords[i] =
Vector2DScalar(
(1.0f + collapsedCoords[i].x)/2.0f,
(1.0f + collapsedCoords[i].y)/2.0f
);
texCoords[i+uniquePoints] =
Vector2DScalar(
(1.0f + collapsedCoords[i].x)/2.0f,
(1.0f + collapsedCoords[i].z)/2.0f
);
}
}
else
{
for(i=0;i<nrTri;i++)
{
texCoords[3*i] =
Vector2DScalar(
(1.0f + coords[3*i].x)/2.0f,
(1.0f + coords[3*i].y)/2.0f
);
texCoords[3*i+1] =
Vector2DScalar(
(1.0f + coords[3*i+1].x)/2.0f,
(1.0f + coords[3*i+1].y)/2.0f
);
texCoords[3*i+2] =
Vector2DScalar(
(1.0f + coords[3*i+2].x)/2.0f,
(1.0f + coords[3*i+2].y)/2.0f
);
texCoords[3*i+nrTri] =
Vector2DScalar(
(1.0f + coords[3*i].x)/2.0f,
(1.0f + coords[3*i].z)/2.0f
);
texCoords[3*i+1+nrTri] =
Vector2DScalar(
(1.0f + coords[3*i+1].x)/2.0f,
(1.0f + coords[3*i+1].z)/2.0f
);
texCoords[3*i+2+nrTri] =
Vector2DScalar(
(1.0f + coords[3*i+2].x)/2.0f,
(1.0f + coords[3*i+2].z)/2.0f
);
}
}
}
else
{
for(i=0;i<2*uniquePoints;i++)
{
texCoords[i] = Vector2DScalar(0.0f, 0.0f);
}
}
}
mesh->SetTexCoordData(texCoords, 2*uniquePoints);
if(icoInfo.indexed==true)
{
for(i=0;i<uniquePoints;i++)
{
colors[i] =
RGBAColor(
(1.0f + collapsedCoords[i].x)/2.0f,
(1.0f + collapsedCoords[i].y)/2.0f,
(1.0f + collapsedCoords[i].z)/2.0f,
1.0f
);
}
}
else
{
for(i=0;i<uniquePoints;i++)
{
colors[i] =
RGBAColor(
(1.0f + coords[i].x)/2.0f,
(1.0f + coords[i].y)/2.0f,
(1.0f + coords[i].z)/2.0f,
1.0f
);
}
}
mesh->SetColorData(colors, uniquePoints);
mesh->SetReferenceState(*state2, 1);
ret->Add(mesh);
mesh->DetachReference();
}
Unregister_Pointer(colors);
delete [] colors;
Unregister_Pointer(texCoords);
delete [] texCoords;
Unregister_Pointer(index);
delete [] index;
if(icoInfo.indexed==true)
{
Unregister_Pointer(collapsedCoords);
delete [] collapsedCoords;
}
Unregister_Pointer(coords);
delete [] coords;
Unregister_Pointer(lengths);
delete [] lengths;
gos_PopCurrentHeap();
return ret;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -