aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llfloaterworldmap.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llfloaterworldmap.cpp')
-rw-r--r--linden/indra/newview/llfloaterworldmap.cpp75
1 files changed, 69 insertions, 6 deletions
diff --git a/linden/indra/newview/llfloaterworldmap.cpp b/linden/indra/newview/llfloaterworldmap.cpp
index dc42a40..ccd252b 100644
--- a/linden/indra/newview/llfloaterworldmap.cpp
+++ b/linden/indra/newview/llfloaterworldmap.cpp
@@ -179,6 +179,8 @@ LLFloaterWorldMap::LLFloaterWorldMap()
179 mCompletingRegionName(""), 179 mCompletingRegionName(""),
180 mWaitingForTracker(FALSE), 180 mWaitingForTracker(FALSE),
181 mExactMatch(FALSE), 181 mExactMatch(FALSE),
182 mIsClosing(FALSE),
183 mSetToUserPosition(TRUE),
182 mTrackedLocation(0,0,0), 184 mTrackedLocation(0,0,0),
183 mTrackedStatus(LLTracker::TRACKING_NOTHING) 185 mTrackedStatus(LLTracker::TRACKING_NOTHING)
184{ 186{
@@ -355,6 +357,9 @@ void LLFloaterWorldMap::show(void*, BOOL center_on_target)
355 357
356 gFloaterWorldMap->buildAvatarIDList(); 358 gFloaterWorldMap->buildAvatarIDList();
357 gFloaterWorldMap->buildLandmarkIDLists(); 359 gFloaterWorldMap->buildLandmarkIDLists();
360
361 // If nothing is being tracked, set flag so the user position will be found
362 gFloaterWorldMap->mSetToUserPosition = ( LLTracker::getTrackingStatus() == LLTracker::TRACKING_NOTHING );
358 } 363 }
359 364
360 if (center_on_target) 365 if (center_on_target)
@@ -517,7 +522,7 @@ void LLFloaterWorldMap::draw()
517 childSetEnabled("Teleport", (BOOL)tracking_status); 522 childSetEnabled("Teleport", (BOOL)tracking_status);
518// childSetEnabled("Clear", (BOOL)tracking_status); 523// childSetEnabled("Clear", (BOOL)tracking_status);
519 childSetEnabled("Show Destination", (BOOL)tracking_status || gWorldMap->mIsTrackingUnknownLocation); 524 childSetEnabled("Show Destination", (BOOL)tracking_status || gWorldMap->mIsTrackingUnknownLocation);
520 childSetEnabled("copy_slurl", (BOOL)tracking_status); 525 childSetEnabled("copy_slurl", (mSLURL.size() > 0) );
521 526
522 setMouseOpaque(TRUE); 527 setMouseOpaque(TRUE);
523 mDragHandle->setMouseOpaque(TRUE); 528 mDragHandle->setMouseOpaque(TRUE);
@@ -661,7 +666,8 @@ void LLFloaterWorldMap::trackLocation(const LLVector3d& pos_global)
661 return; 666 return;
662 } 667 }
663 668
664 LLString sim_name = gWorldMap->simNameFromPosGlobal( pos_global ); 669 LLString sim_name;
670 gWorldMap->simNameFromPosGlobal( pos_global, sim_name );
665 F32 region_x = (F32)fmod( pos_global.mdV[VX], (F64)REGION_WIDTH_METERS ); 671 F32 region_x = (F32)fmod( pos_global.mdV[VX], (F64)REGION_WIDTH_METERS );
666 F32 region_y = (F32)fmod( pos_global.mdV[VY], (F64)REGION_WIDTH_METERS ); 672 F32 region_y = (F32)fmod( pos_global.mdV[VY], (F64)REGION_WIDTH_METERS );
667 LLString full_name = llformat("%s (%d, %d, %d)", 673 LLString full_name = llformat("%s (%d, %d, %d)",
@@ -682,15 +688,51 @@ void LLFloaterWorldMap::trackLocation(const LLVector3d& pos_global)
682 688
683void LLFloaterWorldMap::updateLocation() 689void LLFloaterWorldMap::updateLocation()
684{ 690{
691 bool gotSimName;
692
693 LLTracker::ETrackingStatus status = LLTracker::getTrackingStatus();
694
685 // These values may get updated by a message, so need to check them every frame 695 // These values may get updated by a message, so need to check them every frame
686 // The fields may be changed by the user, so only update them if the data changes 696 // The fields may be changed by the user, so only update them if the data changes
687 LLVector3d pos_global = LLTracker::getTrackedPositionGlobal(); 697 LLVector3d pos_global = LLTracker::getTrackedPositionGlobal();
688 if (pos_global.isExactlyZero()) 698 if (pos_global.isExactlyZero())
689 { 699 {
700 LLVector3d agentPos = gAgent.getPositionGlobal();
701
702 // Set to avatar's current postion if nothing is selected
703 if ( status == LLTracker::TRACKING_NOTHING && mSetToUserPosition )
704 {
705 // Make sure we know where we are before setting the current user position
706 LLString agent_sim_name;
707 gotSimName = gWorldMap->simNameFromPosGlobal( agentPos, agent_sim_name );
708 if ( gotSimName )
709 {
710 mSetToUserPosition = FALSE;
711
712 // Fill out the location field
713 childSetValue("location", agent_sim_name);
714
715 // Figure out where user is
716 LLVector3d agentPos = gAgent.getPositionGlobal();
717
718 S32 agent_x = llround( (F32)fmod( agentPos.mdV[VX], (F64)REGION_WIDTH_METERS ) );
719 S32 agent_y = llround( (F32)fmod( agentPos.mdV[VY], (F64)REGION_WIDTH_METERS ) );
720 S32 agent_z = llround( (F32)agentPos.mdV[VZ] );
721
722 childSetValue("spin x", LLSD(agent_x) );
723 childSetValue("spin y", LLSD(agent_y) );
724 childSetValue("spin z", LLSD(agent_z) );
725
726 // Set the current SLURL
727 mSLURL = LLWeb::escapeURL( llformat("http://slurl.com/secondlife/%s/%d/%d/%d",
728 agent_sim_name.c_str(), agent_x, agent_y, agent_z) );
729 }
730 }
731
690 return; // invalid location 732 return; // invalid location
691 } 733 }
692 LLTracker::ETrackingStatus status = LLTracker::getTrackingStatus(); 734 LLString sim_name;
693 LLString sim_name = gWorldMap->simNameFromPosGlobal( pos_global ); 735 gotSimName = gWorldMap->simNameFromPosGlobal( pos_global, sim_name );
694 if ((status != LLTracker::TRACKING_NOTHING) && 736 if ((status != LLTracker::TRACKING_NOTHING) &&
695 (status != mTrackedStatus || pos_global != mTrackedLocation || sim_name != mTrackedSimName)) 737 (status != mTrackedStatus || pos_global != mTrackedLocation || sim_name != mTrackedSimName))
696 { 738 {
@@ -717,8 +759,16 @@ void LLFloaterWorldMap::updateLocation()
717 childSetValue("spin y", LLSD(region_y) ); 759 childSetValue("spin y", LLSD(region_y) );
718 childSetValue("spin z", LLSD((F32)pos_global.mdV[VZ]) ); 760 childSetValue("spin z", LLSD((F32)pos_global.mdV[VZ]) );
719 761
720 mSLURL = LLWeb::escapeURL(llformat("http://slurl.com/secondlife/%s/%d/%d/%d", 762 // simNameFromPosGlobal can fail, so don't give the user an invalid SLURL
721 sim_name.c_str(), llround(region_x), llround(region_y), llround((F32)pos_global.mdV[VZ]))); 763 if ( gotSimName )
764 {
765 mSLURL = LLWeb::escapeURL(llformat("http://slurl.com/secondlife/%s/%d/%d/%d",
766 sim_name.c_str(), llround(region_x), llround(region_y), llround((F32)pos_global.mdV[VZ])));
767 }
768 else
769 { // Empty SLURL will disable the "Copy SLURL to clipboard" button
770 mSLURL = "";
771 }
722 } 772 }
723} 773}
724 774
@@ -1102,6 +1152,9 @@ void LLFloaterWorldMap::onLandmarkComboCommit( LLUICtrl* ctrl, void* userdata )
1102 1152
1103 self->trackLandmark( item_id); 1153 self->trackLandmark( item_id);
1104 onShowTargetBtn(self); 1154 onShowTargetBtn(self);
1155
1156 // Reset to user postion if nothing is tracked
1157 self->mSetToUserPosition = ( LLTracker::getTrackingStatus() == LLTracker::TRACKING_NOTHING );
1105} 1158}
1106 1159
1107// static 1160// static
@@ -1153,6 +1206,10 @@ void LLFloaterWorldMap::onAvatarComboCommit( LLUICtrl* ctrl, void* userdata )
1153 self->trackAvatar(new_avatar_id, name); 1206 self->trackAvatar(new_avatar_id, name);
1154 onShowTargetBtn(self); 1207 onShowTargetBtn(self);
1155 } 1208 }
1209 else
1210 { // Reset to user postion if nothing is tracked
1211 self->mSetToUserPosition = ( LLTracker::getTrackingStatus() == LLTracker::TRACKING_NOTHING );
1212 }
1156} 1213}
1157 1214
1158// static 1215// static
@@ -1208,6 +1265,8 @@ void LLFloaterWorldMap::onClearBtn(void* data)
1208 self->mTrackedStatus = LLTracker::TRACKING_NOTHING; 1265 self->mTrackedStatus = LLTracker::TRACKING_NOTHING;
1209 LLTracker::stopTracking((void *)(intptr_t)TRUE); 1266 LLTracker::stopTracking((void *)(intptr_t)TRUE);
1210 gWorldMap->mIsTrackingUnknownLocation = FALSE; 1267 gWorldMap->mIsTrackingUnknownLocation = FALSE;
1268 self->mSLURL = ""; // Clear the SLURL since it's invalid
1269 self->mSetToUserPosition = TRUE; // Revert back to the current user position
1211} 1270}
1212 1271
1213// static 1272// static
@@ -1226,6 +1285,10 @@ void LLFloaterWorldMap::onShowTargetBtn(void* data)
1226void LLFloaterWorldMap::onShowAgentBtn(void* data) 1285void LLFloaterWorldMap::onShowAgentBtn(void* data)
1227{ 1286{
1228 LLWorldMapView::setPan( 0, 0, FALSE); // FALSE == animate 1287 LLWorldMapView::setPan( 0, 0, FALSE); // FALSE == animate
1288
1289 // Set flag so user's location will be displayed if not tracking anything else
1290 LLFloaterWorldMap* self = (LLFloaterWorldMap*)data;
1291 self->mSetToUserPosition = TRUE;
1229} 1292}
1230 1293
1231// static 1294// static