Re #691: refactored splitOb() (Boris)

o refactored all <bla>{1,2,3} things into constant arrays
o pushed those into for-loops to make code more compact
o added function copyPoint()

git-svn-id: https://svn.code.sf.net/p/speed-dreams/code/trunk@4863 30fe4595-0a0c-4342-8851-515496e4dcbd

Former-commit-id: ed68dd24fa48c7da86875a9d9f8e5c109d7da2a7
Former-commit-id: 0b600de6f9148cd51207fcb68585e370e4406619
This commit is contained in:
kmetykog 2012-08-17 22:08:22 +00:00
parent d9233f16de
commit 2cee97cb81
2 changed files with 54 additions and 90 deletions

View file

@ -51,6 +51,13 @@
#define SetPoint(p, a, b, c) (p).x = a; (p).y = b; (p).z = c; #define SetPoint(p, a, b, c) (p).x = a; (p).y = b; (p).z = c;
void copyPoint(point_t * dest, point_t * src)
{
dest->x = src->x;
dest->y = src->y;
dest->z = src->z;
}
#ifndef M_PI #ifndef M_PI
#define M_PI 3.14159267 #define M_PI 3.14159267
#endif #endif
@ -537,10 +544,13 @@ int splitOb(ob_t **object)
int curtri = 0; int curtri = 0;
int j = 0; int j = 0;
int n = 0; int n = 0;
double u1, u2, u3;
double v1, v2, v3; double curu[3];
int indice1, indice2, indice3; double curv[3];
int m1, m2, m3; int curidx[3];
int curstoredidx[3];
int i = 0;
int touse = 0; int touse = 0;
int orignumtris = 0; /* number of surfaces/triangles in the source object */ int orignumtris = 0; /* number of surfaces/triangles in the source object */
int orignumverts = 0; /* number of vertices in the source object: orignumtris * 3 */ int orignumverts = 0; /* number of vertices in the source object: orignumtris * 3 */
@ -588,20 +598,16 @@ int splitOb(ob_t **object)
curvert = curtri * 3; curvert = curtri * 3;
/** find vertices of the triangle */ /** find vertices of the triangle */
indice1 = (*object)->vertexarray[curvert].indice; for(i = 0; i < 3; i++)
u1 = (*object)->vertexarray[curvert].u; {
v1 = (*object)->vertexarray[curvert].v; curidx[i] = (*object)->vertexarray[curvert+i].indice;
indice2 = (*object)->vertexarray[curvert + 1].indice; curu[i] = (*object)->vertexarray[curvert+i].u;
u2 = (*object)->vertexarray[curvert + 1].u; curv[i] = (*object)->vertexarray[curvert+i].v;
v2 = (*object)->vertexarray[curvert + 1].v;
indice3 = (*object)->vertexarray[curvert + 2].indice;
u3 = (*object)->vertexarray[curvert + 2].u;
v3 = (*object)->vertexarray[curvert + 2].v;
m1 = findIndice(indice1, oldva, n); curstoredidx[i] = findIndice(curidx[i], oldva, n);
m2 = findIndice(indice2, oldva, n); }
m3 = findIndice(indice3, oldva, n);
if (m1 == -1 && m2 == -1 && m3 == -1) if (curstoredidx[0] == -1 && curstoredidx[1] == -1 && curstoredidx[2] == -1)
{ {
if (firstTri == 0) if (firstTri == 0)
touse = 1; touse = 1;
@ -612,24 +618,17 @@ int splitOb(ob_t **object)
else else
{ {
touse = 1; touse = 1;
if (m1 != -1)
if (text[m1 * 2] != u1 || text[m1 * 2 + 1] != v1) for(i = 0; i < 3; i++)
{ {
touse = 0; if (curstoredidx[i] != -1)
/* triangle is not ok */ if(text[curstoredidx[i] * 2] != curu[i]
} || text[curstoredidx[i] * 2 + 1] != curv[i])
if (m2 != -1) {
if (text[m2 * 2] != u2 || text[m2 * 2 + 1] != v2) touse = 0;
{ /* triangle is not ok */
touse = 0; }
/* triangle is not ok */ }
}
if (m3 != -1)
if (text[m3 * 2] != u3 || text[m3 * 2 + 1] != v3)
{
touse = 0;
/* triangle is not ok */
}
} }
if (touse == 1) if (touse == 1)
@ -641,64 +640,27 @@ int splitOb(ob_t **object)
/* store the vertices of the triangle with new indice */ /* store the vertices of the triangle with new indice */
/* not yet in the array : store it at the current position */ /* not yet in the array : store it at the current position */
if (m1 == -1) for(i = 0; i < 3; i++)
{ {
oldva[n] = indice1; /* remember the value of the vertice already saved */ if (curstoredidx[i] == -1)
text[n * 2] = u1; {
text[n * 2 + 1] = v1; oldva[n] = curidx[i]; /* remember the value of the vertice already saved */
m1 = n; text[n * 2] = curu[i];
n++; text[n * 2 + 1] = curv[i];
(*object)->vertexarray[curvert].saved = 0; curstoredidx[i] = n;
pttmp[m1].x = (*object)->vertex[indice1].x; n++;
pttmp[m1].y = (*object)->vertex[indice1].y;
pttmp[m1].z = (*object)->vertex[indice1].z; (*object)->vertexarray[curvert+i].saved = 0;
snorm[m1].x = (*object)->norm[indice1].x; copyPoint(&pttmp[curstoredidx[i]], &((*object)->vertex[curidx[i]]));
snorm[m1].y = (*object)->norm[indice1].y; copyPoint(&snorm[curstoredidx[i]], &((*object)->norm[curidx[i]]));
snorm[m1].z = (*object)->norm[indice1].z; }
}
if (m2 == -1) vatmp[numvertstored].indice = curstoredidx[i];
{ vatmp[numvertstored].u = curu[i];
oldva[n] = indice2; vatmp[numvertstored].v = curv[i];
text[n * 2] = u2; numvertstored++;
text[n * 2 + 1] = v2;
m2 = n;
n++;
(*object)->vertexarray[curvert + 1].saved = 0;
pttmp[m2].x = (*object)->vertex[indice2].x;
pttmp[m2].y = (*object)->vertex[indice2].y;
pttmp[m2].z = (*object)->vertex[indice2].z;
snorm[m2].x = (*object)->norm[indice2].x;
snorm[m2].y = (*object)->norm[indice2].y;
snorm[m2].z = (*object)->norm[indice2].z;
}
if (m3 == -1)
{
oldva[n] = indice3;
text[n * 2] = u3;
text[n * 2 + 1] = v3;
m3 = n;
n++;
(*object)->vertexarray[curvert + 2].saved = 0;
pttmp[m3].x = (*object)->vertex[indice3].x;
pttmp[m3].y = (*object)->vertex[indice3].y;
pttmp[m3].z = (*object)->vertex[indice3].z;
snorm[m3].x = (*object)->norm[indice3].x;
snorm[m3].y = (*object)->norm[indice3].y;
snorm[m3].z = (*object)->norm[indice3].z;
} }
vatmp[numvertstored].indice = m1;
vatmp[numvertstored].u = u1;
vatmp[numvertstored].v = v1;
numvertstored++;
vatmp[numvertstored].indice = m2;
vatmp[numvertstored].u = u2;
vatmp[numvertstored].v = v2;
numvertstored++;
vatmp[numvertstored].indice = m3;
vatmp[numvertstored].u = u3;
vatmp[numvertstored].v = v3;
numvertstored++;
numtristored++; numtristored++;
atleastone = 1; atleastone = 1;

View file

@ -66,6 +66,8 @@ typedef struct point
double z; double z;
} point_t; } point_t;
void copyPoint(point_t * dest, point_t * src);
typedef struct tcoord typedef struct tcoord
{ {
int indice; int indice;