diff options
Diffstat (limited to '')
-rw-r--r-- | linden/indra/newview/llvoavatar.cpp | 284 |
1 files changed, 213 insertions, 71 deletions
diff --git a/linden/indra/newview/llvoavatar.cpp b/linden/indra/newview/llvoavatar.cpp index 7d70dd2..3d2523e 100644 --- a/linden/indra/newview/llvoavatar.cpp +++ b/linden/indra/newview/llvoavatar.cpp | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2001-2008, Linden Research, Inc. | 7 | * Copyright (c) 2001-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
@@ -244,6 +244,11 @@ static F32 calc_bouncy_animation(F32 x) | |||
244 | return -(cosf(x * F_PI * 2.5f - F_PI_BY_TWO))*(0.4f + x * -0.1f) + x * 1.3f; | 244 | return -(cosf(x * F_PI * 2.5f - F_PI_BY_TWO))*(0.4f + x * -0.1f) + x * 1.3f; |
245 | } | 245 | } |
246 | 246 | ||
247 | BOOL LLLineSegmentCapsuleIntersect(const LLVector3& start, const LLVector3& end, const LLVector3& p1, const LLVector3& p2, const F32& radius, LLVector3& result) | ||
248 | { | ||
249 | return FALSE; | ||
250 | } | ||
251 | |||
247 | //----------------------------------------------------------------------------- | 252 | //----------------------------------------------------------------------------- |
248 | // Static Data | 253 | // Static Data |
249 | //----------------------------------------------------------------------------- | 254 | //----------------------------------------------------------------------------- |
@@ -267,6 +272,7 @@ LLUUID LLVOAvatar::sStepSounds[LL_MCODE_END] = | |||
267 | LLUUID(SND_RUBBER_RUBBER) | 272 | LLUUID(SND_RUBBER_RUBBER) |
268 | }; | 273 | }; |
269 | 274 | ||
275 | // static | ||
270 | S32 LLVOAvatar::sRenderName = RENDER_NAME_ALWAYS; | 276 | S32 LLVOAvatar::sRenderName = RENDER_NAME_ALWAYS; |
271 | BOOL LLVOAvatar::sRenderGroupTitles = TRUE; | 277 | BOOL LLVOAvatar::sRenderGroupTitles = TRUE; |
272 | S32 LLVOAvatar::sNumVisibleChatBubbles = 0; | 278 | S32 LLVOAvatar::sNumVisibleChatBubbles = 0; |
@@ -279,9 +285,12 @@ BOOL LLVOAvatar::sVisibleInFirstPerson = FALSE; | |||
279 | F32 LLVOAvatar::sLODFactor = 1.f; | 285 | F32 LLVOAvatar::sLODFactor = 1.f; |
280 | BOOL LLVOAvatar::sUseImpostors = FALSE; | 286 | BOOL LLVOAvatar::sUseImpostors = FALSE; |
281 | BOOL LLVOAvatar::sJointDebug = FALSE; | 287 | BOOL LLVOAvatar::sJointDebug = FALSE; |
282 | |||
283 | S32 LLVOAvatar::sCurJoint = 0; | 288 | S32 LLVOAvatar::sCurJoint = 0; |
284 | S32 LLVOAvatar::sCurVolume = 0; | 289 | S32 LLVOAvatar::sCurVolume = 0; |
290 | F32 LLVOAvatar::sUnbakedTime = 0.f; | ||
291 | F32 LLVOAvatar::sUnbakedUpdateTime = 0.f; | ||
292 | F32 LLVOAvatar::sGreyTime = 0.f; | ||
293 | F32 LLVOAvatar::sGreyUpdateTime = 0.f; | ||
285 | 294 | ||
286 | struct LLAvatarTexData | 295 | struct LLAvatarTexData |
287 | { | 296 | { |
@@ -753,7 +762,7 @@ LLVOAvatar::LLVOAvatar( | |||
753 | mRippleTimeLast = 0.f; | 762 | mRippleTimeLast = 0.f; |
754 | 763 | ||
755 | mShadowImagep = gImageList.getImageFromFile("foot_shadow.j2c"); | 764 | mShadowImagep = gImageList.getImageFromFile("foot_shadow.j2c"); |
756 | mShadowImagep->bind(); | 765 | gGL.getTexUnit(0)->bind(mShadowImagep.get()); |
757 | mShadowImagep->setClamp(TRUE, TRUE); | 766 | mShadowImagep->setClamp(TRUE, TRUE); |
758 | 767 | ||
759 | mInAir = FALSE; | 768 | mInAir = FALSE; |
@@ -1062,11 +1071,29 @@ void LLVOAvatar::deleteLayerSetCaches() | |||
1062 | if( mLowerBodyLayerSet ) mLowerBodyLayerSet->deleteCaches(); | 1071 | if( mLowerBodyLayerSet ) mLowerBodyLayerSet->deleteCaches(); |
1063 | if( mEyesLayerSet ) mEyesLayerSet->deleteCaches(); | 1072 | if( mEyesLayerSet ) mEyesLayerSet->deleteCaches(); |
1064 | if( mSkirtLayerSet ) mSkirtLayerSet->deleteCaches(); | 1073 | if( mSkirtLayerSet ) mSkirtLayerSet->deleteCaches(); |
1074 | |||
1075 | if(mUpperMaskTexName) | ||
1076 | { | ||
1077 | glDeleteTextures(1, (GLuint*)&mUpperMaskTexName); | ||
1078 | mUpperMaskTexName = 0 ; | ||
1079 | } | ||
1080 | if(mHeadMaskTexName) | ||
1081 | { | ||
1082 | glDeleteTextures(1, (GLuint*)&mHeadMaskTexName); | ||
1083 | mHeadMaskTexName = 0 ; | ||
1084 | } | ||
1085 | if(mLowerMaskTexName) | ||
1086 | { | ||
1087 | glDeleteTextures(1, (GLuint*)&mLowerMaskTexName); | ||
1088 | mLowerMaskTexName = 0 ; | ||
1089 | } | ||
1065 | } | 1090 | } |
1066 | 1091 | ||
1067 | // static | 1092 | // static |
1068 | BOOL LLVOAvatar::areAllNearbyInstancesBaked() | 1093 | BOOL LLVOAvatar::areAllNearbyInstancesBaked(S32& grey_avatars) |
1069 | { | 1094 | { |
1095 | BOOL res = TRUE; | ||
1096 | grey_avatars = 0; | ||
1070 | for (std::vector<LLCharacter*>::iterator iter = LLCharacter::sInstances.begin(); | 1097 | for (std::vector<LLCharacter*>::iterator iter = LLCharacter::sInstances.begin(); |
1071 | iter != LLCharacter::sInstances.end(); ++iter) | 1098 | iter != LLCharacter::sInstances.end(); ++iter) |
1072 | { | 1099 | { |
@@ -1075,18 +1102,22 @@ BOOL LLVOAvatar::areAllNearbyInstancesBaked() | |||
1075 | { | 1102 | { |
1076 | continue; | 1103 | continue; |
1077 | } | 1104 | } |
1078 | else | 1105 | // else |
1079 | if( inst->getPixelArea() < MIN_PIXEL_AREA_FOR_COMPOSITE ) | 1106 | // if( inst->getPixelArea() < MIN_PIXEL_AREA_FOR_COMPOSITE ) |
1080 | { | 1107 | // { |
1081 | return TRUE; // Assumes sInstances is sorted by pixel area. | 1108 | // return res; // Assumes sInstances is sorted by pixel area. |
1082 | } | 1109 | // } |
1083 | else | 1110 | else |
1084 | if( !inst->isFullyBaked() ) | 1111 | if( !inst->isFullyBaked() ) |
1085 | { | 1112 | { |
1086 | return FALSE; | 1113 | res = FALSE; |
1114 | if (inst->mHasGrey) | ||
1115 | { | ||
1116 | ++grey_avatars; | ||
1117 | } | ||
1087 | } | 1118 | } |
1088 | } | 1119 | } |
1089 | return TRUE; | 1120 | return res; |
1090 | } | 1121 | } |
1091 | 1122 | ||
1092 | // static | 1123 | // static |
@@ -1131,7 +1162,7 @@ void LLVOAvatar::dumpBakedStatus() | |||
1131 | } | 1162 | } |
1132 | 1163 | ||
1133 | 1164 | ||
1134 | F64 dist_to_camera = (inst->getPositionGlobal() - camera_pos_global).magVec(); | 1165 | F64 dist_to_camera = (inst->getPositionGlobal() - camera_pos_global).length(); |
1135 | llcont << " " << dist_to_camera << "m "; | 1166 | llcont << " " << dist_to_camera << "m "; |
1136 | 1167 | ||
1137 | llcont << " " << inst->mPixelArea << " pixels"; | 1168 | llcont << " " << inst->mPixelArea << " pixels"; |
@@ -1569,6 +1600,96 @@ void LLVOAvatar::getSpatialExtents(LLVector3& newMin, LLVector3& newMax) | |||
1569 | newMax += buffer; | 1600 | newMax += buffer; |
1570 | } | 1601 | } |
1571 | 1602 | ||
1603 | //----------------------------------------------------------------------------- | ||
1604 | // renderCollisionVolumes() | ||
1605 | //----------------------------------------------------------------------------- | ||
1606 | void LLVOAvatar::renderCollisionVolumes() | ||
1607 | { | ||
1608 | for (S32 i = 0; i < mNumCollisionVolumes; i++) | ||
1609 | { | ||
1610 | mCollisionVolumes[i].renderCollision(); | ||
1611 | } | ||
1612 | |||
1613 | if (mNameText.notNull()) | ||
1614 | { | ||
1615 | LLVector3 unused; | ||
1616 | mNameText->lineSegmentIntersect(LLVector3(0,0,0), LLVector3(0,0,1), unused, TRUE); | ||
1617 | } | ||
1618 | } | ||
1619 | |||
1620 | BOOL LLVOAvatar::lineSegmentIntersect(const LLVector3& start, const LLVector3& end, | ||
1621 | S32 face, | ||
1622 | BOOL pick_transparent, | ||
1623 | S32* face_hit, | ||
1624 | LLVector3* intersection, | ||
1625 | LLVector2* tex_coord, | ||
1626 | LLVector3* normal, | ||
1627 | LLVector3* bi_normal | ||
1628 | ) | ||
1629 | { | ||
1630 | |||
1631 | if (mIsSelf && !gAgent.needsRenderAvatar() || !LLPipeline::sPickAvatar) | ||
1632 | { | ||
1633 | return FALSE; | ||
1634 | } | ||
1635 | |||
1636 | if (lineSegmentBoundingBox(start, end)) | ||
1637 | { | ||
1638 | for (S32 i = 0; i < mNumCollisionVolumes; ++i) | ||
1639 | { | ||
1640 | mCollisionVolumes[i].updateWorldMatrix(); | ||
1641 | |||
1642 | glh::matrix4f mat((F32*) mCollisionVolumes[i].getXform()->getWorldMatrix().mMatrix); | ||
1643 | glh::matrix4f inverse = mat.inverse(); | ||
1644 | glh::matrix4f norm_mat = inverse.transpose(); | ||
1645 | |||
1646 | glh::vec3f p1(start.mV); | ||
1647 | glh::vec3f p2(end.mV); | ||
1648 | |||
1649 | inverse.mult_matrix_vec(p1); | ||
1650 | inverse.mult_matrix_vec(p2); | ||
1651 | |||
1652 | LLVector3 position; | ||
1653 | LLVector3 norm; | ||
1654 | |||
1655 | if (linesegment_sphere(LLVector3(p1.v), LLVector3(p2.v), LLVector3(0,0,0), 1.f, position, norm)) | ||
1656 | { | ||
1657 | glh::vec3f res_pos(position.mV); | ||
1658 | mat.mult_matrix_vec(res_pos); | ||
1659 | |||
1660 | norm.normalize(); | ||
1661 | glh::vec3f res_norm(norm.mV); | ||
1662 | norm_mat.mult_matrix_dir(res_norm); | ||
1663 | |||
1664 | if (intersection) | ||
1665 | { | ||
1666 | *intersection = LLVector3(res_pos.v); | ||
1667 | } | ||
1668 | |||
1669 | if (normal) | ||
1670 | { | ||
1671 | *normal = LLVector3(res_norm.v); | ||
1672 | } | ||
1673 | |||
1674 | return TRUE; | ||
1675 | } | ||
1676 | } | ||
1677 | } | ||
1678 | |||
1679 | LLVector3 position; | ||
1680 | if (mNameText.notNull() && mNameText->lineSegmentIntersect(start, end, position)) | ||
1681 | { | ||
1682 | if (intersection) | ||
1683 | { | ||
1684 | *intersection = position; | ||
1685 | } | ||
1686 | |||
1687 | return TRUE; | ||
1688 | } | ||
1689 | |||
1690 | return FALSE; | ||
1691 | } | ||
1692 | |||
1572 | 1693 | ||
1573 | //----------------------------------------------------------------------------- | 1694 | //----------------------------------------------------------------------------- |
1574 | // parseSkeletonFile() | 1695 | // parseSkeletonFile() |
@@ -2737,8 +2858,8 @@ void LLVOAvatar::idleUpdateMisc(bool detailed_update) | |||
2737 | else | 2858 | else |
2738 | { | 2859 | { |
2739 | getSpatialExtents(ext[0], ext[1]); | 2860 | getSpatialExtents(ext[0], ext[1]); |
2740 | if ((ext[1]-mImpostorExtents[1]).magVec() > 0.05f || | 2861 | if ((ext[1]-mImpostorExtents[1]).length() > 0.05f || |
2741 | (ext[0]-mImpostorExtents[0]).magVec() > 0.05f) | 2862 | (ext[0]-mImpostorExtents[0]).length() > 0.05f) |
2742 | { | 2863 | { |
2743 | mNeedsImpostorUpdate = TRUE; | 2864 | mNeedsImpostorUpdate = TRUE; |
2744 | } | 2865 | } |
@@ -2905,7 +3026,7 @@ void LLVOAvatar::idleUpdateWindEffect() | |||
2905 | F32 time_delta = mRippleTimer.getElapsedTimeF32() - mRippleTimeLast; | 3026 | F32 time_delta = mRippleTimer.getElapsedTimeF32() - mRippleTimeLast; |
2906 | mRippleTimeLast = mRippleTimer.getElapsedTimeF32(); | 3027 | mRippleTimeLast = mRippleTimer.getElapsedTimeF32(); |
2907 | LLVector3 velocity = getVelocity(); | 3028 | LLVector3 velocity = getVelocity(); |
2908 | F32 speed = velocity.magVec(); | 3029 | F32 speed = velocity.length(); |
2909 | //RN: velocity varies too much frame to frame for this to work | 3030 | //RN: velocity varies too much frame to frame for this to work |
2910 | mRippleAccel.clearVec();//lerp(mRippleAccel, (velocity - mLastVel) * time_delta, LLCriticalDamp::getInterpolant(0.02f)); | 3031 | mRippleAccel.clearVec();//lerp(mRippleAccel, (velocity - mLastVel) * time_delta, LLCriticalDamp::getInterpolant(0.02f)); |
2911 | mLastVel = velocity; | 3032 | mLastVel = velocity; |
@@ -2924,7 +3045,7 @@ void LLVOAvatar::idleUpdateWindEffect() | |||
2924 | } | 3045 | } |
2925 | 3046 | ||
2926 | wind.mV[VZ] += hover_strength; | 3047 | wind.mV[VZ] += hover_strength; |
2927 | wind.normVec(); | 3048 | wind.normalize(); |
2928 | 3049 | ||
2929 | wind.mV[VW] = llmin(0.025f + (speed * 0.015f) + hover_strength, 0.5f); | 3050 | wind.mV[VW] = llmin(0.025f + (speed * 0.015f) + hover_strength, 0.5f); |
2930 | F32 interp; | 3051 | F32 interp; |
@@ -3047,10 +3168,10 @@ void LLVOAvatar::idleUpdateNameTag(const LLVector3& root_pos_last) | |||
3047 | LLVector3 pixel_up_vec; | 3168 | LLVector3 pixel_up_vec; |
3048 | LLViewerCamera::getInstance()->getPixelVectors(root_pos_last, pixel_up_vec, pixel_right_vec); | 3169 | LLViewerCamera::getInstance()->getPixelVectors(root_pos_last, pixel_up_vec, pixel_right_vec); |
3049 | LLVector3 camera_to_av = root_pos_last - LLViewerCamera::getInstance()->getOrigin(); | 3170 | LLVector3 camera_to_av = root_pos_last - LLViewerCamera::getInstance()->getOrigin(); |
3050 | camera_to_av.normVec(); | 3171 | camera_to_av.normalize(); |
3051 | LLVector3 local_camera_at = camera_to_av * ~root_rot; | 3172 | LLVector3 local_camera_at = camera_to_av * ~root_rot; |
3052 | LLVector3 local_camera_up = camera_to_av % LLViewerCamera::getInstance()->getLeftAxis(); | 3173 | LLVector3 local_camera_up = camera_to_av % LLViewerCamera::getInstance()->getLeftAxis(); |
3053 | local_camera_up.normVec(); | 3174 | local_camera_up.normalize(); |
3054 | local_camera_up = local_camera_up * ~root_rot; | 3175 | local_camera_up = local_camera_up * ~root_rot; |
3055 | 3176 | ||
3056 | local_camera_up.scaleVec(mBodySize * 0.5f); | 3177 | local_camera_up.scaleVec(mBodySize * 0.5f); |
@@ -3502,7 +3623,7 @@ BOOL LLVOAvatar::updateCharacter(LLAgent &agent) | |||
3502 | 3623 | ||
3503 | LLVector3 xyVel = getVelocity(); | 3624 | LLVector3 xyVel = getVelocity(); |
3504 | xyVel.mV[VZ] = 0.0f; | 3625 | xyVel.mV[VZ] = 0.0f; |
3505 | speed = xyVel.magVec(); | 3626 | speed = xyVel.length(); |
3506 | 3627 | ||
3507 | BOOL throttle = TRUE; | 3628 | BOOL throttle = TRUE; |
3508 | 3629 | ||
@@ -3587,14 +3708,14 @@ BOOL LLVOAvatar::updateCharacter(LLAgent &agent) | |||
3587 | if (mIsSelf) | 3708 | if (mIsSelf) |
3588 | { | 3709 | { |
3589 | primDir = agent.getAtAxis() - projected_vec(agent.getAtAxis(), agent.getReferenceUpVector()); | 3710 | primDir = agent.getAtAxis() - projected_vec(agent.getAtAxis(), agent.getReferenceUpVector()); |
3590 | primDir.normVec(); | 3711 | primDir.normalize(); |
3591 | } | 3712 | } |
3592 | else | 3713 | else |
3593 | { | 3714 | { |
3594 | primDir = getRotation().getMatrix3().getFwdRow(); | 3715 | primDir = getRotation().getMatrix3().getFwdRow(); |
3595 | } | 3716 | } |
3596 | LLVector3 velDir = getVelocity(); | 3717 | LLVector3 velDir = getVelocity(); |
3597 | velDir.normVec(); | 3718 | velDir.normalize(); |
3598 | if ( mSignaledAnimations.find(ANIM_AGENT_WALK) != mSignaledAnimations.end()) | 3719 | if ( mSignaledAnimations.find(ANIM_AGENT_WALK) != mSignaledAnimations.end()) |
3599 | { | 3720 | { |
3600 | F32 vpD = velDir * primDir; | 3721 | F32 vpD = velDir * primDir; |
@@ -3616,13 +3737,13 @@ BOOL LLVOAvatar::updateCharacter(LLAgent &agent) | |||
3616 | LLVector3 at_axis = LLViewerCamera::getInstance()->getAtAxis(); | 3737 | LLVector3 at_axis = LLViewerCamera::getInstance()->getAtAxis(); |
3617 | LLVector3 up_vector = gAgent.getReferenceUpVector(); | 3738 | LLVector3 up_vector = gAgent.getReferenceUpVector(); |
3618 | at_axis -= up_vector * (at_axis * up_vector); | 3739 | at_axis -= up_vector * (at_axis * up_vector); |
3619 | at_axis.normVec(); | 3740 | at_axis.normalize(); |
3620 | 3741 | ||
3621 | F32 dot = fwdDir * at_axis; | 3742 | F32 dot = fwdDir * at_axis; |
3622 | if (dot < 0.f) | 3743 | if (dot < 0.f) |
3623 | { | 3744 | { |
3624 | fwdDir -= 2.f * at_axis * dot; | 3745 | fwdDir -= 2.f * at_axis * dot; |
3625 | fwdDir.normVec(); | 3746 | fwdDir.normalize(); |
3626 | } | 3747 | } |
3627 | } | 3748 | } |
3628 | 3749 | ||
@@ -3690,7 +3811,7 @@ BOOL LLVOAvatar::updateCharacter(LLAgent &agent) | |||
3690 | 3811 | ||
3691 | // Now compute the full world space rotation for the whole body (wQv) | 3812 | // Now compute the full world space rotation for the whole body (wQv) |
3692 | LLVector3 leftDir = upDir % fwdDir; | 3813 | LLVector3 leftDir = upDir % fwdDir; |
3693 | leftDir.normVec(); | 3814 | leftDir.normalize(); |
3694 | fwdDir = leftDir % upDir; | 3815 | fwdDir = leftDir % upDir; |
3695 | LLQuaternion wQv( fwdDir, leftDir, upDir ); | 3816 | LLQuaternion wQv( fwdDir, leftDir, upDir ); |
3696 | 3817 | ||
@@ -4131,7 +4252,7 @@ U32 LLVOAvatar::renderSkinned(EAvatarRenderPass pass) | |||
4131 | LLVector3 collide_point = slaved_pos; | 4252 | LLVector3 collide_point = slaved_pos; |
4132 | collide_point.mV[VZ] -= foot_plane_normal.mV[VZ] * (dist_from_plane + COLLISION_TOLERANCE - FOOT_COLLIDE_FUDGE); | 4253 | collide_point.mV[VZ] -= foot_plane_normal.mV[VZ] * (dist_from_plane + COLLISION_TOLERANCE - FOOT_COLLIDE_FUDGE); |
4133 | 4254 | ||
4134 | gGL.begin(LLVertexBuffer::LINES); | 4255 | gGL.begin(LLRender::LINES); |
4135 | { | 4256 | { |
4136 | F32 SQUARE_SIZE = 0.2f; | 4257 | F32 SQUARE_SIZE = 0.2f; |
4137 | gGL.color4f(1.f, 0.f, 0.f, 1.f); | 4258 | gGL.color4f(1.f, 0.f, 0.f, 1.f); |
@@ -4278,7 +4399,7 @@ U32 LLVOAvatar::renderFootShadows() | |||
4278 | LLGLDepthTest test(GL_TRUE, GL_FALSE); | 4399 | LLGLDepthTest test(GL_TRUE, GL_FALSE); |
4279 | //render foot shadows | 4400 | //render foot shadows |
4280 | LLGLEnable blend(GL_BLEND); | 4401 | LLGLEnable blend(GL_BLEND); |
4281 | mShadowImagep->bind(); | 4402 | gGL.getTexUnit(0)->bind(mShadowImagep.get()); |
4282 | glColor4fv(mShadow0Facep->getRenderColor().mV); | 4403 | glColor4fv(mShadow0Facep->getRenderColor().mV); |
4283 | mShadow0Facep->renderIndexed(foot_mask); | 4404 | mShadow0Facep->renderIndexed(foot_mask); |
4284 | glColor4fv(mShadow1Facep->getRenderColor().mV); | 4405 | glColor4fv(mShadow1Facep->getRenderColor().mV); |
@@ -4296,7 +4417,7 @@ U32 LLVOAvatar::renderImpostor(LLColor4U color) | |||
4296 | 4417 | ||
4297 | LLVector3 pos(getRenderPosition()+mImpostorOffset); | 4418 | LLVector3 pos(getRenderPosition()+mImpostorOffset); |
4298 | LLVector3 at = (pos - LLViewerCamera::getInstance()->getOrigin()); | 4419 | LLVector3 at = (pos - LLViewerCamera::getInstance()->getOrigin()); |
4299 | at.normVec(); | 4420 | at.normalize(); |
4300 | LLVector3 left = LLViewerCamera::getInstance()->getUpAxis() % at; | 4421 | LLVector3 left = LLViewerCamera::getInstance()->getUpAxis() % at; |
4301 | LLVector3 up = at%left; | 4422 | LLVector3 up = at%left; |
4302 | 4423 | ||
@@ -4324,8 +4445,8 @@ U32 LLVOAvatar::renderImpostor(LLColor4U color) | |||
4324 | color.mV[3] = (U8) (alpha*255); | 4445 | color.mV[3] = (U8) (alpha*255); |
4325 | 4446 | ||
4326 | gGL.color4ubv(color.mV); | 4447 | gGL.color4ubv(color.mV); |
4327 | mImpostor.bindTexture(); | 4448 | gGL.getTexUnit(0)->bind(&mImpostor); |
4328 | gGL.begin(LLVertexBuffer::QUADS); | 4449 | gGL.begin(LLRender::QUADS); |
4329 | gGL.texCoord2f(0,0); | 4450 | gGL.texCoord2f(0,0); |
4330 | gGL.vertex3fv((pos+left-up).mV); | 4451 | gGL.vertex3fv((pos+left-up).mV); |
4331 | gGL.texCoord2f(1,0); | 4452 | gGL.texCoord2f(1,0); |
@@ -4340,17 +4461,6 @@ U32 LLVOAvatar::renderImpostor(LLColor4U color) | |||
4340 | return 6; | 4461 | return 6; |
4341 | } | 4462 | } |
4342 | 4463 | ||
4343 | //----------------------------------------------------------------------------- | ||
4344 | // renderCollisionVolumes() | ||
4345 | //----------------------------------------------------------------------------- | ||
4346 | void LLVOAvatar::renderCollisionVolumes() | ||
4347 | { | ||
4348 | for (S32 i = 0; i < mNumCollisionVolumes; i++) | ||
4349 | { | ||
4350 | mCollisionVolumes[i].renderCollision(); | ||
4351 | } | ||
4352 | } | ||
4353 | |||
4354 | //------------------------------------------------------------------------ | 4464 | //------------------------------------------------------------------------ |
4355 | // LLVOAvatar::updateTextures() | 4465 | // LLVOAvatar::updateTextures() |
4356 | //------------------------------------------------------------------------ | 4466 | //------------------------------------------------------------------------ |
@@ -4385,23 +4495,23 @@ void LLVOAvatar::updateTextures(LLAgent &agent) | |||
4385 | { | 4495 | { |
4386 | if( head_baked && ! mHeadBakedLoaded ) | 4496 | if( head_baked && ! mHeadBakedLoaded ) |
4387 | { | 4497 | { |
4388 | getTEImage( TEX_HEAD_BAKED )->bind(); | 4498 | gGL.getTexUnit(0)->bind(getTEImage( TEX_HEAD_BAKED )); |
4389 | } | 4499 | } |
4390 | if( upper_baked && ! mUpperBakedLoaded ) | 4500 | if( upper_baked && ! mUpperBakedLoaded ) |
4391 | { | 4501 | { |
4392 | getTEImage( TEX_UPPER_BAKED )->bind(); | 4502 | gGL.getTexUnit(0)->bind(getTEImage( TEX_UPPER_BAKED )); |
4393 | } | 4503 | } |
4394 | if( lower_baked && ! mLowerBakedLoaded ) | 4504 | if( lower_baked && ! mLowerBakedLoaded ) |
4395 | { | 4505 | { |
4396 | getTEImage( TEX_LOWER_BAKED )->bind(); | 4506 | gGL.getTexUnit(0)->bind(getTEImage( TEX_LOWER_BAKED )); |
4397 | } | 4507 | } |
4398 | if( eyes_baked && ! mEyesBakedLoaded ) | 4508 | if( eyes_baked && ! mEyesBakedLoaded ) |
4399 | { | 4509 | { |
4400 | getTEImage( TEX_EYES_BAKED )->bind(); | 4510 | gGL.getTexUnit(0)->bind(getTEImage( TEX_EYES_BAKED )); |
4401 | } | 4511 | } |
4402 | if( skirt_baked && ! mSkirtBakedLoaded ) | 4512 | if( skirt_baked && ! mSkirtBakedLoaded ) |
4403 | { | 4513 | { |
4404 | getTEImage( TEX_SKIRT_BAKED )->bind(); | 4514 | gGL.getTexUnit(0)->bind(getTEImage( TEX_SKIRT_BAKED )); |
4405 | } | 4515 | } |
4406 | } | 4516 | } |
4407 | 4517 | ||
@@ -4432,6 +4542,7 @@ void LLVOAvatar::updateTextures(LLAgent &agent) | |||
4432 | 4542 | ||
4433 | mMaxPixelArea = 0.f; | 4543 | mMaxPixelArea = 0.f; |
4434 | mMinPixelArea = 99999999.f; | 4544 | mMinPixelArea = 99999999.f; |
4545 | mHasGrey = FALSE; // debug | ||
4435 | for (U32 i = 0; i < getNumTEs(); i++) | 4546 | for (U32 i = 0; i < getNumTEs(); i++) |
4436 | { | 4547 | { |
4437 | LLViewerImage *imagep = getTEImage(i); | 4548 | LLViewerImage *imagep = getTEImage(i); |
@@ -4590,22 +4701,35 @@ void LLVOAvatar::updateTextures(LLAgent &agent) | |||
4590 | void LLVOAvatar::addLocalTextureStats( LLVOAvatar::ELocTexIndex idx, LLViewerImage* imagep, | 4701 | void LLVOAvatar::addLocalTextureStats( LLVOAvatar::ELocTexIndex idx, LLViewerImage* imagep, |
4591 | F32 texel_area_ratio, BOOL render_avatar, BOOL covered_by_baked ) | 4702 | F32 texel_area_ratio, BOOL render_avatar, BOOL covered_by_baked ) |
4592 | { | 4703 | { |
4593 | if (!covered_by_baked && | 4704 | if (!covered_by_baked && render_avatar) // render_avatar is always true if mIsSelf |
4594 | render_avatar && // always true if mIsSelf | 4705 | { |
4595 | mLocalTexture[ idx ].notNull() && mLocalTexture[idx]->getID() != IMG_DEFAULT_AVATAR) | 4706 | if (mLocalTexture[ idx ].notNull() && mLocalTexture[idx]->getID() != IMG_DEFAULT_AVATAR) |
4596 | { | ||
4597 | F32 desired_pixels; | ||
4598 | if( mIsSelf ) | ||
4599 | { | 4707 | { |
4600 | desired_pixels = llmin(mPixelArea, (F32)LOCTEX_IMAGE_AREA_SELF ); | 4708 | F32 desired_pixels; |
4601 | imagep->setBoostLevel(LLViewerImage::BOOST_AVATAR_SELF); | 4709 | if( mIsSelf ) |
4710 | { | ||
4711 | desired_pixels = llmin(mPixelArea, (F32)LOCTEX_IMAGE_AREA_SELF ); | ||
4712 | imagep->setBoostLevel(LLViewerImage::BOOST_AVATAR_SELF); | ||
4713 | } | ||
4714 | else | ||
4715 | { | ||
4716 | desired_pixels = llmin(mPixelArea, (F32)LOCTEX_IMAGE_AREA_OTHER ); | ||
4717 | imagep->setBoostLevel(LLViewerImage::BOOST_AVATAR); | ||
4718 | } | ||
4719 | imagep->addTextureStats( desired_pixels / texel_area_ratio ); | ||
4720 | if (imagep->getDiscardLevel() < 0) | ||
4721 | { | ||
4722 | mHasGrey = TRUE; // for statistics gathering | ||
4723 | } | ||
4602 | } | 4724 | } |
4603 | else | 4725 | else |
4604 | { | 4726 | { |
4605 | desired_pixels = llmin(mPixelArea, (F32)LOCTEX_IMAGE_AREA_OTHER ); | 4727 | if (mLocalTexture[idx]->getID() == IMG_DEFAULT_AVATAR) |
4606 | imagep->setBoostLevel(LLViewerImage::BOOST_AVATAR); | 4728 | { |
4729 | // texture asset is missing | ||
4730 | mHasGrey = TRUE; // for statistics gathering | ||
4731 | } | ||
4607 | } | 4732 | } |
4608 | imagep->addTextureStats( desired_pixels, texel_area_ratio ); | ||
4609 | } | 4733 | } |
4610 | } | 4734 | } |
4611 | 4735 | ||
@@ -4614,7 +4738,7 @@ void LLVOAvatar::addBakedTextureStats( LLViewerImage* imagep, F32 pixel_area, F3 | |||
4614 | { | 4738 | { |
4615 | mMaxPixelArea = llmax(pixel_area, mMaxPixelArea); | 4739 | mMaxPixelArea = llmax(pixel_area, mMaxPixelArea); |
4616 | mMinPixelArea = llmin(pixel_area, mMinPixelArea); | 4740 | mMinPixelArea = llmin(pixel_area, mMinPixelArea); |
4617 | imagep->addTextureStats(pixel_area, texel_area_ratio); | 4741 | imagep->addTextureStats(pixel_area / texel_area_ratio); |
4618 | imagep->setBoostLevel(boost_level); | 4742 | imagep->setBoostLevel(boost_level); |
4619 | } | 4743 | } |
4620 | 4744 | ||
@@ -4803,12 +4927,13 @@ BOOL LLVOAvatar::processSingleAnimationStateChange( const LLUUID& anim_id, BOOL | |||
4803 | // to support both spatialized and non-spatialized instances of the same sound | 4927 | // to support both spatialized and non-spatialized instances of the same sound |
4804 | //if (mIsSelf) | 4928 | //if (mIsSelf) |
4805 | //{ | 4929 | //{ |
4806 | // F32 volume = gain * gSavedSettings.getF32("AudioLevelUI") | 4930 | // gAudiop->triggerSound(LLUUID(gSavedSettings.getString("UISndTyping")), 1.0f, LLAudioEngine::AUDIO_TYPE_UI); |
4807 | // gAudiop->triggerSound(LLUUID(gSavedSettings.getString("UISndTyping")), volume); | ||
4808 | //} | 4931 | //} |
4809 | //else | 4932 | //else |
4810 | LLUUID sound_id = LLUUID(gSavedSettings.getString("UISndTyping")); | 4933 | { |
4811 | gAudiop->triggerSound(sound_id, getID(), 1.0f, LLAudioEngine::AUDIO_TYPE_SFX, char_pos_global); | 4934 | LLUUID sound_id = LLUUID(gSavedSettings.getString("UISndTyping")); |
4935 | gAudiop->triggerSound(sound_id, getID(), 1.0f, LLAudioEngine::AUDIO_TYPE_SFX, char_pos_global); | ||
4936 | } | ||
4812 | } | 4937 | } |
4813 | } | 4938 | } |
4814 | } | 4939 | } |
@@ -5826,7 +5951,7 @@ void LLVOAvatar::setPixelAreaAndAngle(LLAgent &agent) | |||
5826 | } | 5951 | } |
5827 | else | 5952 | else |
5828 | { | 5953 | { |
5829 | F32 radius = size.magVec(); | 5954 | F32 radius = size.length(); |
5830 | mAppAngle = (F32) atan2( radius, range) * RAD_TO_DEG; | 5955 | mAppAngle = (F32) atan2( radius, range) * RAD_TO_DEG; |
5831 | } | 5956 | } |
5832 | 5957 | ||
@@ -5998,7 +6123,7 @@ void LLVOAvatar::updateShadowFaces() | |||
5998 | sprite.setPosition(shadow_pos_agent); | 6123 | sprite.setPosition(shadow_pos_agent); |
5999 | 6124 | ||
6000 | LLVector3 foot_to_knee = mKneeLeftp->getWorldPosition() - joint_world_pos; | 6125 | LLVector3 foot_to_knee = mKneeLeftp->getWorldPosition() - joint_world_pos; |
6001 | //foot_to_knee.normVec(); | 6126 | //foot_to_knee.normalize(); |
6002 | foot_to_knee -= projected_vec(foot_to_knee, sun_vec); | 6127 | foot_to_knee -= projected_vec(foot_to_knee, sun_vec); |
6003 | sprite.setYaw(azimuth(sun_vec - foot_to_knee)); | 6128 | sprite.setYaw(azimuth(sun_vec - foot_to_knee)); |
6004 | 6129 | ||
@@ -6031,7 +6156,7 @@ void LLVOAvatar::updateShadowFaces() | |||
6031 | sprite.setPosition(shadow_pos_agent); | 6156 | sprite.setPosition(shadow_pos_agent); |
6032 | 6157 | ||
6033 | LLVector3 foot_to_knee = mKneeRightp->getWorldPosition() - joint_world_pos; | 6158 | LLVector3 foot_to_knee = mKneeRightp->getWorldPosition() - joint_world_pos; |
6034 | //foot_to_knee.normVec(); | 6159 | //foot_to_knee.normalize(); |
6035 | foot_to_knee -= projected_vec(foot_to_knee, sun_vec); | 6160 | foot_to_knee -= projected_vec(foot_to_knee, sun_vec); |
6036 | sprite.setYaw(azimuth(sun_vec - foot_to_knee)); | 6161 | sprite.setYaw(azimuth(sun_vec - foot_to_knee)); |
6037 | 6162 | ||
@@ -6392,7 +6517,7 @@ void LLVOAvatar::getOffObject() | |||
6392 | LLVector3 at_axis = LLVector3::x_axis; | 6517 | LLVector3 at_axis = LLVector3::x_axis; |
6393 | at_axis = at_axis * av_rot; | 6518 | at_axis = at_axis * av_rot; |
6394 | at_axis.mV[VZ] = 0.f; | 6519 | at_axis.mV[VZ] = 0.f; |
6395 | at_axis.normVec(); | 6520 | at_axis.normalize(); |
6396 | gAgent.resetAxes(at_axis); | 6521 | gAgent.resetAxes(at_axis); |
6397 | 6522 | ||
6398 | //reset orientation | 6523 | //reset orientation |
@@ -6946,7 +7071,7 @@ BOOL LLVOAvatar::bindScratchTexture( LLGLenum format ) | |||
6946 | GLuint gl_name = getScratchTexName( format, &texture_bytes ); | 7071 | GLuint gl_name = getScratchTexName( format, &texture_bytes ); |
6947 | if( gl_name ) | 7072 | if( gl_name ) |
6948 | { | 7073 | { |
6949 | LLImageGL::bindExternalTexture( gl_name, 0, GL_TEXTURE_2D ); | 7074 | gGL.getTexUnit(0)->bindManual(LLTexUnit::TT_TEXTURE, gl_name); |
6950 | stop_glerror(); | 7075 | stop_glerror(); |
6951 | 7076 | ||
6952 | F32* last_bind_time = LLVOAvatar::sScratchTexLastBindTime.getIfThere( format ); | 7077 | F32* last_bind_time = LLVOAvatar::sScratchTexLastBindTime.getIfThere( format ); |
@@ -7004,7 +7129,7 @@ LLGLuint LLVOAvatar::getScratchTexName( LLGLenum format, U32* texture_bytes ) | |||
7004 | glGenTextures(1, &name ); | 7129 | glGenTextures(1, &name ); |
7005 | stop_glerror(); | 7130 | stop_glerror(); |
7006 | 7131 | ||
7007 | LLImageGL::bindExternalTexture( name, 0, GL_TEXTURE_2D ); | 7132 | gGL.getTexUnit(0)->bindManual(LLTexUnit::TT_TEXTURE, name); |
7008 | stop_glerror(); | 7133 | stop_glerror(); |
7009 | 7134 | ||
7010 | glTexImage2D( | 7135 | glTexImage2D( |
@@ -7019,7 +7144,7 @@ LLGLuint LLVOAvatar::getScratchTexName( LLGLenum format, U32* texture_bytes ) | |||
7019 | glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE ); | 7144 | glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE ); |
7020 | stop_glerror(); | 7145 | stop_glerror(); |
7021 | 7146 | ||
7022 | LLImageGL::unbindTexture(0, GL_TEXTURE_2D); | 7147 | gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE); |
7023 | stop_glerror(); | 7148 | stop_glerror(); |
7024 | 7149 | ||
7025 | LLVOAvatar::sScratchTexNames.addData( format, new LLGLuint( name ) ); | 7150 | LLVOAvatar::sScratchTexNames.addData( format, new LLGLuint( name ) ); |
@@ -8628,7 +8753,7 @@ void LLVOAvatar::onBakedTextureMasksLoaded( BOOL success, LLViewerImage *src_vi, | |||
8628 | glGenTextures(1, (GLuint*) &gl_name ); | 8753 | glGenTextures(1, (GLuint*) &gl_name ); |
8629 | stop_glerror(); | 8754 | stop_glerror(); |
8630 | 8755 | ||
8631 | LLImageGL::bindExternalTexture( gl_name, 0, GL_TEXTURE_2D ); | 8756 | gGL.getTexUnit(0)->bindManual(LLTexUnit::TT_TEXTURE, gl_name); |
8632 | stop_glerror(); | 8757 | stop_glerror(); |
8633 | 8758 | ||
8634 | glTexImage2D( | 8759 | glTexImage2D( |
@@ -9034,10 +9159,27 @@ void LLVOAvatar::cullAvatarsByPixelArea() | |||
9034 | } | 9159 | } |
9035 | } | 9160 | } |
9036 | 9161 | ||
9037 | if( LLVOAvatar::areAllNearbyInstancesBaked() ) | 9162 | S32 grey_avatars = 0; |
9163 | if( LLVOAvatar::areAllNearbyInstancesBaked(grey_avatars) ) | ||
9038 | { | 9164 | { |
9039 | LLVOAvatar::deleteCachedImages(); | 9165 | LLVOAvatar::deleteCachedImages(); |
9040 | } | 9166 | } |
9167 | else | ||
9168 | { | ||
9169 | if (gFrameTimeSeconds != sUnbakedUpdateTime) // only update once per frame | ||
9170 | { | ||
9171 | sUnbakedUpdateTime = gFrameTimeSeconds; | ||
9172 | sUnbakedTime += gFrameIntervalSeconds; | ||
9173 | } | ||
9174 | if (grey_avatars > 0) | ||
9175 | { | ||
9176 | if (gFrameTimeSeconds != sGreyUpdateTime) // only update once per frame | ||
9177 | { | ||
9178 | sGreyUpdateTime = gFrameTimeSeconds; | ||
9179 | sGreyTime += gFrameIntervalSeconds; | ||
9180 | } | ||
9181 | } | ||
9182 | } | ||
9041 | } | 9183 | } |
9042 | 9184 | ||
9043 | const LLUUID& LLVOAvatar::grabLocalTexture(ETextureIndex index) | 9185 | const LLUUID& LLVOAvatar::grabLocalTexture(ETextureIndex index) |
@@ -9903,7 +10045,7 @@ void LLVOAvatar::getImpostorValues(LLVector3* extents, LLVector3& angle, F32& di | |||
9903 | extents[1] = ext[1]; | 10045 | extents[1] = ext[1]; |
9904 | 10046 | ||
9905 | LLVector3 at = LLViewerCamera::getInstance()->getOrigin()-(getRenderPosition()+mImpostorOffset); | 10047 | LLVector3 at = LLViewerCamera::getInstance()->getOrigin()-(getRenderPosition()+mImpostorOffset); |
9906 | distance = at.normVec(); | 10048 | distance = at.normalize(); |
9907 | F32 da = 1.f - (at*LLViewerCamera::getInstance()->getAtAxis()); | 10049 | F32 da = 1.f - (at*LLViewerCamera::getInstance()->getAtAxis()); |
9908 | angle.mV[0] = LLViewerCamera::getInstance()->getYaw()*da; | 10050 | angle.mV[0] = LLViewerCamera::getInstance()->getYaw()*da; |
9909 | angle.mV[1] = LLViewerCamera::getInstance()->getPitch()*da; | 10051 | angle.mV[1] = LLViewerCamera::getInstance()->getPitch()*da; |