diff options
author | Jacek Antonelli | 2009-01-28 20:04:52 -0600 |
---|---|---|
committer | Jacek Antonelli | 2009-01-28 20:05:02 -0600 |
commit | 0ef11cf31364456ec247b0fc7ad8f6d1de408400 (patch) | |
tree | 50754b286468147a70271253a2a74215c80e1354 /linden/indra/llprimitive | |
parent | Second Life viewer sources 1.22.5-RC (diff) | |
download | meta-impy-0ef11cf31364456ec247b0fc7ad8f6d1de408400.zip meta-impy-0ef11cf31364456ec247b0fc7ad8f6d1de408400.tar.gz meta-impy-0ef11cf31364456ec247b0fc7ad8f6d1de408400.tar.bz2 meta-impy-0ef11cf31364456ec247b0fc7ad8f6d1de408400.tar.xz |
Second Life viewer sources 1.22.6-RC
Diffstat (limited to 'linden/indra/llprimitive')
-rw-r--r-- | linden/indra/llprimitive/llprimitive.cpp | 205 |
1 files changed, 4 insertions, 201 deletions
diff --git a/linden/indra/llprimitive/llprimitive.cpp b/linden/indra/llprimitive/llprimitive.cpp index 57d0a95..dc389c1 100644 --- a/linden/indra/llprimitive/llprimitive.cpp +++ b/linden/indra/llprimitive/llprimitive.cpp | |||
@@ -952,213 +952,16 @@ BOOL LLPrimitive::setVolume(const LLVolumeParams &volume_params, const S32 detai | |||
952 | 952 | ||
953 | U32 old_face_mask = mVolumep->mFaceMask; | 953 | U32 old_face_mask = mVolumep->mFaceMask; |
954 | 954 | ||
955 | S32 face_bit = 0; | ||
956 | S32 cur_mask = 0; | ||
957 | |||
958 | // grab copies of the old faces so we can determine the TE mappings... | ||
959 | std::vector<LLProfile::Face> old_faces; // list of old faces for remapping texture entries | ||
960 | LLTextureEntry old_tes[9]; | ||
961 | |||
962 | for (S32 face = 0; face < mVolumep->getNumFaces(); face++) | ||
963 | { | ||
964 | old_faces.push_back(mVolumep->getProfile().mFaces[face]); | ||
965 | } | ||
966 | |||
967 | for (face_bit = 0; face_bit < 9; face_bit++) | ||
968 | { | ||
969 | cur_mask = 0x1 << face_bit; | ||
970 | if (old_face_mask & cur_mask) | ||
971 | { | ||
972 | S32 te_index = face_index_from_id(cur_mask, old_faces); | ||
973 | old_tes[face_bit] = *getTE(te_index); | ||
974 | //llinfos << face_bit << ":" << te_index << ":" << old_tes[face_bit].getID() << llendl; | ||
975 | } | ||
976 | } | ||
977 | |||
978 | |||
979 | // build the new object | 955 | // build the new object |
980 | sVolumeManager->unrefVolume(mVolumep); | 956 | sVolumeManager->unrefVolume(mVolumep); |
981 | mVolumep = volumep; | 957 | mVolumep = volumep; |
982 | 958 | ||
983 | U32 new_face_mask = mVolumep->mFaceMask; | 959 | U32 new_face_mask = mVolumep->mFaceMask; |
984 | S32 i; | 960 | if (old_face_mask != new_face_mask) |
985 | |||
986 | /* | ||
987 | std::string old_mask_string; | ||
988 | for (i = 0; i < 9; i++) | ||
989 | { | 961 | { |
990 | if (old_face_mask & (1 << i)) | ||
991 | { | ||
992 | old_mask_string.append("1"); | ||
993 | } | ||
994 | else | ||
995 | { | ||
996 | old_mask_string.append("0"); | ||
997 | } | ||
998 | } | ||
999 | std::string new_mask_string; | ||
1000 | for (i = 0; i < 9; i++) | ||
1001 | { | ||
1002 | if (new_face_mask & (1 << i)) | ||
1003 | { | ||
1004 | new_mask_string.append("1"); | ||
1005 | } | ||
1006 | else | ||
1007 | { | ||
1008 | new_mask_string.append("0"); | ||
1009 | } | ||
1010 | } | ||
1011 | |||
1012 | llinfos << "old mask: " << old_mask_string << llendl; | ||
1013 | llinfos << "new mask: " << new_mask_string << llendl; | ||
1014 | */ | ||
1015 | |||
1016 | |||
1017 | if (old_face_mask == new_face_mask) | ||
1018 | { | ||
1019 | // nothing to do | ||
1020 | return TRUE; | ||
1021 | } | ||
1022 | |||
1023 | if (mVolumep->getNumFaces() == 0 && new_face_mask != 0) | ||
1024 | { | ||
1025 | llwarns << "Object with 0 faces found...INCORRECT!" << llendl; | ||
1026 | setNumTEs(mVolumep->getNumFaces()); | 962 | setNumTEs(mVolumep->getNumFaces()); |
1027 | return TRUE; | 963 | } |
1028 | } | 964 | |
1029 | |||
1030 | |||
1031 | S32 face_mapping[9]; | ||
1032 | for (face_bit = 0; face_bit < 9; face_bit++) | ||
1033 | { | ||
1034 | face_mapping[face_bit] = face_bit; | ||
1035 | } | ||
1036 | |||
1037 | // Generate the face-type mappings | ||
1038 | for (face_bit = 0; face_bit < 9; face_bit++) | ||
1039 | { | ||
1040 | cur_mask = 0x1 << face_bit; | ||
1041 | if (!(new_face_mask & cur_mask)) | ||
1042 | { | ||
1043 | // Face doesn't exist in new map. | ||
1044 | face_mapping[face_bit] = -1; | ||
1045 | continue; | ||
1046 | } | ||
1047 | else if (old_face_mask & cur_mask) | ||
1048 | { | ||
1049 | // Face exists in new and old map. | ||
1050 | face_mapping[face_bit] = face_bit; | ||
1051 | continue; | ||
1052 | } | ||
1053 | |||
1054 | // OK, how we've got a mismatch, where we have to fill a new face with one from | ||
1055 | // the old face. | ||
1056 | if (cur_mask & (LL_FACE_PATH_BEGIN | LL_FACE_PATH_END | LL_FACE_INNER_SIDE)) | ||
1057 | { | ||
1058 | // It's a top/bottom/hollow interior face. | ||
1059 | if (old_face_mask & LL_FACE_PATH_END) | ||
1060 | { | ||
1061 | face_mapping[face_bit] = 1; | ||
1062 | continue; | ||
1063 | } | ||
1064 | else | ||
1065 | { | ||
1066 | S32 cur_outer_mask = LL_FACE_OUTER_SIDE_0; | ||
1067 | for (i = 0; i < 4; i++) | ||
1068 | { | ||
1069 | if (old_face_mask & cur_outer_mask) | ||
1070 | { | ||
1071 | face_mapping[face_bit] = 5 + i; | ||
1072 | break; | ||
1073 | } | ||
1074 | cur_outer_mask <<= 1; | ||
1075 | } | ||
1076 | if (i == 4) | ||
1077 | { | ||
1078 | llwarns << "No path end or outer face in volume!" << llendl; | ||
1079 | } | ||
1080 | continue; | ||
1081 | } | ||
1082 | } | ||
1083 | |||
1084 | if (cur_mask & (LL_FACE_PROFILE_BEGIN | LL_FACE_PROFILE_END)) | ||
1085 | { | ||
1086 | // A cut slice. Use the hollow interior if we have it. | ||
1087 | if (old_face_mask & LL_FACE_INNER_SIDE) | ||
1088 | { | ||
1089 | face_mapping[face_bit] = 2; | ||
1090 | continue; | ||
1091 | } | ||
1092 | |||
1093 | // No interior, use the bottom face. | ||
1094 | // Could figure out which of the outer faces was nearest, but that would be harder. | ||
1095 | if (old_face_mask & LL_FACE_PATH_END) | ||
1096 | { | ||
1097 | face_mapping[face_bit] = 1; | ||
1098 | continue; | ||
1099 | } | ||
1100 | else | ||
1101 | { | ||
1102 | S32 cur_outer_mask = LL_FACE_OUTER_SIDE_0; | ||
1103 | for (i = 0; i < 4; i++) | ||
1104 | { | ||
1105 | if (old_face_mask & cur_outer_mask) | ||
1106 | { | ||
1107 | face_mapping[face_bit] = 5 + i; | ||
1108 | break; | ||
1109 | } | ||
1110 | cur_outer_mask <<= 1; | ||
1111 | } | ||
1112 | if (i == 4) | ||
1113 | { | ||
1114 | llwarns << "No path end or outer face in volume!" << llendl; | ||
1115 | } | ||
1116 | continue; | ||
1117 | } | ||
1118 | } | ||
1119 | |||
1120 | // OK, the face that's missing is an outer face... | ||
1121 | // Pull from the nearest adjacent outer face (there's always guaranteed to be one... | ||
1122 | S32 cur_outer = face_bit - 5; | ||
1123 | S32 min_dist = 5; | ||
1124 | S32 min_outer_bit = -1; | ||
1125 | S32 i; | ||
1126 | for (i = 0; i < 4; i++) | ||
1127 | { | ||
1128 | if (old_face_mask & (LL_FACE_OUTER_SIDE_0 << i)) | ||
1129 | { | ||
1130 | S32 dist = abs(i - cur_outer); | ||
1131 | if (dist < min_dist) | ||
1132 | { | ||
1133 | min_dist = dist; | ||
1134 | min_outer_bit = i + 5; | ||
1135 | } | ||
1136 | } | ||
1137 | } | ||
1138 | if (-1 == min_outer_bit) | ||
1139 | { | ||
1140 | llinfos << (LLVolume *)mVolumep << llendl; | ||
1141 | llwarns << "Bad! No outer faces, impossible!" << llendl; | ||
1142 | } | ||
1143 | face_mapping[face_bit] = min_outer_bit; | ||
1144 | } | ||
1145 | |||
1146 | |||
1147 | setNumTEs(mVolumep->getNumFaces()); | ||
1148 | for (face_bit = 0; face_bit < 9; face_bit++) | ||
1149 | { | ||
1150 | cur_mask = 0x1 << face_bit; | ||
1151 | if (new_face_mask & cur_mask) | ||
1152 | { | ||
1153 | if (-1 == face_mapping[face_bit]) | ||
1154 | { | ||
1155 | llwarns << "No mapping from old face to new face!" << llendl; | ||
1156 | } | ||
1157 | |||
1158 | S32 te_num = face_index_from_id(cur_mask, mVolumep->getProfile().mFaces); | ||
1159 | setTE(te_num, old_tes[face_mapping[face_bit]]); | ||
1160 | } | ||
1161 | } | ||
1162 | return TRUE; | 965 | return TRUE; |
1163 | } | 966 | } |
1164 | 967 | ||