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.cpp193
1 files changed, 139 insertions, 54 deletions
diff --git a/linden/indra/llmath/llvolume.cpp b/linden/indra/llmath/llvolume.cpp
index 327f1bf..5764c38 100644
--- a/linden/indra/llmath/llvolume.cpp
+++ b/linden/indra/llmath/llvolume.cpp
@@ -1799,6 +1799,8 @@ void LLVolume::createVolumeFaces()
1799// sculpt replaces generate() for sculpted surfaces 1799// sculpt replaces generate() for sculpted surfaces
1800void LLVolume::sculpt(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, const U8* sculpt_data, S32 sculpt_level) 1800void LLVolume::sculpt(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, const U8* sculpt_data, S32 sculpt_level)
1801{ 1801{
1802 U8 sculpt_type = mParams.getSculptType();
1803
1802 BOOL data_is_empty = FALSE; 1804 BOOL data_is_empty = FALSE;
1803 1805
1804 if (sculpt_width == 0 || sculpt_height == 0 || sculpt_data == NULL) 1806 if (sculpt_width == 0 || sculpt_height == 0 || sculpt_data == NULL)
@@ -1880,6 +1882,7 @@ void LLVolume::sculpt(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components,
1880 line += sizeT; 1882 line += sizeT;
1881 } 1883 }
1882 } 1884 }
1885
1883 else 1886 else
1884 { 1887 {
1885 S32 line = 0; 1888 S32 line = 0;
@@ -1894,18 +1897,52 @@ void LLVolume::sculpt(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components,
1894 U32 x = (U32) ((F32)t/(sizeT-1) * (F32) sculpt_width); 1897 U32 x = (U32) ((F32)t/(sizeT-1) * (F32) sculpt_width);
1895 U32 y = (U32) ((F32)s/(sizeS-1) * (F32) sculpt_height); 1898 U32 y = (U32) ((F32)s/(sizeS-1) * (F32) sculpt_height);
1896 1899
1897 if (y == sculpt_height) // stitch bottom row 1900 if (y == 0) // top row stitching
1898 { 1901 {
1899 y = sculpt_height - 1; 1902 // pinch?
1900 x = sculpt_width / 2; 1903 if (sculpt_type == LL_SCULPT_TYPE_SPHERE)
1904 {
1905 x = sculpt_width / 2;
1906 }
1901 } 1907 }
1902 1908
1903 if (x == sculpt_width) // stitch sides 1909 if (y == sculpt_height) // bottom row stitching
1904 x = 0; 1910 {
1911 // wrap?
1912 if (sculpt_type == LL_SCULPT_TYPE_TORUS)
1913 {
1914 y = 0;
1915 }
1916 else
1917 {
1918 y = sculpt_height - 1;
1919 }
1905 1920
1906 if (y == 0) // stitch top row 1921 // pinch?
1907 x = sculpt_width / 2; 1922 if (sculpt_type == LL_SCULPT_TYPE_SPHERE)
1908 1923 {
1924 x = sculpt_width / 2;
1925 }
1926 }
1927
1928 if (x == sculpt_width) // side stitching
1929 {
1930 // wrap?
1931 if ((sculpt_type == LL_SCULPT_TYPE_SPHERE) ||
1932 (sculpt_type == LL_SCULPT_TYPE_TORUS) ||
1933 (sculpt_type == LL_SCULPT_TYPE_CYLINDER))
1934 {
1935 x = 0;
1936 }
1937
1938 else
1939 {
1940 x = sculpt_width - 1;
1941 }
1942 }
1943
1944
1945
1909 U32 index = (x + y * sculpt_width) * sculpt_components; 1946 U32 index = (x + y * sculpt_width) * sculpt_components;
1910 pt.mPos.mV[0] = sculpt_data[index ] / 256.f - 0.5f; 1947 pt.mPos.mV[0] = sculpt_data[index ] / 256.f - 0.5f;
1911 pt.mPos.mV[1] = sculpt_data[index+1] / 256.f - 0.5f; 1948 pt.mPos.mV[1] = sculpt_data[index+1] / 256.f - 0.5f;
@@ -4615,82 +4652,130 @@ BOOL LLVolumeFace::createSide()
4615 } 4652 }
4616 } 4653 }
4617 4654
4655 // adjust normals based on wrapping and stitching
4656
4618 BOOL s_bottom_converges = ((mVertices[0].mPosition - mVertices[mNumS*(mNumT-2)].mPosition).magVecSquared() < 0.000001f); 4657 BOOL s_bottom_converges = ((mVertices[0].mPosition - mVertices[mNumS*(mNumT-2)].mPosition).magVecSquared() < 0.000001f);
4619 BOOL s_top_converges = ((mVertices[mNumS-1].mPosition - mVertices[mNumS*(mNumT-2)+mNumS-1].mPosition).magVecSquared() < 0.000001f); 4658 BOOL s_top_converges = ((mVertices[mNumS-1].mPosition - mVertices[mNumS*(mNumT-2)+mNumS-1].mPosition).magVecSquared() < 0.000001f);
4620 4659 U8 sculpt_type = mVolumep->getParams().getSculptType();
4621 if (mVolumep->getPath().isOpen() == FALSE) { //wrap normals on T 4660
4622 for (S32 i = 0; i < mNumS; i++) { 4661 if (sculpt_type == LL_SCULPT_TYPE_NONE) // logic for non-sculpt volumes
4623 LLVector3 norm = mVertices[i].mNormal + mVertices[mNumS*(mNumT-1)+i].mNormal; 4662 {
4624 mVertices[i].mNormal = norm; 4663 if (mVolumep->getPath().isOpen() == FALSE)
4625 mVertices[mNumS*(mNumT-1)+i].mNormal = norm; 4664 { //wrap normals on T
4665 for (S32 i = 0; i < mNumS; i++)
4666 {
4667 LLVector3 norm = mVertices[i].mNormal + mVertices[mNumS*(mNumT-1)+i].mNormal;
4668 mVertices[i].mNormal = norm;
4669 mVertices[mNumS*(mNumT-1)+i].mNormal = norm;
4670 }
4626 } 4671 }
4627 }
4628 4672
4629 if ((mVolumep->getProfile().isOpen() == FALSE) && 4673 if ((mVolumep->getProfile().isOpen() == FALSE) && !(s_bottom_converges))
4630 !(s_bottom_converges))
4631 { //wrap normals on S 4674 { //wrap normals on S
4632 for (S32 i = 0; i < mNumT; i++) { 4675 for (S32 i = 0; i < mNumT; i++)
4676 {
4633 LLVector3 norm = mVertices[mNumS*i].mNormal + mVertices[mNumS*i+mNumS-1].mNormal; 4677 LLVector3 norm = mVertices[mNumS*i].mNormal + mVertices[mNumS*i+mNumS-1].mNormal;
4634 mVertices[mNumS * i].mNormal = norm; 4678 mVertices[mNumS * i].mNormal = norm;
4635 mVertices[mNumS * i+mNumS-1].mNormal = norm; 4679 mVertices[mNumS * i+mNumS-1].mNormal = norm;
4636 } 4680 }
4637 } 4681 }
4638 4682
4639 if (mVolumep->getPathType() == LL_PCODE_PATH_CIRCLE && 4683 if (mVolumep->getPathType() == LL_PCODE_PATH_CIRCLE &&
4640 ((mVolumep->getProfileType() & LL_PCODE_PROFILE_MASK) == LL_PCODE_PROFILE_CIRCLE_HALF)) 4684 ((mVolumep->getProfileType() & LL_PCODE_PROFILE_MASK) == LL_PCODE_PROFILE_CIRCLE_HALF))
4641 { 4685 {
4642 if (s_bottom_converges) 4686 if (s_bottom_converges)
4643 { //all lower S have same normal 4687 { //all lower S have same normal
4644 for (S32 i = 0; i < mNumT; i++) { 4688 for (S32 i = 0; i < mNumT; i++)
4645 mVertices[mNumS*i].mNormal = LLVector3(1,0,0); 4689 {
4690 mVertices[mNumS*i].mNormal = LLVector3(1,0,0);
4691 }
4646 } 4692 }
4647 }
4648 4693
4649 if (s_top_converges) 4694 if (s_top_converges)
4650 { //all upper S have same normal 4695 { //all upper S have same normal
4651 for (S32 i = 0; i < mNumT; i++) { 4696 for (S32 i = 0; i < mNumT; i++)
4652 mVertices[mNumS*i+mNumS-1].mNormal = LLVector3(-1,0,0); 4697 {
4698 mVertices[mNumS*i+mNumS-1].mNormal = LLVector3(-1,0,0);
4699 }
4653 } 4700 }
4654 } 4701 }
4655 } 4702 }
4656
4657 U8 sculpt_type = mVolumep->getParams().getSculptType();
4658 4703
4659 if (sculpt_type == LL_SCULPT_TYPE_SPHERE) 4704 else // logic for sculpt volumes
4660 { 4705 {
4661 // average normals for north pole 4706 BOOL average_poles = FALSE;
4707 BOOL wrap_s = FALSE;
4708 BOOL wrap_t = FALSE;
4709
4710 if (sculpt_type == LL_SCULPT_TYPE_SPHERE)
4711 average_poles = TRUE;
4712
4713 if ((sculpt_type == LL_SCULPT_TYPE_SPHERE) ||
4714 (sculpt_type == LL_SCULPT_TYPE_TORUS) ||
4715 (sculpt_type == LL_SCULPT_TYPE_CYLINDER))
4716 wrap_s = TRUE;
4717
4718 if (sculpt_type == LL_SCULPT_TYPE_TORUS)
4719 wrap_t = TRUE;
4720
4662 4721
4663 LLVector3 average(0.0, 0.0, 0.0); 4722 if (average_poles)
4664 for (S32 i = 0; i < mNumS; i++)
4665 { 4723 {
4666 average += mVertices[i].mNormal; 4724 // average normals for north pole
4667 } 4725
4726 LLVector3 average(0.0, 0.0, 0.0);
4727 for (S32 i = 0; i < mNumS; i++)
4728 {
4729 average += mVertices[i].mNormal;
4730 }
4731
4732 // set average
4733 for (S32 i = 0; i < mNumS; i++)
4734 {
4735 mVertices[i].mNormal = average;
4736 }
4737
4738 // average normals for south pole
4739
4740 average = LLVector3(0.0, 0.0, 0.0);
4741 for (S32 i = 0; i < mNumS; i++)
4742 {
4743 average += mVertices[i + mNumS * (mNumT - 1)].mNormal;
4744 }
4745
4746 // set average
4747 for (S32 i = 0; i < mNumS; i++)
4748 {
4749 mVertices[i + mNumS * (mNumT - 1)].mNormal = average;
4750 }
4668 4751
4669 // set average
4670 for (S32 i = 0; i < mNumS; i++)
4671 {
4672 mVertices[i].mNormal = average;
4673 } 4752 }
4674 }
4675 4753
4676
4677 if (sculpt_type == LL_SCULPT_TYPE_SPHERE)
4678 {
4679 // average normals for south pole
4680 4754
4681 LLVector3 average(0.0, 0.0, 0.0); 4755 if (wrap_s)
4682 for (S32 i = 0; i < mNumS; i++)
4683 { 4756 {
4684 average += mVertices[i + mNumS * (mNumT - 1)].mNormal; 4757 for (S32 i = 0; i < mNumT; i++)
4758 {
4759 LLVector3 norm = mVertices[mNumS*i].mNormal + mVertices[mNumS*i+mNumS-1].mNormal;
4760 mVertices[mNumS * i].mNormal = norm;
4761 mVertices[mNumS * i+mNumS-1].mNormal = norm;
4762 }
4685 } 4763 }
4686 4764
4687 // set average 4765
4688 for (S32 i = 0; i < mNumS; i++) 4766
4767 if (wrap_t)
4689 { 4768 {
4690 mVertices[i + mNumS * (mNumT - 1)].mNormal = average; 4769 for (S32 i = 0; i < mNumS; i++)
4770 {
4771 LLVector3 norm = mVertices[i].mNormal + mVertices[mNumS*(mNumT-1)+i].mNormal;
4772 mVertices[i].mNormal = norm;
4773 mVertices[mNumS*(mNumT-1)+i].mNormal = norm;
4774 }
4775
4691 } 4776 }
4692 }
4693 4777
4778 }
4694 4779
4695 4780
4696 //normalize normals and binormals here so the meshes that reference 4781 //normalize normals and binormals here so the meshes that reference