本文整理汇总了C++中CArray::Create方法的典型用法代码示例。如果您正苦于以下问题:C++ CArray::Create方法的具体用法?C++ CArray::Create怎么用?C++ CArray::Create使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类CArray
的用法示例。
在下文中一共展示了CArray::Create方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: OOF_ReadIntList
static int OOF_ReadIntList (CFile& cf, CArray<int>& list)
{
uint i;
char szId [20] = "";
list.Destroy ();
if (!(i = OOF_ReadInt (cf, "nList")))
return 0;
if (!list.Create (i))
return -1;
for (i = 0; i < list.Length (); i++) {
if (bLogOOF)
sprintf (szId, "list [%d]", i);
list [i] = OOF_ReadInt (cf, szId);
}
return list.Length ();
}
示例2: OOF_ReadVertList
static bool OOF_ReadVertList (CFile& cf, CArray<CFloatVector>& list, int nVerts, CFloatVector *pvMin, CFloatVector *pvMax)
{
char szId [20] = "";
OOF_InitMinMax (pvMin, pvMax);
if (!list.Create (nVerts))
return false;
for (int i = 0; i < nVerts; i++) {
if (bLogOOF)
sprintf (szId, "vertList [%d]", i);
OOF_ReadVector (cf, list + i, szId);
#if OOF_TEST_CUBE
pv [i].x -= 10;
pv [i].y += 15;
//pv [i].z += 5;
pv [i].x /= 2;
pv [i].y /= 2;
pv [i].z /= 2;
#endif
OOF_GetMinMax (list + i, pvMin, pvMax);
}
return true;
}
示例3: Radius
fix CModel::Radius (CObject *objP)
{
CSubModel* psm;
CFace* pmf;
CVertex* pmv;
CArray<CFloatVector3> vertices;
CFloatVector3 vCenter, vOffset, v, vMin, vMax;
float fRad = 0, r;
short h, i, j, k;
tModelSphere *sP = gameData.models.spheres + m_nModel;
if (m_nType >= 0) {
if ((m_nSubModels == sP->nSubModels) && (m_nFaces == sP->nFaces) && (m_nFaceVerts == sP->nFaceVerts)) {
gameData.models.offsets [m_nModel] = sP->vOffsets [m_nType];
return sP->xRads [m_nType];
}
}
//first get the biggest distance between any two model vertices
if (vertices.Create (m_nFaceVerts)) {
CFloatVector3 *pv, *pvi, *pvj;
for (i = 0, h = m_nSubModels, psm = m_subModels.Buffer (), pv = vertices.Buffer (); i < h; i++, psm++) {
if (psm->m_nHitbox > 0) {
vOffset.Assign (gameData.models.hitboxes [m_nModel].hitboxes [psm->m_nHitbox].vOffset);
for (j = psm->m_nFaces, pmf = psm->m_faces; j; j--, pmf++) {
for (k = pmf->m_nVerts, pmv = m_faceVerts + pmf->m_nIndex; k; k--, pmv++, pv++)
*pv = pmv->m_vertex + vOffset;
}
}
}
h = (short) (pv - vertices.Buffer ()) - 1;
CQuickSort<CFloatVector3> qs;
qs.SortAscending (vertices.Buffer (), 0, h, &RenderModel::CModel::CmpVerts);
//G3SortModelVerts (vertices, 0, h);
h = FilterVertices (vertices, h);
for (i = 0, pvi = vertices.Buffer (); i < h - 1; i++, pvi++)
for (j = i + 1, pvj = vertices + j; j < h; j++, pvj++)
if (fRad < (r = CFloatVector3::Dist (*pvi, *pvj))) {
fRad = r;
vMin = *pvi;
vMax = *pvj;
}
fRad /= 2;
// then move the tentatively computed model center around so that all vertices are enclosed in the sphere
// around the center with the radius computed above
vCenter.Assign (gameData.models.offsets [m_nModel]);
for (i = h, pv = vertices.Buffer (); i; i--, pv++) {
v = *pv - vCenter;
r = v.Mag();
if (fRad < r)
vCenter += v * ((r - fRad) / r);
}
for (i = h, pv = vertices.Buffer (); i; i--, pv++)
if (fRad < (r = CFloatVector3::Dist (*pv, vCenter)))
fRad = r;
vertices.Destroy ();
gameData.models.offsets [m_nModel].Assign (vCenter);
if (m_nType >= 0) {
sP->nSubModels = m_nSubModels;
sP->nFaces = m_nFaces;
sP->nFaceVerts = m_nFaceVerts;
sP->vOffsets [m_nType] = gameData.models.offsets [m_nModel];
sP->xRads [m_nType] = F2X (fRad);
}
}
else {
// then move the tentatively computed model center around so that all vertices are enclosed in the sphere
// around the center with the radius computed above
vCenter.Assign (gameData.models.offsets [m_nModel]);
for (i = 0, h = m_nSubModels, psm = m_subModels.Buffer (); i < h; i++, psm++) {
if (psm->m_nHitbox > 0) {
vOffset.Assign (gameData.models.hitboxes [m_nModel].hitboxes [psm->m_nHitbox].vOffset);
for (j = psm->m_nFaces, pmf = psm->m_faces; j; j--, pmf++) {
for (k = pmf->m_nVerts, pmv = m_faceVerts + pmf->m_nIndex; k; k--, pmv++) {
v = pmv->m_vertex + vOffset;
if (fRad < (r = CFloatVector3::Dist (v, vCenter)))
fRad = r;
}
}
}
}
gameData.models.offsets [m_nModel].Assign (vCenter);
}
return F2X (fRad);
}