aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llmath/llvolume.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llmath/llvolume.cpp')
-rw-r--r--linden/indra/llmath/llvolume.cpp220
1 files changed, 118 insertions, 102 deletions
diff --git a/linden/indra/llmath/llvolume.cpp b/linden/indra/llmath/llvolume.cpp
index c527e85..e42413a 100644
--- a/linden/indra/llmath/llvolume.cpp
+++ b/linden/indra/llmath/llvolume.cpp
@@ -724,11 +724,11 @@ BOOL LLProfile::generate(BOOL path_open,F32 detail, S32 split)
724BOOL LLProfileParams::importFile(FILE *fp) 724BOOL LLProfileParams::importFile(FILE *fp)
725{ 725{
726 const S32 BUFSIZE = 16384; 726 const S32 BUFSIZE = 16384;
727 char buffer[BUFSIZE]; 727 char buffer[BUFSIZE]; /* Flawfinder: ignore */
728 // *NOTE: changing the size or type of these buffers will require 728 // *NOTE: changing the size or type of these buffers will require
729 // changing the sscanf below. 729 // changing the sscanf below.
730 char keyword[256]; 730 char keyword[256]; /* Flawfinder: ignore */
731 char valuestr[256]; 731 char valuestr[256]; /* Flawfinder: ignore */
732 keyword[0] = 0; 732 keyword[0] = 0;
733 valuestr[0] = 0; 733 valuestr[0] = 0;
734 F32 tempF32; 734 F32 tempF32;
@@ -737,7 +737,10 @@ BOOL LLProfileParams::importFile(FILE *fp)
737 while (!feof(fp)) 737 while (!feof(fp))
738 { 738 {
739 fgets(buffer, BUFSIZE, fp); 739 fgets(buffer, BUFSIZE, fp);
740 sscanf(buffer, " %255s %255s", keyword, valuestr); 740 sscanf( /* Flawfinder: ignore */
741 buffer,
742 " %255s %255s",
743 keyword, valuestr);
741 if (!keyword) 744 if (!keyword)
742 { 745 {
743 continue; 746 continue;
@@ -796,11 +799,11 @@ BOOL LLProfileParams::exportFile(FILE *fp) const
796BOOL LLProfileParams::importLegacyStream(std::istream& input_stream) 799BOOL LLProfileParams::importLegacyStream(std::istream& input_stream)
797{ 800{
798 const S32 BUFSIZE = 16384; 801 const S32 BUFSIZE = 16384;
799 char buffer[BUFSIZE]; 802 char buffer[BUFSIZE]; /* Flawfinder: ignore */
800 // *NOTE: changing the size or type of these buffers will require 803 // *NOTE: changing the size or type of these buffers will require
801 // changing the sscanf below. 804 // changing the sscanf below.
802 char keyword[256]; 805 char keyword[256]; /* Flawfinder: ignore */
803 char valuestr[256]; 806 char valuestr[256]; /* Flawfinder: ignore */
804 keyword[0] = 0; 807 keyword[0] = 0;
805 valuestr[0] = 0; 808 valuestr[0] = 0;
806 F32 tempF32; 809 F32 tempF32;
@@ -809,7 +812,11 @@ BOOL LLProfileParams::importLegacyStream(std::istream& input_stream)
809 while (input_stream.good()) 812 while (input_stream.good())
810 { 813 {
811 input_stream.getline(buffer, BUFSIZE); 814 input_stream.getline(buffer, BUFSIZE);
812 sscanf(buffer, " %255s %255s", keyword, valuestr); 815 sscanf( /* Flawfinder: ignore */
816 buffer,
817 " %255s %255s",
818 keyword,
819 valuestr);
813 if (!keyword) 820 if (!keyword)
814 { 821 {
815 continue; 822 continue;
@@ -1218,11 +1225,11 @@ BOOL LLDynamicPath::generate(F32 detail, S32 split)
1218BOOL LLPathParams::importFile(FILE *fp) 1225BOOL LLPathParams::importFile(FILE *fp)
1219{ 1226{
1220 const S32 BUFSIZE = 16384; 1227 const S32 BUFSIZE = 16384;
1221 char buffer[BUFSIZE]; 1228 char buffer[BUFSIZE]; /* Flawfinder: ignore */
1222 // *NOTE: changing the size or type of these buffers will require 1229 // *NOTE: changing the size or type of these buffers will require
1223 // changing the sscanf below. 1230 // changing the sscanf below.
1224 char keyword[256]; 1231 char keyword[256]; /* Flawfinder: ignore */
1225 char valuestr[256]; 1232 char valuestr[256]; /* Flawfinder: ignore */
1226 keyword[0] = 0; 1233 keyword[0] = 0;
1227 valuestr[0] = 0; 1234 valuestr[0] = 0;
1228 1235
@@ -1233,7 +1240,10 @@ BOOL LLPathParams::importFile(FILE *fp)
1233 while (!feof(fp)) 1240 while (!feof(fp))
1234 { 1241 {
1235 fgets(buffer, BUFSIZE, fp); 1242 fgets(buffer, BUFSIZE, fp);
1236 sscanf(buffer, " %255s %255s", keyword, valuestr); 1243 sscanf( /* Flawfinder: ignore */
1244 buffer,
1245 " %255s %255s",
1246 keyword, valuestr);
1237 if (!keyword) 1247 if (!keyword)
1238 { 1248 {
1239 continue; 1249 continue;
@@ -1359,11 +1369,11 @@ BOOL LLPathParams::exportFile(FILE *fp) const
1359BOOL LLPathParams::importLegacyStream(std::istream& input_stream) 1369BOOL LLPathParams::importLegacyStream(std::istream& input_stream)
1360{ 1370{
1361 const S32 BUFSIZE = 16384; 1371 const S32 BUFSIZE = 16384;
1362 char buffer[BUFSIZE]; 1372 char buffer[BUFSIZE]; /* Flawfinder: ignore */
1363 // *NOTE: changing the size or type of these buffers will require 1373 // *NOTE: changing the size or type of these buffers will require
1364 // changing the sscanf below. 1374 // changing the sscanf below.
1365 char keyword[256]; 1375 char keyword[256]; /* Flawfinder: ignore */
1366 char valuestr[256]; 1376 char valuestr[256]; /* Flawfinder: ignore */
1367 keyword[0] = 0; 1377 keyword[0] = 0;
1368 valuestr[0] = 0; 1378 valuestr[0] = 0;
1369 1379
@@ -1374,7 +1384,10 @@ BOOL LLPathParams::importLegacyStream(std::istream& input_stream)
1374 while (input_stream.good()) 1384 while (input_stream.good())
1375 { 1385 {
1376 input_stream.getline(buffer, BUFSIZE); 1386 input_stream.getline(buffer, BUFSIZE);
1377 sscanf(buffer, " %255s %255s", keyword, valuestr); 1387 sscanf( /* Flawfinder: ignore */
1388 buffer,
1389 " %255s %255s",
1390 keyword, valuestr);
1378 if (!keyword) 1391 if (!keyword)
1379 { 1392 {
1380 continue; 1393 continue;
@@ -1771,9 +1784,6 @@ void LLVolume::createVolumeFaces()
1771 mVolumeFaces[i].create(); 1784 mVolumeFaces[i].create();
1772 } 1785 }
1773 } 1786 }
1774
1775 mBounds[1] = LLVector3(0,0,0);
1776 mBounds[0] = LLVector3(512,512,512);
1777} 1787}
1778 1788
1779 1789
@@ -1818,21 +1828,28 @@ void LLVolumeParams::copyParams(const LLVolumeParams &params)
1818 mPathParams.copyParams(params.mPathParams); 1828 mPathParams.copyParams(params.mPathParams);
1819} 1829}
1820 1830
1831// Less restricitve approx 0 for volumes
1832const F32 APPROXIMATELY_ZERO = 0.001f;
1833bool approx_zero( F32 f, F32 tolerance = APPROXIMATELY_ZERO)
1834{
1835 return (f >= -tolerance) && (f <= tolerance);
1836}
1837
1821// return true if in range (or nearly so) 1838// return true if in range (or nearly so)
1822static bool limit_range(F32& v, F32 min, F32 max) 1839static bool limit_range(F32& v, F32 min, F32 max, F32 tolerance = APPROXIMATELY_ZERO)
1823{ 1840{
1824 F32 min_delta = v - min; 1841 F32 min_delta = v - min;
1825 if (min_delta < 0.f) 1842 if (min_delta < 0.f)
1826 { 1843 {
1827 v = min; 1844 v = min;
1828 if (!is_approx_zero(min_delta)) 1845 if (!approx_zero(min_delta, tolerance))
1829 return false; 1846 return false;
1830 } 1847 }
1831 F32 max_delta = max - v; 1848 F32 max_delta = max - v;
1832 if (max_delta < 0.f) 1849 if (max_delta < 0.f)
1833 { 1850 {
1834 v = max; 1851 v = max;
1835 if (!is_approx_zero(max_delta)) 1852 if (!approx_zero(max_delta, tolerance))
1836 return false; 1853 return false;
1837 } 1854 }
1838 return true; 1855 return true;
@@ -1847,9 +1864,10 @@ bool LLVolumeParams::setBeginAndEndS(const F32 b, const F32 e)
1847 valid &= limit_range(begin, 0.f, 1.f - MIN_CUT_DELTA); 1864 valid &= limit_range(begin, 0.f, 1.f - MIN_CUT_DELTA);
1848 1865
1849 F32 end = e; 1866 F32 end = e;
1867 if (end >= .0149f && end < MIN_CUT_DELTA) end = MIN_CUT_DELTA; // eliminate warning for common rounding error
1850 valid &= limit_range(end, MIN_CUT_DELTA, 1.f); 1868 valid &= limit_range(end, MIN_CUT_DELTA, 1.f);
1851 1869
1852 valid &= limit_range(begin, 0.f, end - MIN_CUT_DELTA); 1870 valid &= limit_range(begin, 0.f, end - MIN_CUT_DELTA, .01f);
1853 1871
1854 // Now set them. 1872 // Now set them.
1855 mProfileParams.setBegin(begin); 1873 mProfileParams.setBegin(begin);
@@ -1869,7 +1887,7 @@ bool LLVolumeParams::setBeginAndEndT(const F32 b, const F32 e)
1869 F32 end = e; 1887 F32 end = e;
1870 valid &= limit_range(end, MIN_CUT_DELTA, 1.f); 1888 valid &= limit_range(end, MIN_CUT_DELTA, 1.f);
1871 1889
1872 valid &= limit_range(begin, 0.f, end - MIN_CUT_DELTA); 1890 valid &= limit_range(begin, 0.f, end - MIN_CUT_DELTA, .01f);
1873 1891
1874 // Now set them. 1892 // Now set them.
1875 mPathParams.setBegin(begin); 1893 mPathParams.setBegin(begin);
@@ -2026,7 +2044,7 @@ bool LLVolumeParams::setRadiusOffset(const F32 offset)
2026 { 2044 {
2027 radius_offset = max_radius_mag; 2045 radius_offset = max_radius_mag;
2028 } 2046 }
2029 valid = is_approx_zero(delta); 2047 valid = approx_zero(delta, .1f);
2030 } 2048 }
2031 2049
2032 mPathParams.setRadiusOffset(radius_offset); 2050 mPathParams.setRadiusOffset(radius_offset);
@@ -2060,7 +2078,7 @@ bool LLVolumeParams::setSkew(const F32 skew_value)
2060 { 2078 {
2061 skew = min_skew_mag; 2079 skew = min_skew_mag;
2062 } 2080 }
2063 valid = is_approx_zero(delta); 2081 valid = approx_zero(delta, .01f);
2064 } 2082 }
2065 2083
2066 mPathParams.setSkew(skew); 2084 mPathParams.setSkew(skew);
@@ -2185,7 +2203,7 @@ S32 *LLVolume::getTriangleIndices(U32 &num_indices) const
2185 size_s_out = getProfile().getTotalOut(); 2203 size_s_out = getProfile().getTotalOut();
2186 size_t = getPath().mPath.size(); 2204 size_t = getPath().mPath.size();
2187 2205
2188 if (open) 2206 if (open) /* Flawfinder: ignore */
2189 { 2207 {
2190 if (hollow) 2208 if (hollow)
2191 { 2209 {
@@ -2807,7 +2825,7 @@ noindices:
2807 return NULL; 2825 return NULL;
2808 } 2826 }
2809 num_indices = count; 2827 num_indices = count;
2810 memcpy(indices, index, count * sizeof(S32)); 2828 memcpy(indices, index, count * sizeof(S32)); /* Flawfinder: ignore */
2811 return indices; 2829 return indices;
2812} 2830}
2813 2831
@@ -2986,10 +3004,15 @@ void LLVolume::generateSilhouetteVertices(std::vector<LLVector3> &vertices,
2986 S32 v2 = face.mIndices[j*3+((k+1)%3)]; 3004 S32 v2 = face.mIndices[j*3+((k+1)%3)];
2987 3005
2988 vertices.push_back(face.mVertices[v1].mPosition*mat); 3006 vertices.push_back(face.mVertices[v1].mPosition*mat);
2989 normals.push_back(face.mVertices[v1].mNormal*norm_mat); 3007 LLVector3 norm1 = face.mVertices[v1].mNormal * norm_mat;
3008 norm1.normVec();
3009 normals.push_back(norm1);
2990 3010
2991 vertices.push_back(face.mVertices[v2].mPosition*mat); 3011 vertices.push_back(face.mVertices[v2].mPosition*mat);
2992 normals.push_back(face.mVertices[v2].mNormal*norm_mat); 3012 LLVector3 norm2 = face.mVertices[v2].mNormal * norm_mat;
3013 norm2.normVec();
3014 normals.push_back(norm2);
3015
2993 segments.push_back(vertices.size()); 3016 segments.push_back(vertices.size());
2994 } 3017 }
2995 } 3018 }
@@ -3310,7 +3333,7 @@ BOOL LLVolume::cleanupTriangleData( const S32 num_input_vertices,
3310 3333
3311 *output_triangles = new S32[cur_tri*3]; 3334 *output_triangles = new S32[cur_tri*3];
3312 num_output_triangles = cur_tri; 3335 num_output_triangles = cur_tri;
3313 memcpy(*output_triangles, sorted_tris, 3*cur_tri*sizeof(S32)); 3336 memcpy(*output_triangles, sorted_tris, 3*cur_tri*sizeof(S32)); /* Flawfinder: ignore */
3314 3337
3315 /* 3338 /*
3316 llinfos << "Out vertices: " << num_output_vertices << llendl; 3339 llinfos << "Out vertices: " << num_output_vertices << llendl;
@@ -3347,16 +3370,16 @@ BOOL LLVolumeParams::importFile(FILE *fp)
3347{ 3370{
3348 //llinfos << "importing volume" << llendl; 3371 //llinfos << "importing volume" << llendl;
3349 const S32 BUFSIZE = 16384; 3372 const S32 BUFSIZE = 16384;
3350 char buffer[BUFSIZE]; 3373 char buffer[BUFSIZE]; /* Flawfinder: ignore */
3351 // *NOTE: changing the size or type of this buffer will require 3374 // *NOTE: changing the size or type of this buffer will require
3352 // changing the sscanf below. 3375 // changing the sscanf below.
3353 char keyword[256]; 3376 char keyword[256]; /* Flawfinder: ignore */
3354 keyword[0] = 0; 3377 keyword[0] = 0;
3355 3378
3356 while (!feof(fp)) 3379 while (!feof(fp))
3357 { 3380 {
3358 fgets(buffer, BUFSIZE, fp); 3381 fgets(buffer, BUFSIZE, fp);
3359 sscanf(buffer, " %255s", keyword); 3382 sscanf(buffer, " %255s", keyword); /* Flawfinder: ignore */
3360 if (!keyword) 3383 if (!keyword)
3361 { 3384 {
3362 continue; 3385 continue;
@@ -3403,8 +3426,8 @@ BOOL LLVolumeParams::importLegacyStream(std::istream& input_stream)
3403 const S32 BUFSIZE = 16384; 3426 const S32 BUFSIZE = 16384;
3404 // *NOTE: changing the size or type of this buffer will require 3427 // *NOTE: changing the size or type of this buffer will require
3405 // changing the sscanf below. 3428 // changing the sscanf below.
3406 char buffer[BUFSIZE]; 3429 char buffer[BUFSIZE]; /* Flawfinder: ignore */
3407 char keyword[256]; 3430 char keyword[256]; /* Flawfinder: ignore */
3408 keyword[0] = 0; 3431 keyword[0] = 0;
3409 3432
3410 while (input_stream.good()) 3433 while (input_stream.good())
@@ -3753,6 +3776,9 @@ BOOL LLVolumeFace::createUnCutCubeCap()
3753 num_vertices = (grid_size+1)*(grid_size+1); 3776 num_vertices = (grid_size+1)*(grid_size+1);
3754 num_indices = quad_count * 4; 3777 num_indices = quad_count * 4;
3755 3778
3779 LLVector3& min = mExtents[0];
3780 LLVector3& max = mExtents[1];
3781
3756 S32 offset = 0; 3782 S32 offset = 0;
3757 if (mTypeMask & TOP_MASK) 3783 if (mTypeMask & TOP_MASK)
3758 offset = (max_t-1) * max_s; 3784 offset = (max_t-1) * max_s;
@@ -3792,32 +3818,6 @@ BOOL LLVolumeFace::createUnCutCubeCap()
3792 } 3818 }
3793 3819
3794 S32 vtop = mVertices.size(); 3820 S32 vtop = mVertices.size();
3795// S32 itop = mIndices.size();
3796/// vector_append(mVertices,4);
3797// vector_append(mIndices,4);
3798// LLVector3 new_pt = lerp(pt1, pt2, t_fraction);
3799#if 0
3800 for(int t=0;t<4;t++){
3801 VertexData vd;
3802 vd.mPosition = corners[t].mPosition;
3803 vd.mNormal =
3804 ((corners[(t+1)%4].mPosition-corners[t].mPosition)%
3805 (corners[(t+2)%4].mPosition-corners[(t+1)%4].mPosition));
3806 vd.mNormal.normVec();
3807
3808 if (mTypeMask & TOP_MASK)
3809 vd.mNormal *= -1.0f;
3810 vd.mBinormal = vd.mNormal;
3811 vd.mTexCoord = corners[t].mTexCoord;
3812 mVertices.push_back(vd);
3813 }
3814 int idxs[] = {0,1,2,2,3,0};
3815 if (mTypeMask & TOP_MASK){
3816 for(int i=0;i<6;i++)mIndices.push_back(vtop+idxs[i]);
3817 }else{
3818 for(int i=5;i>=0;i--)mIndices.push_back(vtop+idxs[i]);
3819 }
3820#else
3821 for(int gx = 0;gx<grid_size+1;gx++){ 3821 for(int gx = 0;gx<grid_size+1;gx++){
3822 for(int gy = 0;gy<grid_size+1;gy++){ 3822 for(int gy = 0;gy<grid_size+1;gy++){
3823 VertexData newVert; 3823 VertexData newVert;
@@ -3829,8 +3829,20 @@ BOOL LLVolumeFace::createUnCutCubeCap()
3829 (F32)gx/(F32)grid_size, 3829 (F32)gx/(F32)grid_size,
3830 (F32)gy/(F32)grid_size); 3830 (F32)gy/(F32)grid_size);
3831 mVertices.push_back(newVert); 3831 mVertices.push_back(newVert);
3832
3833 if (gx == 0 && gy == 0)
3834 {
3835 min = max = newVert.mPosition;
3836 }
3837 else
3838 {
3839 update_min_max(min,max,newVert.mPosition);
3840 }
3832 } 3841 }
3833 } 3842 }
3843
3844 mCenter = (min + max) * 0.5f;
3845
3834 int idxs[] = {0,1,(grid_size+1)+1,(grid_size+1)+1,(grid_size+1),0}; 3846 int idxs[] = {0,1,(grid_size+1)+1,(grid_size+1)+1,(grid_size+1),0};
3835 for(int gx = 0;gx<grid_size;gx++){ 3847 for(int gx = 0;gx<grid_size;gx++){
3836 for(int gy = 0;gy<grid_size;gy++){ 3848 for(int gy = 0;gy<grid_size;gy++){
@@ -3841,7 +3853,7 @@ BOOL LLVolumeFace::createUnCutCubeCap()
3841 } 3853 }
3842 } 3854 }
3843 } 3855 }
3844#endif 3856
3845 return TRUE; 3857 return TRUE;
3846} 3858}
3847 3859
@@ -3888,12 +3900,15 @@ BOOL LLVolumeFace::createCap()
3888 // Figure out the normal, assume all caps are flat faces. 3900 // Figure out the normal, assume all caps are flat faces.
3889 // Cross product to get normals. 3901 // Cross product to get normals.
3890 3902
3891 LLVector2 cuv = LLVector2(0,0); 3903 LLVector2 cuv;
3892 3904 LLVector2 min_uv, max_uv;
3905
3906 LLVector3& min = mExtents[0];
3907 LLVector3& max = mExtents[1];
3908
3893 // Copy the vertices into the array 3909 // Copy the vertices into the array
3894 for (i = 0; i < num_vertices; i++) 3910 for (i = 0; i < num_vertices; i++)
3895 { 3911 {
3896
3897 if (mTypeMask & TOP_MASK) 3912 if (mTypeMask & TOP_MASK)
3898 { 3913 {
3899 mVertices[i].mTexCoord.mV[0] = profile[i].mV[0]+0.5f; 3914 mVertices[i].mTexCoord.mV[0] = profile[i].mV[0]+0.5f;
@@ -3906,17 +3921,22 @@ BOOL LLVolumeFace::createCap()
3906 mVertices[i].mTexCoord.mV[1] = 0.5f - profile[i].mV[1]; 3921 mVertices[i].mTexCoord.mV[1] = 0.5f - profile[i].mV[1];
3907 } 3922 }
3908 3923
3909 if(i){ 3924 mVertices[i].mPosition = mesh[i + offset].mPos;
3910 //Dont include the first point of the profile in the average 3925
3911 cuv += mVertices[i].mTexCoord; 3926 if (i == 0)
3912 mCenter += mVertices[i].mPosition = mesh[i + offset].mPos; 3927 {
3928 min = max = mVertices[i].mPosition;
3929 min_uv = max_uv = mVertices[i].mTexCoord;
3930 }
3931 else
3932 {
3933 update_min_max(min,max, mVertices[i].mPosition);
3934 update_min_max(min_uv, max_uv, mVertices[i].mTexCoord);
3913 } 3935 }
3914 else mVertices[i].mPosition = mesh[i + offset].mPos;
3915 //mVertices[i].mNormal = normal;
3916 } 3936 }
3917 3937
3918 mCenter /= (F32)(num_vertices-1); 3938 mCenter = (min+max)*0.5f;
3919 cuv /= (F32)(num_vertices-1); 3939 cuv = (min_uv + max_uv)*0.5f;
3920 3940
3921 LLVector3 binormal = calc_binormal_from_triangle( 3941 LLVector3 binormal = calc_binormal_from_triangle(
3922 mCenter, cuv, 3942 mCenter, cuv,
@@ -4221,13 +4241,11 @@ BOOL LLVolumeFace::createCap()
4221 return TRUE; 4241 return TRUE;
4222} 4242}
4223 4243
4224
4225BOOL LLVolumeFace::createSide() 4244BOOL LLVolumeFace::createSide()
4226{ 4245{
4227 BOOL flat = mTypeMask & FLAT_MASK; 4246 BOOL flat = mTypeMask & FLAT_MASK;
4228 S32 num_vertices, num_indices; 4247 S32 num_vertices, num_indices;
4229 4248
4230
4231 const std::vector<LLVolume::Point>& mesh = mVolumep->getMesh(); 4249 const std::vector<LLVolume::Point>& mesh = mVolumep->getMesh();
4232 const std::vector<LLVector3>& profile = mVolumep->getProfile().mProfile; 4250 const std::vector<LLVector3>& profile = mVolumep->getProfile().mProfile;
4233 const std::vector<LLPath::PathPt>& path_data = mVolumep->getPath().mPath; 4251 const std::vector<LLPath::PathPt>& path_data = mVolumep->getPath().mPath;
@@ -4243,6 +4261,9 @@ BOOL LLVolumeFace::createSide()
4243 vector_append(mIndices,num_indices); 4261 vector_append(mIndices,num_indices);
4244 vector_append(mEdge, num_indices); 4262 vector_append(mEdge, num_indices);
4245 4263
4264 LLVector3& face_min = mExtents[0];
4265 LLVector3& face_max = mExtents[1];
4266
4246 mCenter.clearVec(); 4267 mCenter.clearVec();
4247 4268
4248 S32 begin_stex = llfloor( profile[mBeginS].mV[2] ); 4269 S32 begin_stex = llfloor( profile[mBeginS].mV[2] );
@@ -4290,17 +4311,26 @@ BOOL LLVolumeFace::createSide()
4290 i = mBeginS + s + max_s*t; 4311 i = mBeginS + s + max_s*t;
4291 } 4312 }
4292 4313
4293 mCenter += mVertices[cur_vertex].mPosition = mesh[i].mPos; 4314 mVertices[cur_vertex].mPosition = mesh[i].mPos;
4294 mVertices[cur_vertex].mTexCoord = LLVector2(ss,tt); 4315 mVertices[cur_vertex].mTexCoord = LLVector2(ss,tt);
4295 4316
4296 mVertices[cur_vertex].mNormal = LLVector3(0,0,0); 4317 mVertices[cur_vertex].mNormal = LLVector3(0,0,0);
4297 mVertices[cur_vertex].mBinormal = LLVector3(0,0,0); 4318 mVertices[cur_vertex].mBinormal = LLVector3(0,0,0);
4298 4319
4320 if (cur_vertex == 0)
4321 {
4322 face_min = face_max = mesh[i].mPos;
4323 }
4324 else
4325 {
4326 update_min_max(face_min, face_max, mesh[i].mPos);
4327 }
4328
4299 cur_vertex++; 4329 cur_vertex++;
4300 4330
4301 if ((mTypeMask & INNER_MASK) && (mTypeMask & FLAT_MASK) && mNumS > 2 && s > 0) 4331 if ((mTypeMask & INNER_MASK) && (mTypeMask & FLAT_MASK) && mNumS > 2 && s > 0)
4302 { 4332 {
4303 mCenter += mVertices[cur_vertex].mPosition = mesh[i].mPos; 4333 mVertices[cur_vertex].mPosition = mesh[i].mPos;
4304 mVertices[cur_vertex].mTexCoord = LLVector2(ss,tt); 4334 mVertices[cur_vertex].mTexCoord = LLVector2(ss,tt);
4305 4335
4306 mVertices[cur_vertex].mNormal = LLVector3(0,0,0); 4336 mVertices[cur_vertex].mNormal = LLVector3(0,0,0);
@@ -4322,15 +4352,19 @@ BOOL LLVolumeFace::createSide()
4322 4352
4323 i = mBeginS + s + max_s*t; 4353 i = mBeginS + s + max_s*t;
4324 ss = profile[mBeginS + s].mV[2] - begin_stex; 4354 ss = profile[mBeginS + s].mV[2] - begin_stex;
4325 mCenter += mVertices[cur_vertex].mPosition = mesh[i].mPos; 4355 mVertices[cur_vertex].mPosition = mesh[i].mPos;
4326 mVertices[cur_vertex].mTexCoord = LLVector2(ss,tt); 4356 mVertices[cur_vertex].mTexCoord = LLVector2(ss,tt);
4327 4357
4328 mVertices[cur_vertex].mNormal = LLVector3(0,0,0); 4358 mVertices[cur_vertex].mNormal = LLVector3(0,0,0);
4329 mVertices[cur_vertex].mBinormal = LLVector3(0,0,0); 4359 mVertices[cur_vertex].mBinormal = LLVector3(0,0,0);
4360
4361 update_min_max(face_min,face_max,mesh[i].mPos);
4362
4330 cur_vertex++; 4363 cur_vertex++;
4331 } 4364 }
4332 } 4365 }
4333 mCenter /= (F32)num_vertices; 4366
4367 mCenter = (face_min + face_max) * 0.5f;
4334 4368
4335 S32 cur_index = 0; 4369 S32 cur_index = 0;
4336 S32 cur_edge = 0; 4370 S32 cur_edge = 0;
@@ -4454,32 +4488,14 @@ BOOL LLVolumeFace::createSide()
4454 } 4488 }
4455 } 4489 }
4456 4490
4457 //this loop would LOVE OpenMP 4491 //normalize normals and binormals here so the meshes that reference
4458 LLVector3 min = mVolumep->mBounds[0] - mVolumep->mBounds[1]; 4492 //this volume data don't have to
4459 LLVector3 max = mVolumep->mBounds[0] + mVolumep->mBounds[1]; 4493 for (U32 i = 0; i < mVertices.size(); i++)
4460
4461 if (min == max && min == LLVector3(512,512,512))
4462 { 4494 {
4463 min = max = mVertices[0].mPosition;
4464 }
4465
4466 for (U32 i = 0; i < mVertices.size(); i++) {
4467 mVertices[i].mNormal.normVec(); 4495 mVertices[i].mNormal.normVec();
4468 mVertices[i].mBinormal.normVec(); 4496 mVertices[i].mBinormal.normVec();
4469
4470 for (U32 j = 0; j < 3; j++) {
4471 if (mVertices[i].mPosition.mV[j] > max.mV[j]) {
4472 max.mV[j] = mVertices[i].mPosition.mV[j];
4473 }
4474 if (mVertices[i].mPosition.mV[j] < min.mV[j]) {
4475 min.mV[j] = mVertices[i].mPosition.mV[j];
4476 }
4477 }
4478 } 4497 }
4479 4498
4480 mVolumep->mBounds[0] = (min + max) * 0.5f; //center
4481 mVolumep->mBounds[1] = (max - min) * 0.5f; //half-height
4482
4483 return TRUE; 4499 return TRUE;
4484} 4500}
4485 4501
@@ -4578,7 +4594,7 @@ LLVector3 calc_binormal_from_triangle(
4578 -r0.mV[VZ] / r0.mV[VX], 4594 -r0.mV[VZ] / r0.mV[VX],
4579 -r1.mV[VZ] / r1.mV[VX], 4595 -r1.mV[VZ] / r1.mV[VX],
4580 -r2.mV[VZ] / r2.mV[VX]); 4596 -r2.mV[VZ] / r2.mV[VX]);
4581 //binormal.normVec(); 4597 // binormal.normVec();
4582 return binormal; 4598 return binormal;
4583 } 4599 }
4584 else 4600 else