aboutsummaryrefslogtreecommitdiff
path: root/js/lib/geom/shape-primitive.js
diff options
context:
space:
mode:
authorhwc4872012-05-22 16:40:42 -0700
committerhwc4872012-05-22 16:40:42 -0700
commit08851078e89e9d4cb8fa341fa697a91be8de8ab9 (patch)
treefee8c0d38c1c540ef00c33e728346d765a4e699c /js/lib/geom/shape-primitive.js
parent50ede4afa801f53caff7939dad0408f9a0a8b744 (diff)
parent862ee363584dfba4bdd9abacbc3a3244c7ec66b5 (diff)
downloadninja-08851078e89e9d4cb8fa341fa697a91be8de8ab9.tar.gz
Merge branch 'master' of github.com:Motorola-Mobility/ninja-internal into Textures
Conflicts: js/lib/geom/shape-primitive.js js/lib/rdge/materials/linear-gradient-material.js
Diffstat (limited to 'js/lib/geom/shape-primitive.js')
-rw-r--r--js/lib/geom/shape-primitive.js27
1 files changed, 26 insertions, 1 deletions
diff --git a/js/lib/geom/shape-primitive.js b/js/lib/geom/shape-primitive.js
index 380cf334..858f38c8 100644
--- a/js/lib/geom/shape-primitive.js
+++ b/js/lib/geom/shape-primitive.js
@@ -49,7 +49,7 @@ ShapePrimitive.create = function(coords, normals, uvs, indices, primType, ver
49 return prim; 49 return prim;
50}; 50};
51 51
52ShapePrimitive.getMeshBounds = function( verts, nVerts ) 52ShapePrimitive.getBounds = function( prim )
53{ 53{
54 if (!verts || (nVerts <= 0)) return null; 54 if (!verts || (nVerts <= 0)) return null;
55 55
@@ -76,6 +76,31 @@ ShapePrimitive.refineMesh = function( verts, norms, uvs, indices, nVertices, pa
76 var oldVrtCount = nVertices; 76 var oldVrtCount = nVertices;
77 77
78 // get the param range 78 // get the param range
79 var verts = prim.bufferStreams[0];
80 var nVerts = verts.length;
81 var xMin = verts[0], xMax = verts[0],
82 yMin = verts[1], yMax = verts[1],
83 zMin = verts[2], zMax = verts[2];
84
85 for (var index=3; index<verts.length; )
86 {
87 if (verts[index] < xMin) xMin = verts[index];
88 else if (verts[index] > xMax) xMax = verts[index];
89
90 index++;
91 if (verts[index] < yMin) yMin = verts[index];
92 else if (verts[index] > yMax) yMax = verts[index];
93
94 index++;
95 if (verts[index] < zMin) zMin = verts[index];
96 else if (verts[index] > zMax) zMax = verts[index];
97
98 index++;
99 }
100
101 return [xMin, yMin, zMin, xMax, yMax, zMax];
102};
103
79 var pUMin = paramRange[0], pVMin = paramRange[1], 104 var pUMin = paramRange[0], pVMin = paramRange[1],
80 pUMax = paramRange[2], pVMax = paramRange[3]; 105 pUMax = paramRange[2], pVMax = paramRange[3];
81 var iTriangle = 0; 106 var iTriangle = 0;