diff options
Diffstat (limited to 'linden/indra/newview/llnetmap.cpp')
-rw-r--r-- | linden/indra/newview/llnetmap.cpp | 91 |
1 files changed, 29 insertions, 62 deletions
diff --git a/linden/indra/newview/llnetmap.cpp b/linden/indra/newview/llnetmap.cpp index 01400b1..9226fac 100644 --- a/linden/indra/newview/llnetmap.cpp +++ b/linden/indra/newview/llnetmap.cpp | |||
@@ -103,15 +103,20 @@ LLNetMap::LLNetMap( | |||
103 | 103 | ||
104 | mObjectImageCenterGlobal = gAgent.getCameraPositionGlobal(); | 104 | mObjectImageCenterGlobal = gAgent.getCameraPositionGlobal(); |
105 | 105 | ||
106 | // TODO: exteralize hardcoded constants. | ||
106 | const S32 DIR_WIDTH = 10; | 107 | const S32 DIR_WIDTH = 10; |
107 | const S32 DIR_HEIGHT = 10; | 108 | const S32 DIR_HEIGHT = 10; |
108 | LLRect major_dir_rect( 0, DIR_HEIGHT, DIR_WIDTH, 0 ); | 109 | LLRect major_dir_rect( 0, DIR_HEIGHT, DIR_WIDTH, 0 ); |
109 | 110 | const LLColor4 minor_color( 1.f, 1.f, 1.f, .7f ); | |
110 | mTextBoxNorth = new LLTextBox( "N", major_dir_rect ); | 111 | const LLRect minor_dir_rect( 0, DIR_HEIGHT, DIR_WIDTH * 2, 0 ); |
111 | mTextBoxNorth->setFontStyle(LLFontGL::DROP_SHADOW_SOFT); | 112 | |
113 | // Note: removing special treatment for north compass point (DEV-10559). -MG | ||
114 | //mTextBoxNorth = new LLTextBox( "N", major_dir_rect ); | ||
115 | //mTextBoxNorth->setFontStyle(LLFontGL::DROP_SHADOW_SOFT); | ||
116 | //addChild( mTextBoxNorth ); | ||
117 | mTextBoxNorth = new LLTextBox( "N", major_dir_rect ); | ||
118 | mTextBoxNorth->setColor( minor_color ); | ||
112 | addChild( mTextBoxNorth ); | 119 | addChild( mTextBoxNorth ); |
113 | |||
114 | LLColor4 minor_color( 1.f, 1.f, 1.f, .7f ); | ||
115 | 120 | ||
116 | mTextBoxEast = new LLTextBox( "E", major_dir_rect ); | 121 | mTextBoxEast = new LLTextBox( "E", major_dir_rect ); |
117 | mTextBoxEast->setColor( minor_color ); | 122 | mTextBoxEast->setColor( minor_color ); |
@@ -127,8 +132,6 @@ LLNetMap::LLNetMap( | |||
127 | mTextBoxSouth->setColor( minor_color ); | 132 | mTextBoxSouth->setColor( minor_color ); |
128 | addChild( mTextBoxSouth ); | 133 | addChild( mTextBoxSouth ); |
129 | 134 | ||
130 | LLRect minor_dir_rect( 0, DIR_HEIGHT, DIR_WIDTH * 2, 0 ); | ||
131 | |||
132 | mTextBoxSouthEast = new LLTextBox( "SE", minor_dir_rect ); | 135 | mTextBoxSouthEast = new LLTextBox( "SE", minor_dir_rect ); |
133 | mTextBoxSouthEast->setColor( minor_color ); | 136 | mTextBoxSouthEast->setColor( minor_color ); |
134 | addChild( mTextBoxSouthEast ); | 137 | addChild( mTextBoxSouthEast ); |
@@ -163,8 +166,6 @@ LLNetMap::LLNetMap( | |||
163 | mPopupMenuHandle = menu->getHandle(); | 166 | mPopupMenuHandle = menu->getHandle(); |
164 | 167 | ||
165 | sInstance = this; | 168 | sInstance = this; |
166 | |||
167 | gSavedSettings.getControl("MiniMapRotate")->addListener(&mNetMapListener); | ||
168 | } | 169 | } |
169 | 170 | ||
170 | LLNetMap::~LLNetMap() | 171 | LLNetMap::~LLNetMap() |
@@ -172,17 +173,6 @@ LLNetMap::~LLNetMap() | |||
172 | sInstance = NULL; | 173 | sInstance = NULL; |
173 | } | 174 | } |
174 | 175 | ||
175 | EWidgetType LLNetMap::getWidgetType() const | ||
176 | { | ||
177 | return WIDGET_TYPE_NET_MAP; | ||
178 | } | ||
179 | |||
180 | LLString LLNetMap::getWidgetTag() const | ||
181 | { | ||
182 | return LL_NET_MAP_TAG; | ||
183 | } | ||
184 | |||
185 | |||
186 | void LLNetMap::setScale( F32 scale ) | 176 | void LLNetMap::setScale( F32 scale ) |
187 | { | 177 | { |
188 | gMiniMapScale = scale; | 178 | gMiniMapScale = scale; |
@@ -196,20 +186,8 @@ void LLNetMap::setScale( F32 scale ) | |||
196 | F32 half_width = (F32)(getRect().getWidth() / 2); | 186 | F32 half_width = (F32)(getRect().getWidth() / 2); |
197 | F32 half_height = (F32)(getRect().getHeight() / 2); | 187 | F32 half_height = (F32)(getRect().getHeight() / 2); |
198 | F32 radius = sqrt( half_width * half_width + half_height * half_height ); | 188 | F32 radius = sqrt( half_width * half_width + half_height * half_height ); |
199 | |||
200 | F32 region_widths = (2.f*radius)/gMiniMapScale; | 189 | F32 region_widths = (2.f*radius)/gMiniMapScale; |
201 | 190 | F32 meters = region_widths * LLWorld::getInstance()->getRegionWidthInMeters(); | |
202 | F32 meters; | ||
203 | if (!gWorldPointer) | ||
204 | { | ||
205 | // Hack! Sometimes world hasn't been initialized at this point. | ||
206 | meters = 256.f*region_widths; | ||
207 | } | ||
208 | else | ||
209 | { | ||
210 | meters = region_widths * gWorldPointer->getRegionWidthInMeters(); | ||
211 | } | ||
212 | |||
213 | F32 num_pixels = (F32)mObjectImagep->getWidth(); | 191 | F32 num_pixels = (F32)mObjectImagep->getWidth(); |
214 | mObjectMapTPM = num_pixels/meters; | 192 | mObjectMapTPM = num_pixels/meters; |
215 | mObjectMapPixels = 2.f*radius; | 193 | mObjectMapPixels = 2.f*radius; |
@@ -233,10 +211,6 @@ void LLNetMap::draw() | |||
233 | { | 211 | { |
234 | static LLFrameTimer map_timer; | 212 | static LLFrameTimer map_timer; |
235 | 213 | ||
236 | if (!getVisible() || !gWorldPointer) | ||
237 | { | ||
238 | return; | ||
239 | } | ||
240 | if (mObjectImagep.isNull()) | 214 | if (mObjectImagep.isNull()) |
241 | { | 215 | { |
242 | createObjectImage(); | 216 | createObjectImage(); |
@@ -273,15 +247,15 @@ void LLNetMap::draw() | |||
273 | if( LLNetMap::sRotateMap ) | 247 | if( LLNetMap::sRotateMap ) |
274 | { | 248 | { |
275 | // rotate subsequent draws to agent rotation | 249 | // rotate subsequent draws to agent rotation |
276 | rotation = atan2( gCamera->getAtAxis().mV[VX], gCamera->getAtAxis().mV[VY] ); | 250 | rotation = atan2( LLViewerCamera::getInstance()->getAtAxis().mV[VX], LLViewerCamera::getInstance()->getAtAxis().mV[VY] ); |
277 | glRotatef( rotation * RAD_TO_DEG, 0.f, 0.f, 1.f); | 251 | glRotatef( rotation * RAD_TO_DEG, 0.f, 0.f, 1.f); |
278 | } | 252 | } |
279 | 253 | ||
280 | // figure out where agent is | 254 | // figure out where agent is |
281 | S32 region_width = llround(gWorldPointer->getRegionWidthInMeters()); | 255 | S32 region_width = llround(LLWorld::getInstance()->getRegionWidthInMeters()); |
282 | 256 | ||
283 | for (LLWorld::region_list_t::iterator iter = gWorldp->mActiveRegionList.begin(); | 257 | for (LLWorld::region_list_t::iterator iter = LLWorld::getInstance()->mActiveRegionList.begin(); |
284 | iter != gWorldp->mActiveRegionList.end(); ++iter) | 258 | iter != LLWorld::getInstance()->mActiveRegionList.end(); ++iter) |
285 | { | 259 | { |
286 | LLViewerRegion* regionp = *iter; | 260 | LLViewerRegion* regionp = *iter; |
287 | // Find x and y position relative to camera's center. | 261 | // Find x and y position relative to camera's center. |
@@ -397,8 +371,8 @@ void LLNetMap::draw() | |||
397 | LLVector3 pos_map; | 371 | LLVector3 pos_map; |
398 | 372 | ||
399 | // Draw avatars | 373 | // Draw avatars |
400 | for (LLWorld::region_list_t::iterator iter = gWorldp->mActiveRegionList.begin(); | 374 | for (LLWorld::region_list_t::iterator iter = LLWorld::getInstance()->mActiveRegionList.begin(); |
401 | iter != gWorldp->mActiveRegionList.end(); ++iter) | 375 | iter != LLWorld::getInstance()->mActiveRegionList.end(); ++iter) |
402 | { | 376 | { |
403 | LLViewerRegion* regionp = *iter; | 377 | LLViewerRegion* regionp = *iter; |
404 | const LLVector3d& origin_global = regionp->getOriginGlobal(); | 378 | const LLVector3d& origin_global = regionp->getOriginGlobal(); |
@@ -462,19 +436,18 @@ void LLNetMap::draw() | |||
462 | } | 436 | } |
463 | 437 | ||
464 | // Draw dot for self avatar position | 438 | // Draw dot for self avatar position |
465 | //drawTracking( gAgent.getPosGlobalFromAgent(gAgent.getFrameAgent().getCenter()), gSelfMapColor ); | ||
466 | pos_global = gAgent.getPositionGlobal(); | 439 | pos_global = gAgent.getPositionGlobal(); |
467 | pos_map = globalPosToView(pos_global); | 440 | pos_map = globalPosToView(pos_global); |
468 | gl_draw_image(llround(pos_map.mV[VX]) - 4, | 441 | LLUIImagePtr you = LLWorldMapView::sAvatarYouSmallImage; |
469 | llround(pos_map.mV[VY]) - 4, | 442 | you->draw( |
470 | LLWorldMapView::sAvatarYouSmallImage, | 443 | llround(pos_map.mV[VX]) - you->getWidth()/2, |
471 | LLColor4::white); | 444 | llround(pos_map.mV[VY]) - you->getHeight()/2); |
472 | 445 | ||
473 | // Draw frustum | 446 | // Draw frustum |
474 | F32 meters_to_pixels = gMiniMapScale/ gWorldPointer->getRegionWidthInMeters(); | 447 | F32 meters_to_pixels = gMiniMapScale/ LLWorld::getInstance()->getRegionWidthInMeters(); |
475 | 448 | ||
476 | F32 horiz_fov = gCamera->getView() * gCamera->getAspect(); | 449 | F32 horiz_fov = LLViewerCamera::getInstance()->getView() * LLViewerCamera::getInstance()->getAspect(); |
477 | F32 far_clip_meters = gCamera->getFar(); | 450 | F32 far_clip_meters = LLViewerCamera::getInstance()->getFar(); |
478 | F32 far_clip_pixels = far_clip_meters * meters_to_pixels; | 451 | F32 far_clip_pixels = far_clip_meters * meters_to_pixels; |
479 | 452 | ||
480 | F32 half_width_meters = far_clip_meters * tan( horiz_fov / 2 ); | 453 | F32 half_width_meters = far_clip_meters * tan( horiz_fov / 2 ); |
@@ -503,7 +476,7 @@ void LLNetMap::draw() | |||
503 | // If we don't rotate the map, we have to rotate the frustum. | 476 | // If we don't rotate the map, we have to rotate the frustum. |
504 | gGL.pushMatrix(); | 477 | gGL.pushMatrix(); |
505 | gGL.translatef( ctr_x, ctr_y, 0 ); | 478 | gGL.translatef( ctr_x, ctr_y, 0 ); |
506 | glRotatef( atan2( gCamera->getAtAxis().mV[VX], gCamera->getAtAxis().mV[VY] ) * RAD_TO_DEG, 0.f, 0.f, -1.f); | 479 | glRotatef( atan2( LLViewerCamera::getInstance()->getAtAxis().mV[VX], LLViewerCamera::getInstance()->getAtAxis().mV[VY] ) * RAD_TO_DEG, 0.f, 0.f, -1.f); |
507 | gGL.begin( GL_TRIANGLES ); | 480 | gGL.begin( GL_TRIANGLES ); |
508 | gGL.vertex2f( 0, 0 ); | 481 | gGL.vertex2f( 0, 0 ); |
509 | gGL.vertex2f( -half_width_pixels, far_clip_pixels ); | 482 | gGL.vertex2f( -half_width_pixels, far_clip_pixels ); |
@@ -539,7 +512,7 @@ LLVector3 LLNetMap::globalPosToView( const LLVector3d& global_pos ) | |||
539 | 512 | ||
540 | if( LLNetMap::sRotateMap ) | 513 | if( LLNetMap::sRotateMap ) |
541 | { | 514 | { |
542 | F32 radians = atan2( gCamera->getAtAxis().mV[VX], gCamera->getAtAxis().mV[VY] ); | 515 | F32 radians = atan2( LLViewerCamera::getInstance()->getAtAxis().mV[VX], LLViewerCamera::getInstance()->getAtAxis().mV[VY] ); |
543 | LLQuaternion rot(radians, LLVector3(0.f, 0.f, 1.f)); | 516 | LLQuaternion rot(radians, LLVector3(0.f, 0.f, 1.f)); |
544 | pos_local.rotVec( rot ); | 517 | pos_local.rotVec( rot ); |
545 | } | 518 | } |
@@ -583,7 +556,7 @@ LLVector3d LLNetMap::viewPosToGlobal( S32 x, S32 y ) | |||
583 | 556 | ||
584 | LLVector3 pos_local( (F32)x, (F32)y, 0 ); | 557 | LLVector3 pos_local( (F32)x, (F32)y, 0 ); |
585 | 558 | ||
586 | F32 radians = - atan2( gCamera->getAtAxis().mV[VX], gCamera->getAtAxis().mV[VY] ); | 559 | F32 radians = - atan2( LLViewerCamera::getInstance()->getAtAxis().mV[VX], LLViewerCamera::getInstance()->getAtAxis().mV[VY] ); |
587 | 560 | ||
588 | if( LLNetMap::sRotateMap ) | 561 | if( LLNetMap::sRotateMap ) |
589 | { | 562 | { |
@@ -591,7 +564,7 @@ LLVector3d LLNetMap::viewPosToGlobal( S32 x, S32 y ) | |||
591 | pos_local.rotVec( rot ); | 564 | pos_local.rotVec( rot ); |
592 | } | 565 | } |
593 | 566 | ||
594 | pos_local *= ( gWorldPointer->getRegionWidthInMeters() / gMiniMapScale ); | 567 | pos_local *= ( LLWorld::getInstance()->getRegionWidthInMeters() / gMiniMapScale ); |
595 | 568 | ||
596 | LLVector3d pos_global; | 569 | LLVector3d pos_global; |
597 | pos_global.setVec( pos_local ); | 570 | pos_global.setVec( pos_local ); |
@@ -614,7 +587,7 @@ BOOL LLNetMap::handleToolTip( S32 x, S32 y, LLString& msg, LLRect* sticky_rect_s | |||
614 | { | 587 | { |
615 | return FALSE; | 588 | return FALSE; |
616 | } | 589 | } |
617 | LLViewerRegion* region = gWorldPointer->getRegionFromPosGlobal( viewPosToGlobal( x, y ) ); | 590 | LLViewerRegion* region = LLWorld::getInstance()->getRegionFromPosGlobal( viewPosToGlobal( x, y ) ); |
618 | if( region ) | 591 | if( region ) |
619 | { | 592 | { |
620 | msg.assign( region->getName() ); | 593 | msg.assign( region->getName() ); |
@@ -828,9 +801,3 @@ void LLNetMap::handleZoomLevel(void* which) | |||
828 | break; | 801 | break; |
829 | } | 802 | } |
830 | } | 803 | } |
831 | |||
832 | bool LLRotateNetMapListener::handleEvent(LLPointer<LLEvent> event, const LLSD& user_data) | ||
833 | { | ||
834 | LLNetMap::setRotateMap(event->getValue().asBoolean()); | ||
835 | return true; | ||
836 | } | ||