diff options
21 files changed, 366 insertions, 450 deletions
diff --git a/ChangeLog.txt b/ChangeLog.txt index cc2de88..8566125 100644 --- a/ChangeLog.txt +++ b/ChangeLog.txt | |||
@@ -1,3 +1,29 @@ | |||
1 | 2009-06-09 McCabe Maxsted <hakushakukun@gmail.com> | ||
2 | |||
3 | * Backported 1.23's minimap conversion to XUI. | ||
4 | |||
5 | modified: indra/llui/llui.cpp | ||
6 | modified: indra/llui/llui.h | ||
7 | modified: indra/newview/CMakeLists.txt | ||
8 | modified: indra/newview/llagent.cpp | ||
9 | modified: indra/newview/llcolorscheme.cpp | ||
10 | modified: indra/newview/llcolorscheme.h | ||
11 | modified: indra/newview/llfloatermap.cpp | ||
12 | modified: indra/newview/llfloatermap.h | ||
13 | modified: indra/newview/llmenucommands.cpp | ||
14 | modified: indra/newview/llnetmap.cpp | ||
15 | modified: indra/newview/llnetmap.h | ||
16 | modified: indra/newview/llstartup.cpp | ||
17 | modified: indra/newview/llviewercontrol.cpp | ||
18 | modified: indra/newview/llviewermenu.cpp | ||
19 | modified: indra/newview/llviewerobject.cpp | ||
20 | modified: indra/newview/llviewerregion.cpp | ||
21 | modified: indra/newview/llviewerwindow.cpp | ||
22 | modified: indra/newview/llworldmapview.cpp | ||
23 | modified: indra/newview/skins/default/colors_base.xml | ||
24 | modified: indra/newview/skins/silver/colors_base.xml | ||
25 | |||
26 | |||
1 | 2009-06-08 McCabe Maxsted <hakushakukun@gmail.com> | 27 | 2009-06-08 McCabe Maxsted <hakushakukun@gmail.com> |
2 | 28 | ||
3 | * Changed 'IM Received' button to '__ New IMs'. | 29 | * Changed 'IM Received' button to '__ New IMs'. |
diff --git a/linden/indra/llui/llui.cpp b/linden/indra/llui/llui.cpp index f3e73fd..8a7b80e 100644 --- a/linden/indra/llui/llui.cpp +++ b/linden/indra/llui/llui.cpp | |||
@@ -1645,6 +1645,18 @@ void LLUI::setCursorPositionLocal(const LLView* viewp, S32 x, S32 y) | |||
1645 | setCursorPositionScreen(screen_x, screen_y); | 1645 | setCursorPositionScreen(screen_x, screen_y); |
1646 | } | 1646 | } |
1647 | 1647 | ||
1648 | //static | ||
1649 | void LLUI::getCursorPositionLocal(const LLView* viewp, S32 *x, S32 *y) | ||
1650 | { | ||
1651 | LLCoordWindow cursor_pos_window; | ||
1652 | LLView::getWindow()->getCursorPosition(&cursor_pos_window); | ||
1653 | LLCoordGL cursor_pos_gl; | ||
1654 | LLView::getWindow()->convertCoords(cursor_pos_window, &cursor_pos_gl); | ||
1655 | cursor_pos_gl.mX = llround((F32)cursor_pos_gl.mX / LLUI::sGLScaleFactor.mV[VX]); | ||
1656 | cursor_pos_gl.mY = llround((F32)cursor_pos_gl.mY / LLUI::sGLScaleFactor.mV[VY]); | ||
1657 | viewp->screenPointToLocal(cursor_pos_gl.mX, cursor_pos_gl.mY, x, y); | ||
1658 | } | ||
1659 | |||
1648 | // On Windows, the user typically sets the language when they install the | 1660 | // On Windows, the user typically sets the language when they install the |
1649 | // app (by running it with a shortcut that sets InstallLanguage). On Mac, | 1661 | // app (by running it with a shortcut that sets InstallLanguage). On Mac, |
1650 | // or on Windows if the SecondLife.exe executable is run directly, the | 1662 | // or on Windows if the SecondLife.exe executable is run directly, the |
diff --git a/linden/indra/llui/llui.h b/linden/indra/llui/llui.h index 1e731f1..b51b132 100644 --- a/linden/indra/llui/llui.h +++ b/linden/indra/llui/llui.h | |||
@@ -175,6 +175,7 @@ public: | |||
175 | static std::string locateSkin(const std::string& filename); | 175 | static std::string locateSkin(const std::string& filename); |
176 | static void setCursorPositionScreen(S32 x, S32 y); | 176 | static void setCursorPositionScreen(S32 x, S32 y); |
177 | static void setCursorPositionLocal(const LLView* viewp, S32 x, S32 y); | 177 | static void setCursorPositionLocal(const LLView* viewp, S32 x, S32 y); |
178 | static void getCursorPositionLocal(const LLView* viewp, S32 *x, S32 *y); | ||
178 | static void setScaleFactor(const LLVector2& scale_factor); | 179 | static void setScaleFactor(const LLVector2& scale_factor); |
179 | static void setLineWidth(F32 width); | 180 | static void setLineWidth(F32 width); |
180 | static LLUIImage* getUIImage(const std::string& name); | 181 | static LLUIImage* getUIImage(const std::string& name); |
diff --git a/linden/indra/newview/CMakeLists.txt b/linden/indra/newview/CMakeLists.txt index 93c6e5f..34aa29f 100644 --- a/linden/indra/newview/CMakeLists.txt +++ b/linden/indra/newview/CMakeLists.txt | |||
@@ -1070,6 +1070,7 @@ set(viewer_XUI_FILES | |||
1070 | skins/default/xui/en-us/floater_live_lsleditor.xml | 1070 | skins/default/xui/en-us/floater_live_lsleditor.xml |
1071 | skins/default/xui/en-us/floater_lsl_guide.xml | 1071 | skins/default/xui/en-us/floater_lsl_guide.xml |
1072 | skins/default/xui/en-us/floater_media_browser.xml | 1072 | skins/default/xui/en-us/floater_media_browser.xml |
1073 | skins/default/xui/en-us/floater_mini_map.xml | ||
1073 | skins/default/xui/en-us/floater_moveview.xml | 1074 | skins/default/xui/en-us/floater_moveview.xml |
1074 | skins/default/xui/en-us/floater_mute_object.xml | 1075 | skins/default/xui/en-us/floater_mute_object.xml |
1075 | skins/default/xui/en-us/floater_mute.xml | 1076 | skins/default/xui/en-us/floater_mute.xml |
@@ -1125,6 +1126,7 @@ set(viewer_XUI_FILES | |||
1125 | skins/default/xui/en-us/floater_world_map.xml | 1126 | skins/default/xui/en-us/floater_world_map.xml |
1126 | skins/default/xui/en-us/menu_inventory.xml | 1127 | skins/default/xui/en-us/menu_inventory.xml |
1127 | skins/default/xui/en-us/menu_login.xml | 1128 | skins/default/xui/en-us/menu_login.xml |
1129 | skins/default/xui/en-us/menu_mini_map.xml | ||
1128 | skins/default/xui/en-us/menu_pie_attachment.xml | 1130 | skins/default/xui/en-us/menu_pie_attachment.xml |
1129 | skins/default/xui/en-us/menu_pie_avatar.xml | 1131 | skins/default/xui/en-us/menu_pie_avatar.xml |
1130 | skins/default/xui/en-us/menu_pie_hud.xml | 1132 | skins/default/xui/en-us/menu_pie_hud.xml |
@@ -1162,6 +1164,7 @@ set(viewer_XUI_FILES | |||
1162 | skins/default/xui/en-us/panel_media_controls.xml | 1164 | skins/default/xui/en-us/panel_media_controls.xml |
1163 | skins/default/xui/en-us/panel_media_remote_expanded.xml | 1165 | skins/default/xui/en-us/panel_media_remote_expanded.xml |
1164 | skins/default/xui/en-us/panel_media_remote.xml | 1166 | skins/default/xui/en-us/panel_media_remote.xml |
1167 | skins/default/xui/en-us/panel_mini_map.xml | ||
1165 | skins/default/xui/en-us/panel_overlaybar.xml | 1168 | skins/default/xui/en-us/panel_overlaybar.xml |
1166 | skins/default/xui/en-us/panel_place_small.xml | 1169 | skins/default/xui/en-us/panel_place_small.xml |
1167 | skins/default/xui/en-us/panel_place.xml | 1170 | skins/default/xui/en-us/panel_place.xml |
diff --git a/linden/indra/newview/llagent.cpp b/linden/indra/newview/llagent.cpp index 89ba09c..5f0a875 100644 --- a/linden/indra/newview/llagent.cpp +++ b/linden/indra/newview/llagent.cpp | |||
@@ -2816,7 +2816,7 @@ U8 LLAgent::getRenderState() | |||
2816 | static const LLFloaterView::skip_list_t& get_skip_list() | 2816 | static const LLFloaterView::skip_list_t& get_skip_list() |
2817 | { | 2817 | { |
2818 | static LLFloaterView::skip_list_t skip_list; | 2818 | static LLFloaterView::skip_list_t skip_list; |
2819 | skip_list.insert(gFloaterMap); | 2819 | skip_list.insert(LLFloaterMap::getInstance()); |
2820 | return skip_list; | 2820 | return skip_list; |
2821 | } | 2821 | } |
2822 | 2822 | ||
@@ -2894,7 +2894,7 @@ void LLAgent::endAnimationUpdateUI() | |||
2894 | // let the mini-map go visible again. JC | 2894 | // let the mini-map go visible again. JC |
2895 | if (!LLAppViewer::instance()->quitRequested()) | 2895 | if (!LLAppViewer::instance()->quitRequested()) |
2896 | { | 2896 | { |
2897 | gFloaterMap->popVisible(); | 2897 | LLFloaterMap::getInstance()->popVisible(); |
2898 | } | 2898 | } |
2899 | 2899 | ||
2900 | if( gMorphView ) | 2900 | if( gMorphView ) |
@@ -2991,7 +2991,7 @@ void LLAgent::endAnimationUpdateUI() | |||
2991 | { | 2991 | { |
2992 | LLToolMgr::getInstance()->setCurrentToolset(gFaceEditToolset); | 2992 | LLToolMgr::getInstance()->setCurrentToolset(gFaceEditToolset); |
2993 | 2993 | ||
2994 | gFloaterMap->pushVisible(FALSE); | 2994 | LLFloaterMap::getInstance()->pushVisible(FALSE); |
2995 | /* | 2995 | /* |
2996 | LLView *view; | 2996 | LLView *view; |
2997 | for (view = gFloaterView->getFirstChild(); view; view = gFloaterView->getNextChild()) | 2997 | for (view = gFloaterView->getFirstChild(); view; view = gFloaterView->getNextChild()) |
diff --git a/linden/indra/newview/llcolorscheme.cpp b/linden/indra/newview/llcolorscheme.cpp index 3b12acf..07c3e75 100644 --- a/linden/indra/newview/llcolorscheme.cpp +++ b/linden/indra/newview/llcolorscheme.cpp | |||
@@ -36,12 +36,9 @@ | |||
36 | #include "llviewercontrol.h" | 36 | #include "llviewercontrol.h" |
37 | 37 | ||
38 | LLColor4 gTrackColor; | 38 | LLColor4 gTrackColor; |
39 | LLColor4 gSelfMapColor; | ||
40 | LLColor4 gLandmarkMapColor; | 39 | LLColor4 gLandmarkMapColor; |
41 | LLColor4 gLocationMapColor; | 40 | LLColor4 gLocationMapColor; |
42 | LLColor4 gTelehubMapColor; | 41 | LLColor4 gTelehubMapColor; |
43 | LLColor4 gFrustumMapColor; | ||
44 | LLColor4 gRotatingFrustumMapColor; | ||
45 | LLColor4 gEventColor; | 42 | LLColor4 gEventColor; |
46 | LLColor4 gPopularColor; | 43 | LLColor4 gPopularColor; |
47 | LLColor4 gPickColor; | 44 | LLColor4 gPickColor; |
@@ -52,17 +49,9 @@ void init_colors() | |||
52 | { | 49 | { |
53 | gTrackColor = LLColor4::red; | 50 | gTrackColor = LLColor4::red; |
54 | gDisabledTrackColor.setVec( 0.5f, 0.f, 0.f, 1.f ); | 51 | gDisabledTrackColor.setVec( 0.5f, 0.f, 0.f, 1.f ); |
55 | |||
56 | gSelfMapColor = LLColor4::white; | ||
57 | |||
58 | // fleshy color | ||
59 | //gAvatarMapColor.setVec( 255.f/255.f, 223.f/255.f, 170.f/255.f, 1.f); | ||
60 | |||
61 | gLandmarkMapColor = LLColor4::red; | 52 | gLandmarkMapColor = LLColor4::red; |
62 | gLocationMapColor.setVec( 0.f, 0.72f, 1.f, 1.f); | 53 | gLocationMapColor.setVec( 0.f, 0.72f, 1.f, 1.f); |
63 | gTelehubMapColor.setVec( 0.9f, 0.9f, 0.f, 1.f); // dk yellow | 54 | gTelehubMapColor.setVec( 0.9f, 0.9f, 0.f, 1.f); // dk yellow |
64 | gFrustumMapColor.setVec( 1.f, 1.f, 1.f, 0.08f); | ||
65 | gRotatingFrustumMapColor.setVec(1.f, 1.f, 1.f, 0.2f); | ||
66 | gEventColor.setVec( 1.f, 0.5f, 1.f, 1.f ); | 55 | gEventColor.setVec( 1.f, 0.5f, 1.f, 1.f ); |
67 | gPopularColor.setVec( 1.f, 0.0f, 0.f, 1.f ); | 56 | gPopularColor.setVec( 1.f, 0.0f, 0.f, 1.f ); |
68 | gPickColor.setVec( 1.f, 0.0f, 0.f, 1.f ); | 57 | gPickColor.setVec( 1.f, 0.0f, 0.f, 1.f ); |
diff --git a/linden/indra/newview/llcolorscheme.h b/linden/indra/newview/llcolorscheme.h index 9660042..aef3880 100644 --- a/linden/indra/newview/llcolorscheme.h +++ b/linden/indra/newview/llcolorscheme.h | |||
@@ -35,12 +35,9 @@ | |||
35 | #include "v4color.h" | 35 | #include "v4color.h" |
36 | 36 | ||
37 | extern LLColor4 gTrackColor; | 37 | extern LLColor4 gTrackColor; |
38 | extern LLColor4 gSelfMapColor; | ||
39 | extern LLColor4 gLandmarkMapColor; | 38 | extern LLColor4 gLandmarkMapColor; |
40 | extern LLColor4 gLocationMapColor; | 39 | extern LLColor4 gLocationMapColor; |
41 | extern LLColor4 gTelehubMapColor; | 40 | extern LLColor4 gTelehubMapColor; |
42 | extern LLColor4 gFrustumMapColor; | ||
43 | extern LLColor4 gRotatingFrustumMapColor; | ||
44 | extern LLColor4 gEventColor; | 41 | extern LLColor4 gEventColor; |
45 | extern LLColor4 gPopularColor; | 42 | extern LLColor4 gPopularColor; |
46 | extern LLColor4 gPickColor; | 43 | extern LLColor4 gPickColor; |
diff --git a/linden/indra/newview/llfloatermap.cpp b/linden/indra/newview/llfloatermap.cpp index b1aa6c7..6115404 100644 --- a/linden/indra/newview/llfloatermap.cpp +++ b/linden/indra/newview/llfloatermap.cpp | |||
@@ -31,120 +31,43 @@ | |||
31 | 31 | ||
32 | #include "llviewerprecompiledheaders.h" | 32 | #include "llviewerprecompiledheaders.h" |
33 | 33 | ||
34 | // self include | ||
35 | #include "llfloatermap.h" | 34 | #include "llfloatermap.h" |
36 | 35 | ||
37 | // Library includes | ||
38 | #include "llfontgl.h" | ||
39 | #include "llinventory.h" | ||
40 | #include "message.h" | ||
41 | |||
42 | // Viewer includes | ||
43 | #include "llagent.h" | 36 | #include "llagent.h" |
44 | #include "llcolorscheme.h" | 37 | #include "llcolorscheme.h" |
45 | #include "llviewercontrol.h" | 38 | #include "llviewercontrol.h" |
46 | #include "lldraghandle.h" | 39 | #include "lldraghandle.h" |
47 | #include "lleconomy.h" | ||
48 | #include "llfloaterworldmap.h" | ||
49 | #include "llfocusmgr.h" | ||
50 | #include "llnetmap.h" | 40 | #include "llnetmap.h" |
51 | #include "llregionhandle.h" | 41 | #include "llregionhandle.h" |
52 | #include "llresizebar.h" | 42 | #include "llresizebar.h" |
53 | #include "llresizehandle.h" | 43 | #include "lluictrlfactory.h" |
54 | #include "llresmgr.h" | ||
55 | #include "llsky.h" | ||
56 | #include "llsliderctrl.h" | ||
57 | #include "llspinctrl.h" | ||
58 | #include "llstatgraph.h" | ||
59 | #include "llstatusbar.h" | ||
60 | //#include "lltextbox.h" | ||
61 | #include "llui.h" | ||
62 | #include "llviewermenu.h" | ||
63 | #include "llviewerparceloverlay.h" | ||
64 | #include "llviewerregion.h" | ||
65 | #include "llviewerstats.h" | ||
66 | #include "llurlsimstring.h" | ||
67 | |||
68 | #include "llglheaders.h" | ||
69 | |||
70 | // | ||
71 | // Constants | ||
72 | // | ||
73 | const S32 LEGEND_SIZE = 16; | ||
74 | |||
75 | const S32 HPAD = 4; | ||
76 | |||
77 | const S32 MAP_COMBOBOX_WIDTH = 128; | ||
78 | const S32 MAP_COMBOBOX_HEIGHT = 20; | ||
79 | const S32 GO_BTN_WIDTH = 20; | ||
80 | const S32 SLIDER_WIDTH = LEGEND_SIZE + MAP_COMBOBOX_WIDTH + HPAD + GO_BTN_WIDTH - HPAD; | ||
81 | const S32 SLIDER_HEIGHT = 16; | ||
82 | |||
83 | const S32 SIM_STAT_WIDTH = 8; | ||
84 | |||
85 | const S32 MAP_SCALE_MIN = 35; // in pixels per sim | ||
86 | const S32 MAP_SCALE_MAX = 180; // in pixels per sim | ||
87 | const S32 MAP_SCALE_INCREMENT = 5; | ||
88 | |||
89 | const S32 NETMAP_MIN_WIDTH = 128; | ||
90 | const S32 NETMAP_MIN_HEIGHT = 128; | ||
91 | |||
92 | const S32 FLOATERMAP_MIN_WIDTH = | ||
93 | SLIDER_WIDTH + | ||
94 | 2 * (HPAD + LLPANEL_BORDER_WIDTH); | ||
95 | |||
96 | const S32 MORE_BTN_VPAD = 2; | ||
97 | |||
98 | const S32 SPIN_VPAD = 4; | ||
99 | |||
100 | const S32 TRACKING_LABEL_HEIGHT = 16; | ||
101 | |||
102 | const S32 FLOATERMAP_MIN_HEIGHT_LARGE = 60; | ||
103 | |||
104 | // | ||
105 | // Globals | ||
106 | // | ||
107 | LLFloaterMap *gFloaterMap = NULL; | ||
108 | |||
109 | 44 | ||
45 | LLFloaterMap::LLFloaterMap(const LLSD& key) | ||
46 | : | ||
47 | LLFloater(std::string("minimap")), | ||
48 | mPanelMap(NULL) | ||
49 | { | ||
50 | LLCallbackMap::map_t factory_map; | ||
51 | factory_map["mini_mapview"] = LLCallbackMap(createPanelMiniMap, this); | ||
52 | LLUICtrlFactory::getInstance()->buildFloater(this, "floater_mini_map.xml", &factory_map, FALSE); | ||
53 | } | ||
110 | 54 | ||
111 | 55 | ||
112 | // | 56 | // static |
113 | // Member functions | 57 | void* LLFloaterMap::createPanelMiniMap(void* data) |
114 | // | 58 | { |
59 | LLFloaterMap* self = (LLFloaterMap*)data; | ||
60 | self->mPanelMap = new LLNetMap("Mapview"); | ||
61 | return self->mPanelMap; | ||
62 | } | ||
115 | 63 | ||
116 | LLFloaterMap::LLFloaterMap(const std::string& name) | 64 | BOOL LLFloaterMap::postBuild() |
117 | : | ||
118 | LLFloater(name, | ||
119 | std::string("FloaterMiniMapRect"), | ||
120 | LLStringUtil::null, | ||
121 | TRUE, | ||
122 | FLOATERMAP_MIN_WIDTH, | ||
123 | FLOATERMAP_MIN_HEIGHT_LARGE, | ||
124 | FALSE, | ||
125 | FALSE, | ||
126 | TRUE) // close button | ||
127 | { | 65 | { |
128 | const S32 LEFT = LLPANEL_BORDER_WIDTH; | 66 | // Send the drag handle to the back, but make sure close stays on top |
129 | const S32 TOP = getRect().getHeight(); | ||
130 | |||
131 | S32 y = 0; | ||
132 | |||
133 | // Map itself | ||
134 | LLRect map_rect( | ||
135 | LEFT, | ||
136 | TOP - LLPANEL_BORDER_WIDTH, | ||
137 | getRect().getWidth() - LLPANEL_BORDER_WIDTH, | ||
138 | y ); | ||
139 | LLColor4 bg_color = gColors.getColor( "NetMapBackgroundColor" ); | ||
140 | mMap = new LLNetMap("Net Map", map_rect, bg_color); | ||
141 | mMap->setFollowsAll(); | ||
142 | addChildAtEnd(mMap); | ||
143 | |||
144 | // Get the drag handle all the way in back | ||
145 | sendChildToBack(getDragHandle()); | 67 | sendChildToBack(getDragHandle()); |
146 | 68 | sendChildToFront(getChild<LLButton>("llfloater_close_btn")); | |
147 | setIsChrome(TRUE); | 69 | setIsChrome(TRUE); |
70 | return TRUE; | ||
148 | } | 71 | } |
149 | 72 | ||
150 | 73 | ||
@@ -154,11 +77,11 @@ LLFloaterMap::~LLFloaterMap() | |||
154 | 77 | ||
155 | 78 | ||
156 | // virtual | 79 | // virtual |
157 | void LLFloaterMap::setVisible(BOOL visible) | 80 | void LLFloaterMap::onOpen() |
158 | { | 81 | { |
159 | LLFloater::setVisible(visible); | 82 | gFloaterView->adjustToFitScreen(this, FALSE); |
160 | 83 | ||
161 | gSavedSettings.setBOOL("ShowMiniMap", visible); | 84 | gSavedSettings.setBOOL("ShowMiniMap", TRUE); |
162 | } | 85 | } |
163 | 86 | ||
164 | 87 | ||
@@ -188,7 +111,7 @@ void LLFloaterMap::draw() | |||
188 | setMouseOpaque(FALSE); | 111 | setMouseOpaque(FALSE); |
189 | getDragHandle()->setMouseOpaque(FALSE); | 112 | getDragHandle()->setMouseOpaque(FALSE); |
190 | 113 | ||
191 | drawChild(mMap); | 114 | drawChild(mPanelMap); |
192 | } | 115 | } |
193 | else | 116 | else |
194 | { | 117 | { |
@@ -199,18 +122,3 @@ void LLFloaterMap::draw() | |||
199 | } | 122 | } |
200 | } | 123 | } |
201 | 124 | ||
202 | // static | ||
203 | void LLFloaterMap::toggle(void*) | ||
204 | { | ||
205 | if( gFloaterMap ) | ||
206 | { | ||
207 | if (gFloaterMap->getVisible()) | ||
208 | { | ||
209 | gFloaterMap->close(); | ||
210 | } | ||
211 | else | ||
212 | { | ||
213 | gFloaterMap->open(); /* Flawfinder: ignore */ | ||
214 | } | ||
215 | } | ||
216 | } | ||
diff --git a/linden/indra/newview/llfloatermap.h b/linden/indra/newview/llfloatermap.h index 91226dd..dd1cba8 100644 --- a/linden/indra/newview/llfloatermap.h +++ b/linden/indra/newview/llfloatermap.h | |||
@@ -36,32 +36,26 @@ | |||
36 | 36 | ||
37 | class LLNetMap; | 37 | class LLNetMap; |
38 | 38 | ||
39 | // | 39 | class LLFloaterMap : |
40 | // Classes | 40 | public LLFloater, |
41 | // | 41 | public LLFloaterSingleton<LLFloaterMap> |
42 | class LLFloaterMap | ||
43 | : public LLFloater | ||
44 | { | 42 | { |
43 | friend class LLUISingleton<LLFloaterMap, VisibilityPolicy<LLFloater> >; | ||
45 | public: | 44 | public: |
46 | LLFloaterMap(const std::string& name); | ||
47 | virtual ~LLFloaterMap(); | 45 | virtual ~LLFloaterMap(); |
48 | 46 | ||
49 | static void toggle(void*); | 47 | static void* createPanelMiniMap(void* data); |
48 | |||
49 | BOOL postBuild(); | ||
50 | 50 | ||
51 | /*virtual*/ void setVisible(BOOL visible); | ||
52 | /*virtual*/ void draw(); | 51 | /*virtual*/ void draw(); |
52 | /*virtual*/ void onOpen(); | ||
53 | /*virtual*/ void onClose(bool app_quitting); | 53 | /*virtual*/ void onClose(bool app_quitting); |
54 | /*virtual*/ BOOL canClose(); | 54 | /*virtual*/ BOOL canClose(); |
55 | 55 | ||
56 | protected: | 56 | private: |
57 | LLNetMap* mMap; | 57 | LLFloaterMap(const LLSD& key = LLSD()); |
58 | LLNetMap* mPanelMap; | ||
58 | }; | 59 | }; |
59 | 60 | ||
60 | |||
61 | // | ||
62 | // Globals | ||
63 | // | ||
64 | |||
65 | extern LLFloaterMap *gFloaterMap; | ||
66 | |||
67 | #endif // LL_LLFLOATERMAP_H | 61 | #endif // LL_LLFLOATERMAP_H |
diff --git a/linden/indra/newview/llmenucommands.cpp b/linden/indra/newview/llmenucommands.cpp index 2275047..8c4a3b1 100644 --- a/linden/indra/newview/llmenucommands.cpp +++ b/linden/indra/newview/llmenucommands.cpp | |||
@@ -95,7 +95,7 @@ void handle_map(void*) | |||
95 | 95 | ||
96 | void handle_mini_map(void*) | 96 | void handle_mini_map(void*) |
97 | { | 97 | { |
98 | LLFloaterMap::toggle(NULL); | 98 | LLFloaterMap::toggleInstance(); |
99 | } | 99 | } |
100 | 100 | ||
101 | 101 | ||
diff --git a/linden/indra/newview/llnetmap.cpp b/linden/indra/newview/llnetmap.cpp index cedabf7..71eb35b 100644 --- a/linden/indra/newview/llnetmap.cpp +++ b/linden/indra/newview/llnetmap.cpp | |||
@@ -44,22 +44,20 @@ | |||
44 | #include "llcallingcard.h" | 44 | #include "llcallingcard.h" |
45 | #include "llcolorscheme.h" | 45 | #include "llcolorscheme.h" |
46 | #include "llviewercontrol.h" | 46 | #include "llviewercontrol.h" |
47 | #include "llfloateravatarinfo.h" | ||
47 | #include "llfloaterworldmap.h" | 48 | #include "llfloaterworldmap.h" |
48 | #include "llfloatermap.h" | ||
49 | #include "llframetimer.h" | 49 | #include "llframetimer.h" |
50 | #include "lltracker.h" | 50 | #include "lltracker.h" |
51 | #include "llmenugl.h" | 51 | #include "llmenugl.h" |
52 | #include "llstatgraph.h" | ||
53 | #include "llsurface.h" | 52 | #include "llsurface.h" |
54 | #include "lltextbox.h" | 53 | #include "lltextbox.h" |
54 | #include "lluictrlfactory.h" | ||
55 | #include "lluuid.h" | 55 | #include "lluuid.h" |
56 | #include "llviewercamera.h" | 56 | #include "llviewercamera.h" |
57 | #include "llviewerimage.h" | 57 | #include "llviewerimage.h" |
58 | #include "llviewerimagelist.h" | 58 | #include "llviewerimagelist.h" |
59 | #include "llviewermenu.h" | 59 | #include "llviewermenu.h" |
60 | #include "llviewerobjectlist.h" | 60 | #include "llviewerobjectlist.h" |
61 | #include "llviewermenu.h" | ||
62 | #include "llviewerparceloverlay.h" | ||
63 | #include "llviewerregion.h" | 61 | #include "llviewerregion.h" |
64 | #include "llviewerwindow.h" | 62 | #include "llviewerwindow.h" |
65 | #include "llvoavatar.h" | 63 | #include "llvoavatar.h" |
@@ -73,19 +71,14 @@ const F32 MAP_SCALE_MIN = 32; | |||
73 | const F32 MAP_SCALE_MID = 172; | 71 | const F32 MAP_SCALE_MID = 172; |
74 | const F32 MAP_SCALE_MAX = 512; | 72 | const F32 MAP_SCALE_MAX = 512; |
75 | const F32 MAP_SCALE_INCREMENT = 16; | 73 | const F32 MAP_SCALE_INCREMENT = 16; |
74 | const F32 MAP_MIN_PICK_DIST = 4; | ||
75 | const F32 MAP_MINOR_DIR_THRESHOLD = 0.08f; | ||
76 | 76 | ||
77 | const S32 TRACKING_RADIUS = 3; | 77 | const S32 TRACKING_RADIUS = 3; |
78 | 78 | ||
79 | //static | 79 | LLNetMap::LLNetMap(const std::string& name) : |
80 | BOOL LLNetMap::sRotateMap = FALSE; | 80 | LLPanel(name), |
81 | LLNetMap* LLNetMap::sInstance = NULL; | 81 | mScale(128.f), |
82 | |||
83 | LLNetMap::LLNetMap( | ||
84 | const std::string& name, | ||
85 | const LLRect& rect, | ||
86 | const LLColor4& bg_color ) | ||
87 | : | ||
88 | LLUICtrl(name, rect, FALSE, NULL, NULL), mBackgroundColor( bg_color ), | ||
89 | mObjectMapTPM(1.f), | 82 | mObjectMapTPM(1.f), |
90 | mObjectMapPixels(255.f), | 83 | mObjectMapPixels(255.f), |
91 | mTargetPanX( 0.f ), | 84 | mTargetPanX( 0.f ), |
@@ -94,109 +87,57 @@ LLNetMap::LLNetMap( | |||
94 | mCurPanY( 0.f ), | 87 | mCurPanY( 0.f ), |
95 | mUpdateNow( FALSE ) | 88 | mUpdateNow( FALSE ) |
96 | { | 89 | { |
97 | mPixelsPerMeter = gMiniMapScale / REGION_WIDTH_METERS; | 90 | mScale = gSavedSettings.getF32("MiniMapScale"); |
98 | 91 | mPixelsPerMeter = mScale / LLWorld::getInstance()->getRegionWidthInMeters(); | |
99 | LLNetMap::sRotateMap = gSavedSettings.getBOOL( "MiniMapRotate" ); | ||
100 | |||
101 | glyph_color_avatar = gColors.getColor("NetMapGlyphColorAvatar"); | ||
102 | glyph_color_friend = gColors.getColor("NetMapGlyphColorFriend"); | ||
103 | |||
104 | // Surface texture is dynamically generated/updated. | ||
105 | // createObjectImage(); | ||
106 | 92 | ||
107 | mObjectImageCenterGlobal = gAgent.getCameraPositionGlobal(); | 93 | mObjectImageCenterGlobal = gAgent.getCameraPositionGlobal(); |
108 | 94 | ||
109 | // TODO: exteralize hardcoded constants. | 95 | // Register event listeners for popup menu |
110 | const S32 DIR_WIDTH = 10; | 96 | (new LLScaleMap())->registerListener(this, "MiniMap.ZoomLevel"); |
111 | const S32 DIR_HEIGHT = 10; | 97 | (new LLStopTracking())->registerListener(this, "MiniMap.StopTracking"); |
112 | LLRect major_dir_rect( 0, DIR_HEIGHT, DIR_WIDTH, 0 ); | 98 | (new LLEnableTracking())->registerListener(this, "MiniMap.EnableTracking"); |
113 | const LLColor4 minor_color( 1.f, 1.f, 1.f, .7f ); | 99 | (new LLShowAgentProfile())->registerListener(this, "MiniMap.ShowProfile"); |
114 | const LLRect minor_dir_rect( 0, DIR_HEIGHT, DIR_WIDTH * 2, 0 ); | 100 | (new LLEnableProfile())->registerListener(this, "MiniMap.EnableProfile"); |
115 | 101 | ||
116 | // Note: removing special treatment for north compass point (DEV-10559). -MG | 102 | LLUICtrlFactory::getInstance()->buildPanel(this, "panel_mini_map.xml"); |
117 | //mTextBoxNorth = new LLTextBox( "N", major_dir_rect ); | 103 | |
118 | //mTextBoxNorth->setFontStyle(LLFontGL::DROP_SHADOW_SOFT); | 104 | updateMinorDirections(); |
119 | //addChild( mTextBoxNorth ); | 105 | |
120 | mTextBoxNorth = new LLTextBox( std::string("N"), major_dir_rect ); | 106 | LLMenuGL* menu = LLUICtrlFactory::getInstance()->buildMenu("menu_mini_map.xml", this); |
121 | mTextBoxNorth->setColor( minor_color ); | 107 | if (!menu) |
122 | addChild( mTextBoxNorth ); | 108 | { |
123 | 109 | menu = new LLMenuGL(LLStringUtil::null); | |
124 | mTextBoxEast = new LLTextBox( std::string("E"), major_dir_rect ); | 110 | } |
125 | mTextBoxEast->setColor( minor_color ); | ||
126 | addChild( mTextBoxEast ); | ||
127 | |||
128 | major_dir_rect.mRight += 1 ; | ||
129 | mTextBoxWest = new LLTextBox( std::string("W"), major_dir_rect ); | ||
130 | mTextBoxWest->setColor( minor_color ); | ||
131 | addChild( mTextBoxWest ); | ||
132 | major_dir_rect.mRight -= 1 ; | ||
133 | |||
134 | mTextBoxSouth = new LLTextBox( std::string("S"), major_dir_rect ); | ||
135 | mTextBoxSouth->setColor( minor_color ); | ||
136 | addChild( mTextBoxSouth ); | ||
137 | |||
138 | mTextBoxSouthEast = new LLTextBox( std::string("SE"), minor_dir_rect ); | ||
139 | mTextBoxSouthEast->setColor( minor_color ); | ||
140 | addChild( mTextBoxSouthEast ); | ||
141 | |||
142 | mTextBoxNorthEast = new LLTextBox( std::string("NE"), minor_dir_rect ); | ||
143 | mTextBoxNorthEast->setColor( minor_color ); | ||
144 | addChild( mTextBoxNorthEast ); | ||
145 | |||
146 | mTextBoxSouthWest = new LLTextBox( std::string("SW"), minor_dir_rect ); | ||
147 | mTextBoxSouthWest->setColor( minor_color ); | ||
148 | addChild( mTextBoxSouthWest ); | ||
149 | |||
150 | mTextBoxNorthWest = new LLTextBox( std::string("NW"), minor_dir_rect ); | ||
151 | mTextBoxNorthWest->setColor( minor_color ); | ||
152 | addChild( mTextBoxNorthWest ); | ||
153 | |||
154 | // Right-click menu | ||
155 | LLMenuGL* menu; | ||
156 | menu = new LLMenuGL(std::string("popup")); | ||
157 | menu->setCanTearOff(FALSE); | ||
158 | menu->append(new LLMenuItemCallGL(std::string("Zoom Close"), handleZoomLevel, | ||
159 | NULL, (void*)2) ); | ||
160 | menu->append(new LLMenuItemCallGL(std::string("Zoom Medium"), handleZoomLevel, | ||
161 | NULL, (void*)1) ); | ||
162 | menu->append(new LLMenuItemCallGL(std::string("Zoom Far"), handleZoomLevel, | ||
163 | NULL, (void*)0) ); | ||
164 | menu->appendSeparator(); | ||
165 | menu->append(new LLMenuItemCallGL(std::string("Stop Tracking"), &LLTracker::stopTracking, | ||
166 | &LLTracker::isTracking, NULL) ); | ||
167 | menu->setVisible(FALSE); | 111 | menu->setVisible(FALSE); |
168 | addChild(menu); | ||
169 | mPopupMenuHandle = menu->getHandle(); | 112 | mPopupMenuHandle = menu->getHandle(); |
170 | |||
171 | sInstance = this; | ||
172 | } | 113 | } |
173 | 114 | ||
174 | LLNetMap::~LLNetMap() | 115 | LLNetMap::~LLNetMap() |
175 | { | 116 | { |
176 | sInstance = NULL; | ||
177 | } | 117 | } |
178 | 118 | ||
179 | void LLNetMap::setScale( F32 scale ) | 119 | void LLNetMap::setScale( F32 scale ) |
180 | { | 120 | { |
181 | gMiniMapScale = scale; | 121 | mScale = scale; |
182 | if (gMiniMapScale == 0.f) | 122 | if (mScale == 0.f) |
183 | { | 123 | { |
184 | gMiniMapScale = 0.1f; | 124 | mScale = 0.1f; |
185 | } | 125 | } |
126 | gSavedSettings.setF32("MiniMapScale", mScale); | ||
186 | 127 | ||
187 | if (mObjectImagep.notNull()) | 128 | if (mObjectImagep.notNull()) |
188 | { | 129 | { |
189 | F32 half_width = (F32)(getRect().getWidth() / 2); | 130 | F32 width = (F32)(getRect().getWidth()); |
190 | F32 half_height = (F32)(getRect().getHeight() / 2); | 131 | F32 height = (F32)(getRect().getHeight()); |
191 | F32 radius = sqrt( half_width * half_width + half_height * half_height ); | 132 | F32 diameter = sqrt(width * width + height * height); |
192 | F32 region_widths = (2.f*radius)/gMiniMapScale; | 133 | F32 region_widths = diameter / mScale; |
193 | F32 meters = region_widths * LLWorld::getInstance()->getRegionWidthInMeters(); | 134 | F32 meters = region_widths * LLWorld::getInstance()->getRegionWidthInMeters(); |
194 | F32 num_pixels = (F32)mObjectImagep->getWidth(); | 135 | F32 num_pixels = (F32)mObjectImagep->getWidth(); |
195 | mObjectMapTPM = num_pixels/meters; | 136 | mObjectMapTPM = num_pixels / meters; |
196 | mObjectMapPixels = 2.f*radius; | 137 | mObjectMapPixels = diameter; |
197 | } | 138 | } |
198 | 139 | ||
199 | mPixelsPerMeter = gMiniMapScale / REGION_WIDTH_METERS; | 140 | mPixelsPerMeter = mScale / LLWorld::getInstance()->getRegionWidthInMeters(); |
200 | 141 | ||
201 | mUpdateNow = TRUE; | 142 | mUpdateNow = TRUE; |
202 | } | 143 | } |
@@ -218,16 +159,16 @@ void LLNetMap::draw() | |||
218 | { | 159 | { |
219 | createObjectImage(); | 160 | createObjectImage(); |
220 | } | 161 | } |
221 | 162 | ||
222 | mCurPanX = lerp(mCurPanX, mTargetPanX, LLCriticalDamp::getInterpolant(0.1f)); | 163 | mCurPanX = lerp(mCurPanX, mTargetPanX, LLCriticalDamp::getInterpolant(0.1f)); |
223 | mCurPanY = lerp(mCurPanY, mTargetPanY, LLCriticalDamp::getInterpolant(0.1f)); | 164 | mCurPanY = lerp(mCurPanY, mTargetPanY, LLCriticalDamp::getInterpolant(0.1f)); |
224 | 165 | ||
225 | // Prepare a scissor region | ||
226 | F32 rotation = 0; | 166 | F32 rotation = 0; |
227 | 167 | ||
168 | // Prepare a scissor region | ||
228 | { | 169 | { |
229 | LLGLEnable scissor(GL_SCISSOR_TEST); | 170 | LLGLEnable scissor(GL_SCISSOR_TEST); |
230 | 171 | ||
231 | { | 172 | { |
232 | gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE); | 173 | gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE); |
233 | LLLocalClipRect clip(getLocalRect()); | 174 | LLLocalClipRect clip(getLocalRect()); |
@@ -235,8 +176,11 @@ void LLNetMap::draw() | |||
235 | glMatrixMode(GL_MODELVIEW); | 176 | glMatrixMode(GL_MODELVIEW); |
236 | 177 | ||
237 | // Draw background rectangle | 178 | // Draw background rectangle |
238 | gGL.color4fv( mBackgroundColor.mV ); | 179 | if(isBackgroundVisible()) |
239 | gl_rect_2d(0, getRect().getHeight(), getRect().getWidth(), 0); | 180 | { |
181 | gGL.color4fv(isBackgroundOpaque() ? getBackgroundColor().mV : getTransparentColor().mV); | ||
182 | gl_rect_2d(0, getRect().getHeight(), getRect().getWidth(), 0); | ||
183 | } | ||
240 | } | 184 | } |
241 | 185 | ||
242 | // region 0,0 is in the middle | 186 | // region 0,0 is in the middle |
@@ -247,7 +191,8 @@ void LLNetMap::draw() | |||
247 | 191 | ||
248 | gGL.translatef( (F32) center_sw_left, (F32) center_sw_bottom, 0.f); | 192 | gGL.translatef( (F32) center_sw_left, (F32) center_sw_bottom, 0.f); |
249 | 193 | ||
250 | if( LLNetMap::sRotateMap ) | 194 | BOOL rotate_map = gSavedSettings.getBOOL( "MiniMapRotate" ); |
195 | if( rotate_map ) | ||
251 | { | 196 | { |
252 | // rotate subsequent draws to agent rotation | 197 | // rotate subsequent draws to agent rotation |
253 | rotation = atan2( LLViewerCamera::getInstance()->getAtAxis().mV[VX], LLViewerCamera::getInstance()->getAtAxis().mV[VY] ); | 198 | rotation = atan2( LLViewerCamera::getInstance()->getAtAxis().mV[VX], LLViewerCamera::getInstance()->getAtAxis().mV[VY] ); |
@@ -256,35 +201,30 @@ void LLNetMap::draw() | |||
256 | 201 | ||
257 | // figure out where agent is | 202 | // figure out where agent is |
258 | S32 region_width = llround(LLWorld::getInstance()->getRegionWidthInMeters()); | 203 | S32 region_width = llround(LLWorld::getInstance()->getRegionWidthInMeters()); |
204 | LLColor4 this_region_color = gColors.getColor( "NetMapThisRegion" ); | ||
205 | LLColor4 live_region_color = gColors.getColor( "NetMapLiveRegion" ); | ||
206 | LLColor4 dead_region_color = gColors.getColor( "NetMapDeadRegion" ); | ||
259 | 207 | ||
260 | for (LLWorld::region_list_t::const_iterator iter = LLWorld::getInstance()->getRegionList().begin(); | 208 | for (LLWorld::region_list_t::const_iterator iter = LLWorld::getInstance()->getRegionList().begin(); |
261 | iter != LLWorld::getInstance()->getRegionList().end(); ++iter) | 209 | iter != LLWorld::getInstance()->getRegionList().end(); ++iter) |
262 | { | 210 | { |
263 | LLViewerRegion* regionp = *iter; | 211 | LLViewerRegion* regionp = *iter; |
264 | // Find x and y position relative to camera's center. | 212 | // Find x and y position relative to camera's center. |
265 | LLVector3 origin_agent = regionp->getOriginAgent(); | 213 | LLVector3 origin_agent = regionp->getOriginAgent(); |
266 | LLVector3 rel_region_pos = origin_agent - gAgent.getCameraPositionAgent(); | 214 | LLVector3 rel_region_pos = origin_agent - gAgent.getCameraPositionAgent(); |
267 | F32 relative_x = (rel_region_pos.mV[0] / region_width) * gMiniMapScale; | 215 | F32 relative_x = (rel_region_pos.mV[0] / region_width) * mScale; |
268 | F32 relative_y = (rel_region_pos.mV[1] / region_width) * gMiniMapScale; | 216 | F32 relative_y = (rel_region_pos.mV[1] / region_width) * mScale; |
269 | 217 | ||
270 | // background region rectangle | 218 | // background region rectangle |
271 | F32 bottom = relative_y; | 219 | F32 bottom = relative_y; |
272 | F32 left = relative_x; | 220 | F32 left = relative_x; |
273 | F32 top = bottom + gMiniMapScale ; | 221 | F32 top = bottom + mScale ; |
274 | F32 right = left + gMiniMapScale ; | 222 | F32 right = left + mScale ; |
275 | |||
276 | if (regionp == gAgent.getRegion()) | ||
277 | { | ||
278 | gGL.color4f(1.f, 1.f, 1.f, 1.f); | ||
279 | } | ||
280 | else | ||
281 | { | ||
282 | gGL.color4f(0.8f, 0.8f, 0.8f, 1.f); | ||
283 | } | ||
284 | 223 | ||
224 | gGL.color4fv(regionp == gAgent.getRegion() ? this_region_color.mV : live_region_color.mV); | ||
285 | if (!regionp->isAlive()) | 225 | if (!regionp->isAlive()) |
286 | { | 226 | { |
287 | gGL.color4f(1.f, 0.5f, 0.5f, 1.f); | 227 | gGL.color4fv(dead_region_color.mV); |
288 | } | 228 | } |
289 | 229 | ||
290 | 230 | ||
@@ -350,8 +290,8 @@ void LLNetMap::draw() | |||
350 | 290 | ||
351 | LLVector3 map_center_agent = gAgent.getPosAgentFromGlobal(mObjectImageCenterGlobal); | 291 | LLVector3 map_center_agent = gAgent.getPosAgentFromGlobal(mObjectImageCenterGlobal); |
352 | map_center_agent -= gAgent.getCameraPositionAgent(); | 292 | map_center_agent -= gAgent.getCameraPositionAgent(); |
353 | map_center_agent.mV[VX] *= gMiniMapScale/region_width; | 293 | map_center_agent.mV[VX] *= mScale/region_width; |
354 | map_center_agent.mV[VY] *= gMiniMapScale/region_width; | 294 | map_center_agent.mV[VY] *= mScale/region_width; |
355 | 295 | ||
356 | gGL.getTexUnit(0)->bind(mObjectImagep); | 296 | gGL.getTexUnit(0)->bind(mObjectImagep); |
357 | F32 image_half_width = 0.5f*mObjectMapPixels; | 297 | F32 image_half_width = 0.5f*mObjectMapPixels; |
@@ -373,81 +313,67 @@ void LLNetMap::draw() | |||
373 | LLVector3d pos_global; | 313 | LLVector3d pos_global; |
374 | LLVector3 pos_map; | 314 | LLVector3 pos_map; |
375 | 315 | ||
316 | // Mouse pointer in local coordinates | ||
317 | S32 local_mouse_x; | ||
318 | S32 local_mouse_y; | ||
319 | LLUI::getCursorPositionLocal(this, &local_mouse_x, &local_mouse_y); | ||
320 | mClosestAgentToCursor.setNull(); | ||
321 | F32 closest_dist = F32_MAX; | ||
322 | |||
376 | // Draw avatars | 323 | // Draw avatars |
377 | for (LLWorld::region_list_t::const_iterator iter = LLWorld::getInstance()->getRegionList().begin(); | 324 | LLColor4 avatar_color = gColors.getColor( "MapAvatar" ); |
378 | iter != LLWorld::getInstance()->getRegionList().end(); ++iter) | 325 | LLColor4 friend_color = gColors.getColor( "MapFriend" ); |
326 | std::vector<LLUUID> avatar_ids; | ||
327 | std::vector<LLVector3d> positions; | ||
328 | LLWorld::getInstance()->getAvatars(&avatar_ids, &positions); | ||
329 | for(U32 i=0; i<avatar_ids.size(); i++) | ||
379 | { | 330 | { |
380 | LLViewerRegion* regionp = *iter; | ||
381 | const LLVector3d& origin_global = regionp->getOriginGlobal(); | ||
382 | |||
383 | S32 count = regionp->mMapAvatars.count(); | ||
384 | S32 i; | ||
385 | LLVector3 pos_local; | ||
386 | U32 compact_local; | ||
387 | U8 bits; | ||
388 | // TODO: it'd be very cool to draw these in sorted order from lowest Z to highest. | 331 | // TODO: it'd be very cool to draw these in sorted order from lowest Z to highest. |
389 | // just be careful to sort the avatar IDs along with the positions. -MG | 332 | // just be careful to sort the avatar IDs along with the positions. -MG |
390 | for (i = 0; i < count; i++) | 333 | pos_map = globalPosToView(positions[i], rotate_map); |
391 | { | ||
392 | compact_local = regionp->mMapAvatars.get(i); | ||
393 | |||
394 | bits = compact_local & 0xFF; | ||
395 | pos_local.mV[VZ] = F32(bits) * 4.f; | ||
396 | compact_local >>= 8; | ||
397 | |||
398 | bits = compact_local & 0xFF; | ||
399 | pos_local.mV[VY] = (F32)bits; | ||
400 | compact_local >>= 8; | ||
401 | 334 | ||
402 | bits = compact_local & 0xFF; | 335 | LLWorldMapView::drawAvatar( |
403 | pos_local.mV[VX] = (F32)bits; | 336 | pos_map.mV[VX], pos_map.mV[VY], |
337 | is_agent_friend(avatar_ids[i]) ? friend_color : avatar_color, | ||
338 | pos_map.mV[VZ]); | ||
404 | 339 | ||
405 | pos_global.setVec( pos_local ); | 340 | F32 dist_to_cursor = dist_vec(LLVector2(pos_map.mV[VX], pos_map.mV[VY]), LLVector2(local_mouse_x,local_mouse_y)); |
406 | pos_global += origin_global; | 341 | if(dist_to_cursor < MAP_MIN_PICK_DIST && dist_to_cursor < closest_dist) |
407 | 342 | { | |
408 | pos_map = globalPosToView(pos_global); | 343 | closest_dist = dist_to_cursor; |
409 | 344 | mClosestAgentToCursor = avatar_ids[i]; | |
410 | BOOL show_as_friend = FALSE; | ||
411 | if( i < regionp->mMapAvatarIDs.count()) | ||
412 | { | ||
413 | show_as_friend = is_agent_friend(regionp->mMapAvatarIDs.get(i)); | ||
414 | } | ||
415 | LLWorldMapView::drawAvatar( | ||
416 | pos_map.mV[VX], pos_map.mV[VY], | ||
417 | show_as_friend ? glyph_color_friend : glyph_color_avatar, | ||
418 | pos_map.mV[VZ]); | ||
419 | } | 345 | } |
420 | } | 346 | } |
421 | 347 | ||
422 | // Draw dot for autopilot target | 348 | // Draw dot for autopilot target |
423 | if (gAgent.getAutoPilot()) | 349 | if (gAgent.getAutoPilot()) |
424 | { | 350 | { |
425 | drawTracking( gAgent.getAutoPilotTargetGlobal(), gTrackColor ); | 351 | drawTracking( gAgent.getAutoPilotTargetGlobal(), rotate_map, gTrackColor ); |
426 | } | 352 | } |
427 | else | 353 | else |
428 | { | 354 | { |
429 | LLTracker::ETrackingStatus tracking_status = LLTracker::getTrackingStatus(); | 355 | LLTracker::ETrackingStatus tracking_status = LLTracker::getTrackingStatus(); |
430 | if ( LLTracker::TRACKING_AVATAR == tracking_status ) | 356 | if ( LLTracker::TRACKING_AVATAR == tracking_status ) |
431 | { | 357 | { |
432 | drawTracking( LLAvatarTracker::instance().getGlobalPos(), gTrackColor ); | 358 | drawTracking( LLAvatarTracker::instance().getGlobalPos(), rotate_map, gTrackColor ); |
433 | } | 359 | } |
434 | else if ( LLTracker::TRACKING_LANDMARK == tracking_status | 360 | else if ( LLTracker::TRACKING_LANDMARK == tracking_status |
435 | || LLTracker::TRACKING_LOCATION == tracking_status ) | 361 | || LLTracker::TRACKING_LOCATION == tracking_status ) |
436 | { | 362 | { |
437 | drawTracking( LLTracker::getTrackedPositionGlobal(), gTrackColor ); | 363 | drawTracking( LLTracker::getTrackedPositionGlobal(), rotate_map, gTrackColor ); |
438 | } | 364 | } |
439 | } | 365 | } |
440 | 366 | ||
441 | // Draw dot for self avatar position | 367 | // Draw dot for self avatar position |
442 | pos_global = gAgent.getPositionGlobal(); | 368 | pos_global = gAgent.getPositionGlobal(); |
443 | pos_map = globalPosToView(pos_global); | 369 | pos_map = globalPosToView(pos_global, rotate_map); |
444 | LLUIImagePtr you = LLWorldMapView::sAvatarYouSmallImage; | 370 | LLUIImagePtr you = LLWorldMapView::sAvatarYouSmallImage; |
445 | you->draw( | 371 | you->draw( |
446 | llround(pos_map.mV[VX]) - you->getWidth()/2, | 372 | llround(pos_map.mV[VX]) - you->getWidth()/2, |
447 | llround(pos_map.mV[VY]) - you->getHeight()/2); | 373 | llround(pos_map.mV[VY]) - you->getHeight()/2); |
448 | 374 | ||
449 | // Draw frustum | 375 | // Draw frustum |
450 | F32 meters_to_pixels = gMiniMapScale/ LLWorld::getInstance()->getRegionWidthInMeters(); | 376 | F32 meters_to_pixels = mScale/ LLWorld::getInstance()->getRegionWidthInMeters(); |
451 | 377 | ||
452 | F32 horiz_fov = LLViewerCamera::getInstance()->getView() * LLViewerCamera::getInstance()->getAspect(); | 378 | F32 horiz_fov = LLViewerCamera::getInstance()->getView() * LLViewerCamera::getInstance()->getAspect(); |
453 | F32 far_clip_meters = LLViewerCamera::getInstance()->getFar(); | 379 | F32 far_clip_meters = LLViewerCamera::getInstance()->getFar(); |
@@ -462,9 +388,9 @@ void LLNetMap::draw() | |||
462 | 388 | ||
463 | gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE); | 389 | gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE); |
464 | 390 | ||
465 | if( LLNetMap::sRotateMap ) | 391 | if( rotate_map ) |
466 | { | 392 | { |
467 | gGL.color4fv(gFrustumMapColor.mV); | 393 | gGL.color4fv(gColors.getColor("NetMapFrustum").mV); |
468 | 394 | ||
469 | gGL.begin( LLRender::TRIANGLES ); | 395 | gGL.begin( LLRender::TRIANGLES ); |
470 | gGL.vertex2f( ctr_x, ctr_y ); | 396 | gGL.vertex2f( ctr_x, ctr_y ); |
@@ -474,7 +400,7 @@ void LLNetMap::draw() | |||
474 | } | 400 | } |
475 | else | 401 | else |
476 | { | 402 | { |
477 | gGL.color4fv(gRotatingFrustumMapColor.mV); | 403 | gGL.color4fv(gColors.getColor("NetMapFrustumRotating").mV); |
478 | 404 | ||
479 | // If we don't rotate the map, we have to rotate the frustum. | 405 | // If we don't rotate the map, we have to rotate the frustum. |
480 | gGL.pushMatrix(); | 406 | gGL.pushMatrix(); |
@@ -490,21 +416,26 @@ void LLNetMap::draw() | |||
490 | } | 416 | } |
491 | 417 | ||
492 | // Rotation of 0 means that North is up | 418 | // Rotation of 0 means that North is up |
493 | setDirectionPos( mTextBoxEast, rotation ); | 419 | setDirectionPos( getChild<LLTextBox>("e_label"), rotation); |
494 | setDirectionPos( mTextBoxNorth, rotation + F_PI_BY_TWO ); | 420 | setDirectionPos( getChild<LLTextBox>("n_label"), rotation + F_PI_BY_TWO); |
495 | setDirectionPos( mTextBoxWest, rotation + F_PI ); | 421 | setDirectionPos( getChild<LLTextBox>("w_label"), rotation + F_PI); |
496 | setDirectionPos( mTextBoxSouth, rotation + F_PI + F_PI_BY_TWO ); | 422 | setDirectionPos( getChild<LLTextBox>("s_label"), rotation + F_PI + F_PI_BY_TWO); |
497 | 423 | ||
498 | setDirectionPos( mTextBoxNorthEast, rotation + F_PI_BY_TWO / 2); | 424 | setDirectionPos( getChild<LLTextBox>("ne_label"), rotation + F_PI_BY_TWO / 2); |
499 | setDirectionPos( mTextBoxNorthWest, rotation + F_PI_BY_TWO + F_PI_BY_TWO / 2); | 425 | setDirectionPos( getChild<LLTextBox>("nw_label"), rotation + F_PI_BY_TWO + F_PI_BY_TWO / 2); |
500 | setDirectionPos( mTextBoxSouthWest, rotation + F_PI + F_PI_BY_TWO / 2); | 426 | setDirectionPos( getChild<LLTextBox>("sw_label"), rotation + F_PI + F_PI_BY_TWO / 2); |
501 | setDirectionPos( mTextBoxSouthEast, rotation + F_PI + F_PI_BY_TWO + F_PI_BY_TWO / 2); | 427 | setDirectionPos( getChild<LLTextBox>("se_label"), rotation + F_PI + F_PI_BY_TWO + F_PI_BY_TWO / 2); |
502 | 428 | ||
503 | LLUICtrl::draw(); | 429 | LLView::draw(); |
504 | } | 430 | } |
505 | 431 | ||
506 | LLVector3 LLNetMap::globalPosToView( const LLVector3d& global_pos ) | 432 | void LLNetMap::reshape(S32 width, S32 height, BOOL called_from_parent) |
507 | { | 433 | { |
434 | LLPanel::reshape(width, height, called_from_parent); | ||
435 | updateMinorDirections(); | ||
436 | } | ||
437 | |||
438 | LLVector3 LLNetMap::globalPosToView( const LLVector3d& global_pos, BOOL rotated ){ | ||
508 | LLVector3d relative_pos_global = global_pos - gAgent.getCameraPositionGlobal(); | 439 | LLVector3d relative_pos_global = global_pos - gAgent.getCameraPositionGlobal(); |
509 | LLVector3 pos_local; | 440 | LLVector3 pos_local; |
510 | pos_local.setVec(relative_pos_global); // convert to floats from doubles | 441 | pos_local.setVec(relative_pos_global); // convert to floats from doubles |
@@ -513,7 +444,7 @@ LLVector3 LLNetMap::globalPosToView( const LLVector3d& global_pos ) | |||
513 | pos_local.mV[VY] *= mPixelsPerMeter; | 444 | pos_local.mV[VY] *= mPixelsPerMeter; |
514 | // leave Z component in meters | 445 | // leave Z component in meters |
515 | 446 | ||
516 | if( LLNetMap::sRotateMap ) | 447 | if( rotated ) |
517 | { | 448 | { |
518 | F32 radians = atan2( LLViewerCamera::getInstance()->getAtAxis().mV[VX], LLViewerCamera::getInstance()->getAtAxis().mV[VY] ); | 449 | F32 radians = atan2( LLViewerCamera::getInstance()->getAtAxis().mV[VX], LLViewerCamera::getInstance()->getAtAxis().mV[VY] ); |
519 | LLQuaternion rot(radians, LLVector3(0.f, 0.f, 1.f)); | 450 | LLQuaternion rot(radians, LLVector3(0.f, 0.f, 1.f)); |
@@ -526,10 +457,10 @@ LLVector3 LLNetMap::globalPosToView( const LLVector3d& global_pos ) | |||
526 | return pos_local; | 457 | return pos_local; |
527 | } | 458 | } |
528 | 459 | ||
529 | void LLNetMap::drawTracking(const LLVector3d& pos_global, const LLColor4& color, | 460 | void LLNetMap::drawTracking(const LLVector3d& pos_global, BOOL rotated, |
530 | BOOL draw_arrow ) | 461 | const LLColor4& color, BOOL draw_arrow ) |
531 | { | 462 | { |
532 | LLVector3 pos_local = globalPosToView( pos_global ); | 463 | LLVector3 pos_local = globalPosToView( pos_global, rotated ); |
533 | if( (pos_local.mV[VX] < 0) || | 464 | if( (pos_local.mV[VX] < 0) || |
534 | (pos_local.mV[VY] < 0) || | 465 | (pos_local.mV[VY] < 0) || |
535 | (pos_local.mV[VX] >= getRect().getWidth()) || | 466 | (pos_local.mV[VX] >= getRect().getWidth()) || |
@@ -552,22 +483,22 @@ void LLNetMap::drawTracking(const LLVector3d& pos_global, const LLColor4& color, | |||
552 | } | 483 | } |
553 | } | 484 | } |
554 | 485 | ||
555 | LLVector3d LLNetMap::viewPosToGlobal( S32 x, S32 y ) | 486 | LLVector3d LLNetMap::viewPosToGlobal( S32 x, S32 y, BOOL rotated ) |
556 | { | 487 | { |
557 | x -= llround(getRect().getWidth() / 2 + mCurPanX); | 488 | x -= llround(getRect().getWidth() / 2 + mCurPanX); |
558 | y -= llround(getRect().getHeight() / 2 + mCurPanY); | 489 | y -= llround(getRect().getHeight() / 2 + mCurPanY); |
559 | 490 | ||
560 | LLVector3 pos_local( (F32)x, (F32)y, 0 ); | 491 | LLVector3 pos_local( (F32)x, (F32)y, 0.f ); |
561 | 492 | ||
562 | F32 radians = - atan2( LLViewerCamera::getInstance()->getAtAxis().mV[VX], LLViewerCamera::getInstance()->getAtAxis().mV[VY] ); | 493 | F32 radians = - atan2( LLViewerCamera::getInstance()->getAtAxis().mV[VX], LLViewerCamera::getInstance()->getAtAxis().mV[VY] ); |
563 | 494 | ||
564 | if( LLNetMap::sRotateMap ) | 495 | if( rotated ) |
565 | { | 496 | { |
566 | LLQuaternion rot(radians, LLVector3(0.f, 0.f, 1.f)); | 497 | LLQuaternion rot(radians, LLVector3(0.f, 0.f, 1.f)); |
567 | pos_local.rotVec( rot ); | 498 | pos_local.rotVec( rot ); |
568 | } | 499 | } |
569 | 500 | ||
570 | pos_local *= ( LLWorld::getInstance()->getRegionWidthInMeters() / gMiniMapScale ); | 501 | pos_local *= ( LLWorld::getInstance()->getRegionWidthInMeters() / mScale ); |
571 | 502 | ||
572 | LLVector3d pos_global; | 503 | LLVector3d pos_global; |
573 | pos_global.setVec( pos_local ); | 504 | pos_global.setVec( pos_local ); |
@@ -579,7 +510,7 @@ LLVector3d LLNetMap::viewPosToGlobal( S32 x, S32 y ) | |||
579 | BOOL LLNetMap::handleScrollWheel(S32 x, S32 y, S32 clicks) | 510 | BOOL LLNetMap::handleScrollWheel(S32 x, S32 y, S32 clicks) |
580 | { | 511 | { |
581 | // note that clicks are reversed from what you'd think | 512 | // note that clicks are reversed from what you'd think |
582 | setScale(llclamp(gMiniMapScale - clicks*MAP_SCALE_INCREMENT, MAP_SCALE_MIN, MAP_SCALE_MAX)); | 513 | setScale(llclamp(mScale - clicks*MAP_SCALE_INCREMENT, MAP_SCALE_MIN, MAP_SCALE_MAX)); |
583 | return TRUE; | 514 | return TRUE; |
584 | } | 515 | } |
585 | 516 | ||
@@ -590,10 +521,17 @@ BOOL LLNetMap::handleToolTip( S32 x, S32 y, std::string& msg, LLRect* sticky_rec | |||
590 | { | 521 | { |
591 | return FALSE; | 522 | return FALSE; |
592 | } | 523 | } |
593 | LLViewerRegion* region = LLWorld::getInstance()->getRegionFromPosGlobal( viewPosToGlobal( x, y ) ); | 524 | LLViewerRegion* region = LLWorld::getInstance()->getRegionFromPosGlobal( viewPosToGlobal( x, y , gSavedSettings.getBOOL( "MiniMapRotate" )) ); |
594 | if( region ) | 525 | if( region ) |
595 | { | 526 | { |
596 | msg.assign( region->getName() ); | 527 | msg.assign(""); |
528 | std::string fullname; | ||
529 | if(mClosestAgentToCursor.notNull() && gCacheName->getFullName(mClosestAgentToCursor, fullname)) | ||
530 | { | ||
531 | msg.append(fullname); | ||
532 | msg.append("\n"); | ||
533 | } | ||
534 | msg.append( region->getName() ); | ||
597 | 535 | ||
598 | #ifndef LL_RELEASE_FOR_DOWNLOAD | 536 | #ifndef LL_RELEASE_FOR_DOWNLOAD |
599 | std::string buffer; | 537 | std::string buffer; |
@@ -618,8 +556,12 @@ BOOL LLNetMap::handleToolTip( S32 x, S32 y, std::string& msg, LLRect* sticky_rec | |||
618 | &(sticky_rect_screen->mLeft), &(sticky_rect_screen->mBottom) ); | 556 | &(sticky_rect_screen->mLeft), &(sticky_rect_screen->mBottom) ); |
619 | sticky_rect_screen->mRight = sticky_rect_screen->mLeft + 2 * SLOP; | 557 | sticky_rect_screen->mRight = sticky_rect_screen->mLeft + 2 * SLOP; |
620 | sticky_rect_screen->mTop = sticky_rect_screen->mBottom + 2 * SLOP; | 558 | sticky_rect_screen->mTop = sticky_rect_screen->mBottom + 2 * SLOP; |
559 | handled = TRUE; | ||
560 | } | ||
561 | if(!handled) | ||
562 | { | ||
563 | return LLPanel::handleToolTip(x, y, msg, sticky_rect_screen); | ||
621 | } | 564 | } |
622 | handled = TRUE; | ||
623 | return handled; | 565 | return handled; |
624 | } | 566 | } |
625 | 567 | ||
@@ -629,19 +571,32 @@ void LLNetMap::setDirectionPos( LLTextBox* text_box, F32 rotation ) | |||
629 | // Rotation is in radians. | 571 | // Rotation is in radians. |
630 | // Rotation of 0 means x = 1, y = 0 on the unit circle. | 572 | // Rotation of 0 means x = 1, y = 0 on the unit circle. |
631 | 573 | ||
632 | 574 | F32 half_height = (F32)( (getRect().getHeight() - text_box->getRect().getHeight()) / 2); | |
633 | F32 map_half_height = (F32)(getRect().getHeight() / 2); | 575 | F32 half_width = (F32)( (getRect().getWidth() - text_box->getRect().getWidth()) / 2); |
634 | F32 map_half_width = (F32)(getRect().getWidth() / 2); | 576 | F32 radius = llmin( half_height, half_width ); |
635 | F32 text_half_height = (F32)(text_box->getRect().getHeight() / 2); | ||
636 | F32 text_half_width = (F32)(text_box->getRect().getWidth() / 2); | ||
637 | F32 radius = llmin( map_half_height - text_half_height, map_half_width - text_half_width ); | ||
638 | 577 | ||
639 | // Inset by a little to account for position display. | 578 | // Inset by a little to account for position display. |
640 | radius -= 8.f; | 579 | radius -= 8.f; |
641 | 580 | ||
642 | text_box->setOrigin( | 581 | text_box->setOrigin(llround(half_width + radius * cos( rotation )), |
643 | llround(map_half_width - text_half_width + radius * cos( rotation )), | 582 | llround(half_height + radius * sin( rotation ))); |
644 | llround(map_half_height - text_half_height + radius * sin( rotation )) ); | 583 | } |
584 | |||
585 | void LLNetMap::updateMinorDirections() | ||
586 | { | ||
587 | if (getChild<LLTextBox>("ne_label") == NULL) | ||
588 | { | ||
589 | return; | ||
590 | } | ||
591 | |||
592 | // Hide minor directions if they cover too much of the map | ||
593 | bool show_minors = getChild<LLTextBox>("ne_label")->getRect().getHeight() < MAP_MINOR_DIR_THRESHOLD * | ||
594 | llmin(getRect().getWidth(), getRect().getHeight()); | ||
595 | |||
596 | getChild<LLTextBox>("ne_label")->setVisible(show_minors); | ||
597 | getChild<LLTextBox>("nw_label")->setVisible(show_minors); | ||
598 | getChild<LLTextBox>("sw_label")->setVisible(show_minors); | ||
599 | getChild<LLTextBox>("se_label")->setVisible(show_minors); | ||
645 | } | 600 | } |
646 | 601 | ||
647 | void LLNetMap::renderScaledPointGlobal( const LLVector3d& pos, const LLColor4U &color, F32 radius_meters ) | 602 | void LLNetMap::renderScaledPointGlobal( const LLVector3d& pos, const LLColor4U &color, F32 radius_meters ) |
@@ -746,10 +701,10 @@ void LLNetMap::renderPoint(const LLVector3 &pos_local, const LLColor4U &color, | |||
746 | void LLNetMap::createObjectImage() | 701 | void LLNetMap::createObjectImage() |
747 | { | 702 | { |
748 | // Find the size of the side of a square that surrounds the circle that surrounds getRect(). | 703 | // Find the size of the side of a square that surrounds the circle that surrounds getRect(). |
749 | F32 half_width = (F32)(getRect().getWidth() / 2); | 704 | // ... which is, the diagonal of the rect. |
750 | F32 half_height = (F32)(getRect().getHeight() / 2); | 705 | F32 width = getRect().getWidth(); |
751 | F32 radius = sqrt( half_width * half_width + half_height * half_height ); | 706 | F32 height = getRect().getHeight(); |
752 | S32 square_size = S32( 2 * radius ); | 707 | S32 square_size = llround( sqrt(width*width + height*height) ); |
753 | 708 | ||
754 | // Find the least power of two >= the minimum size. | 709 | // Find the least power of two >= the minimum size. |
755 | const S32 MIN_SIZE = 32; | 710 | const S32 MIN_SIZE = 32; |
@@ -768,7 +723,7 @@ void LLNetMap::createObjectImage() | |||
768 | U8* data = mObjectRawImagep->getData(); | 723 | U8* data = mObjectRawImagep->getData(); |
769 | memset( data, 0, img_size * img_size * 4 ); | 724 | memset( data, 0, img_size * img_size * 4 ); |
770 | mObjectImagep = new LLImageGL( mObjectRawImagep, FALSE); | 725 | mObjectImagep = new LLImageGL( mObjectRawImagep, FALSE); |
771 | setScale(gMiniMapScale); | 726 | setScale(mScale); |
772 | } | 727 | } |
773 | mUpdateNow = TRUE; | 728 | mUpdateNow = TRUE; |
774 | } | 729 | } |
@@ -778,7 +733,7 @@ BOOL LLNetMap::handleDoubleClick( S32 x, S32 y, MASK mask ) | |||
778 | if (gSavedSettings.getBOOL( "MiniMapTeleport" )) | 733 | if (gSavedSettings.getBOOL( "MiniMapTeleport" )) |
779 | { | 734 | { |
780 | gAgent.setControlFlags(AGENT_CONTROL_STAND_UP); | 735 | gAgent.setControlFlags(AGENT_CONTROL_STAND_UP); |
781 | gAgent.teleportViaLocation( viewPosToGlobal(x,y) ); | 736 | gAgent.teleportViaLocation( viewPosToGlobal(x,y,gSavedSettings.getBOOL("MiniMapRotate")) ); |
782 | } | 737 | } |
783 | else | 738 | else |
784 | LLFloaterWorldMap::show(NULL, FALSE); | 739 | LLFloaterWorldMap::show(NULL, FALSE); |
@@ -788,6 +743,7 @@ BOOL LLNetMap::handleDoubleClick( S32 x, S32 y, MASK mask ) | |||
788 | 743 | ||
789 | BOOL LLNetMap::handleRightMouseDown(S32 x, S32 y, MASK mask) | 744 | BOOL LLNetMap::handleRightMouseDown(S32 x, S32 y, MASK mask) |
790 | { | 745 | { |
746 | mClosestAgentAtLastRightClick = mClosestAgentToCursor; | ||
791 | LLMenuGL* menu = (LLMenuGL*)mPopupMenuHandle.get(); | 747 | LLMenuGL* menu = (LLMenuGL*)mPopupMenuHandle.get(); |
792 | if (menu) | 748 | if (menu) |
793 | { | 749 | { |
@@ -800,22 +756,53 @@ BOOL LLNetMap::handleRightMouseDown(S32 x, S32 y, MASK mask) | |||
800 | 756 | ||
801 | 757 | ||
802 | // static | 758 | // static |
803 | void LLNetMap::handleZoomLevel(void* which) | 759 | bool LLNetMap::LLScaleMap::handleEvent(LLPointer<LLEvent> event, const LLSD& userdata) |
804 | { | 760 | { |
805 | intptr_t level = (intptr_t)which; | 761 | LLNetMap *self = mPtr; |
762 | |||
763 | S32 level = userdata.asInteger(); | ||
806 | 764 | ||
807 | switch(level) | 765 | switch(level) |
808 | { | 766 | { |
809 | case 0: | 767 | case 0: |
810 | LLNetMap::sInstance->setScale(MAP_SCALE_MIN); | 768 | self->setScale(MAP_SCALE_MIN); |
811 | break; | 769 | break; |
812 | case 1: | 770 | case 1: |
813 | LLNetMap::sInstance->setScale(MAP_SCALE_MID); | 771 | self->setScale(MAP_SCALE_MID); |
814 | break; | 772 | break; |
815 | case 2: | 773 | case 2: |
816 | LLNetMap::sInstance->setScale(MAP_SCALE_MAX); | 774 | self->setScale(MAP_SCALE_MAX); |
817 | break; | 775 | break; |
818 | default: | 776 | default: |
819 | break; | 777 | break; |
820 | } | 778 | } |
779 | |||
780 | return true; | ||
781 | } | ||
782 | |||
783 | bool LLNetMap::LLStopTracking::handleEvent(LLPointer<LLEvent> event, const LLSD& userdata) | ||
784 | { | ||
785 | LLTracker::stopTracking(NULL); | ||
786 | return true; | ||
787 | } | ||
788 | |||
789 | bool LLNetMap::LLEnableTracking::handleEvent(LLPointer<LLEvent> event, const LLSD& userdata) | ||
790 | { | ||
791 | LLNetMap *self = mPtr; | ||
792 | self->findControl(userdata["control"].asString())->setValue(LLTracker::isTracking(NULL)); | ||
793 | return true; | ||
794 | } | ||
795 | |||
796 | bool LLNetMap::LLShowAgentProfile::handleEvent(LLPointer<LLEvent> event, const LLSD& userdata) | ||
797 | { | ||
798 | LLNetMap *self = mPtr; | ||
799 | LLFloaterAvatarInfo::show(self->mClosestAgentAtLastRightClick); | ||
800 | return true; | ||
801 | } | ||
802 | |||
803 | bool LLNetMap::LLEnableProfile::handleEvent(LLPointer<LLEvent> event, const LLSD& userdata) | ||
804 | { | ||
805 | LLNetMap *self = mPtr; | ||
806 | self->findControl(userdata["control"].asString())->setValue(self->isAgentUnderCursor()); | ||
807 | return true; | ||
821 | } | 808 | } |
diff --git a/linden/indra/newview/llnetmap.h b/linden/indra/newview/llnetmap.h index 65d4a4c..be5593d 100644 --- a/linden/indra/newview/llnetmap.h +++ b/linden/indra/newview/llnetmap.h | |||
@@ -32,63 +32,56 @@ | |||
32 | #ifndef LL_LLNETMAP_H | 32 | #ifndef LL_LLNETMAP_H |
33 | #define LL_LLNETMAP_H | 33 | #define LL_LLNETMAP_H |
34 | 34 | ||
35 | #include "llmath.h" | 35 | #include "llpanel.h" |
36 | #include "lluictrl.h" | 36 | #include "llmemberlistener.h" |
37 | #include "v3math.h" | 37 | #include "v3math.h" |
38 | #include "v3dmath.h" | 38 | #include "v3dmath.h" |
39 | #include "v4color.h" | 39 | #include "v4color.h" |
40 | #include "llimage.h" | 40 | #include "llimage.h" |
41 | #include "llimagegl.h" | 41 | #include "llimagegl.h" |
42 | 42 | ||
43 | class LLColor4U; | 43 | |
44 | class LLCoordGL; | ||
45 | class LLTextBox; | 44 | class LLTextBox; |
46 | class LLMenuGL; | ||
47 | 45 | ||
48 | class LLNetMap : public LLUICtrl | 46 | class LLNetMap : public LLPanel |
49 | { | 47 | { |
50 | public: | 48 | public: |
51 | LLNetMap(const std::string& name, const LLRect& rect, const LLColor4& bg_color ); | 49 | LLNetMap(const std::string& name); |
52 | virtual ~LLNetMap(); | 50 | virtual ~LLNetMap(); |
53 | 51 | ||
54 | virtual void draw(); | 52 | virtual void draw(); |
53 | virtual void reshape(S32 width, S32 height, BOOL called_from_parent = TRUE); | ||
55 | virtual BOOL handleDoubleClick( S32 x, S32 y, MASK mask ); | 54 | virtual BOOL handleDoubleClick( S32 x, S32 y, MASK mask ); |
56 | virtual BOOL handleRightMouseDown( S32 x, S32 y, MASK mask ); | 55 | virtual BOOL handleRightMouseDown( S32 x, S32 y, MASK mask ); |
57 | virtual BOOL handleScrollWheel(S32 x, S32 y, S32 clicks); | 56 | virtual BOOL handleScrollWheel(S32 x, S32 y, S32 clicks); |
58 | virtual BOOL handleToolTip( S32 x, S32 y, std::string& msg, LLRect* sticky_rect_screen ); | 57 | virtual BOOL handleToolTip( S32 x, S32 y, std::string& msg, LLRect* sticky_rect_screen ); |
59 | 58 | ||
59 | void renderScaledPointGlobal( const LLVector3d& pos, const LLColor4U &color, F32 radius ); | ||
60 | |||
61 | private: | ||
62 | |||
60 | void setScale( F32 scale ); | 63 | void setScale( F32 scale ); |
64 | |||
65 | // *TODO: Enable panning of the mini-map | ||
61 | void translatePan( F32 delta_x, F32 delta_y ); | 66 | void translatePan( F32 delta_x, F32 delta_y ); |
62 | void setPan( F32 x, F32 y ) { mTargetPanX = x; mTargetPanY = y; } | 67 | void setPan( F32 x, F32 y ) { mTargetPanX = x; mTargetPanY = y; } |
63 | 68 | ||
64 | const LLVector3d& getObjectImageCenterGlobal() { return mObjectImageCenterGlobal; } | ||
65 | void renderPoint(const LLVector3 &pos, const LLColor4U &color, | 69 | void renderPoint(const LLVector3 &pos, const LLColor4U &color, |
66 | S32 diameter, S32 relative_height = 0); | 70 | S32 diameter, S32 relative_height = 0); |
67 | void renderScaledPointGlobal( const LLVector3d& pos, const LLColor4U &color, F32 radius ); | 71 | LLVector3 globalPosToView(const LLVector3d& global_pos, BOOL rotated); |
68 | 72 | LLVector3d viewPosToGlobal(S32 x,S32 y, BOOL rotated); | |
69 | LLVector3 globalPosToView(const LLVector3d& global_pos); | ||
70 | LLVector3d viewPosToGlobal(S32 x,S32 y); | ||
71 | |||
72 | static void setRotateMap( BOOL b ) { LLNetMap::sRotateMap = b; } | ||
73 | static void handleZoomLevel(void* which); | ||
74 | 73 | ||
75 | void drawTracking( const LLVector3d& pos_global, | 74 | void drawTracking( const LLVector3d& pos_global, |
76 | const LLColor4& color, | 75 | BOOL rotated, |
77 | BOOL draw_arrow = TRUE); | 76 | const LLColor4& color, |
77 | BOOL draw_arrow = TRUE); | ||
78 | 78 | ||
79 | protected: | ||
80 | void setDirectionPos( LLTextBox* text_box, F32 rotation ); | 79 | void setDirectionPos( LLTextBox* text_box, F32 rotation ); |
80 | void updateMinorDirections(); | ||
81 | void createObjectImage(); | 81 | void createObjectImage(); |
82 | static void teleport( const LLVector3d& destination ); | ||
83 | static void fly( const LLVector3d& destination ); | ||
84 | 82 | ||
85 | public: | ||
86 | LLHandle<LLView> mPopupMenuHandle; | 83 | LLHandle<LLView> mPopupMenuHandle; |
87 | 84 | ||
88 | LLColor4 mBackgroundColor; | ||
89 | LLColor4 glyph_color_avatar; | ||
90 | LLColor4 glyph_color_friend; | ||
91 | |||
92 | F32 mScale; // Size of a region in pixels | 85 | F32 mScale; // Size of a region in pixels |
93 | F32 mPixelsPerMeter; // world meters to map pixels | 86 | F32 mPixelsPerMeter; // world meters to map pixels |
94 | F32 mObjectMapTPM; // texels per meter on map | 87 | F32 mObjectMapTPM; // texels per meter on map |
@@ -101,18 +94,46 @@ public: | |||
101 | LLVector3d mObjectImageCenterGlobal; | 94 | LLVector3d mObjectImageCenterGlobal; |
102 | LLPointer<LLImageRaw> mObjectRawImagep; | 95 | LLPointer<LLImageRaw> mObjectRawImagep; |
103 | LLPointer<LLImageGL> mObjectImagep; | 96 | LLPointer<LLImageGL> mObjectImagep; |
104 | LLTextBox* mTextBoxEast; | ||
105 | LLTextBox* mTextBoxNorth; | ||
106 | LLTextBox* mTextBoxWest; | ||
107 | LLTextBox* mTextBoxSouth; | ||
108 | 97 | ||
109 | LLTextBox* mTextBoxSouthEast; | 98 | private: |
110 | LLTextBox* mTextBoxNorthEast; | 99 | LLUUID mClosestAgentToCursor; |
111 | LLTextBox* mTextBoxNorthWest; | 100 | LLUUID mClosestAgentAtLastRightClick; |
112 | LLTextBox* mTextBoxSouthWest; | ||
113 | 101 | ||
114 | static BOOL sRotateMap; | 102 | static BOOL sRotateMap; |
115 | static LLNetMap* sInstance; | 103 | static LLNetMap* sInstance; |
104 | static BOOL isAgentUnderCursor(void*) { return sInstance && sInstance->mClosestAgentToCursor.notNull(); } | ||
105 | static void showAgentProfile(void*); | ||
106 | BOOL isAgentUnderCursor() { return mClosestAgentToCursor.notNull(); } | ||
107 | |||
108 | class LLScaleMap : public LLMemberListener<LLNetMap> | ||
109 | { | ||
110 | public: | ||
111 | /*virtual*/ bool handleEvent(LLPointer<LLEvent> event, const LLSD& userdata); | ||
112 | }; | ||
113 | |||
114 | class LLStopTracking : public LLMemberListener<LLNetMap> | ||
115 | { | ||
116 | public: | ||
117 | /*virtual*/ bool handleEvent(LLPointer<LLEvent> event, const LLSD& userdata); | ||
118 | }; | ||
119 | |||
120 | class LLEnableTracking : public LLMemberListener<LLNetMap> | ||
121 | { | ||
122 | public: | ||
123 | /*virtual*/ bool handleEvent(LLPointer<LLEvent> event, const LLSD& userdata); | ||
124 | }; | ||
125 | |||
126 | class LLShowAgentProfile : public LLMemberListener<LLNetMap> | ||
127 | { | ||
128 | public: | ||
129 | /*virtual*/ bool handleEvent(LLPointer<LLEvent> event, const LLSD& userdata); | ||
130 | }; | ||
131 | |||
132 | class LLEnableProfile : public LLMemberListener<LLNetMap> | ||
133 | { | ||
134 | public: | ||
135 | /*virtual*/ bool handleEvent(LLPointer<LLEvent> event, const LLSD& userdata); | ||
136 | }; | ||
116 | }; | 137 | }; |
117 | 138 | ||
118 | 139 | ||
diff --git a/linden/indra/newview/llstartup.cpp b/linden/indra/newview/llstartup.cpp index df7c084..aca3cac 100644 --- a/linden/indra/newview/llstartup.cpp +++ b/linden/indra/newview/llstartup.cpp | |||
@@ -1670,11 +1670,14 @@ bool idle_startup() | |||
1670 | gLoginMenuBarView->setVisible( FALSE ); | 1670 | gLoginMenuBarView->setVisible( FALSE ); |
1671 | gLoginMenuBarView->setEnabled( FALSE ); | 1671 | gLoginMenuBarView->setEnabled( FALSE ); |
1672 | 1672 | ||
1673 | gFloaterMap->setVisible( gSavedSettings.getBOOL("ShowMiniMap") ); | ||
1674 | |||
1675 | LLRect window(0, gViewerWindow->getWindowHeight(), gViewerWindow->getWindowWidth(), 0); | 1673 | LLRect window(0, gViewerWindow->getWindowHeight(), gViewerWindow->getWindowWidth(), 0); |
1676 | gViewerWindow->adjustControlRectanglesForFirstUse(window); | 1674 | gViewerWindow->adjustControlRectanglesForFirstUse(window); |
1677 | 1675 | ||
1676 | if(gSavedSettings.getBOOL("ShowMiniMap")) | ||
1677 | { | ||
1678 | LLFloaterMap::showInstance(); | ||
1679 | } | ||
1680 | |||
1678 | if (gSavedSettings.getBOOL("ShowCameraControls")) | 1681 | if (gSavedSettings.getBOOL("ShowCameraControls")) |
1679 | { | 1682 | { |
1680 | LLFloaterCamera::showInstance(); | 1683 | LLFloaterCamera::showInstance(); |
@@ -3911,8 +3914,7 @@ void reset_login() | |||
3911 | } | 3914 | } |
3912 | 3915 | ||
3913 | // Hide any other stuff | 3916 | // Hide any other stuff |
3914 | if ( gFloaterMap ) | 3917 | LLFloaterMap::hideInstance(); |
3915 | gFloaterMap->setVisible( FALSE ); | ||
3916 | } | 3918 | } |
3917 | 3919 | ||
3918 | //--------------------------------------------------------------------------- | 3920 | //--------------------------------------------------------------------------- |
diff --git a/linden/indra/newview/llviewercontrol.cpp b/linden/indra/newview/llviewercontrol.cpp index aa092c7..89ae973 100644 --- a/linden/indra/newview/llviewercontrol.cpp +++ b/linden/indra/newview/llviewercontrol.cpp | |||
@@ -44,7 +44,6 @@ | |||
44 | #include "llflexibleobject.h" | 44 | #include "llflexibleobject.h" |
45 | #include "llfeaturemanager.h" | 45 | #include "llfeaturemanager.h" |
46 | #include "llviewershadermgr.h" | 46 | #include "llviewershadermgr.h" |
47 | #include "llnetmap.h" | ||
48 | #include "llpanelgeneral.h" | 47 | #include "llpanelgeneral.h" |
49 | #include "llpanelinput.h" | 48 | #include "llpanelinput.h" |
50 | #include "llsky.h" | 49 | #include "llsky.h" |
@@ -409,12 +408,6 @@ bool handleEffectColorChanged(const LLSD& newvalue) | |||
409 | return true; | 408 | return true; |
410 | } | 409 | } |
411 | 410 | ||
412 | bool handleRotateNetMapChanged(const LLSD& newvalue) | ||
413 | { | ||
414 | LLNetMap::setRotateMap(newvalue.asBoolean()); | ||
415 | return true; | ||
416 | } | ||
417 | |||
418 | bool handleVectorizeChanged(const LLSD& newvalue) | 411 | bool handleVectorizeChanged(const LLSD& newvalue) |
419 | { | 412 | { |
420 | LLViewerJointMesh::updateVectorize(); | 413 | LLViewerJointMesh::updateVectorize(); |
@@ -559,7 +552,6 @@ void settings_setup_listeners() | |||
559 | gSavedSettings.getControl("UserLogFile")->getSignal()->connect(boost::bind(&handleLogFileChanged, _1)); | 552 | gSavedSettings.getControl("UserLogFile")->getSignal()->connect(boost::bind(&handleLogFileChanged, _1)); |
560 | gSavedSettings.getControl("RenderHideGroupTitle")->getSignal()->connect(boost::bind(handleHideGroupTitleChanged, _1)); | 553 | gSavedSettings.getControl("RenderHideGroupTitle")->getSignal()->connect(boost::bind(handleHideGroupTitleChanged, _1)); |
561 | gSavedSettings.getControl("EffectColor")->getSignal()->connect(boost::bind(handleEffectColorChanged, _1)); | 554 | gSavedSettings.getControl("EffectColor")->getSignal()->connect(boost::bind(handleEffectColorChanged, _1)); |
562 | gSavedSettings.getControl("MiniMapRotate")->getSignal()->connect(boost::bind(handleRotateNetMapChanged, _1)); | ||
563 | gSavedSettings.getControl("VectorizePerfTest")->getSignal()->connect(boost::bind(&handleVectorizeChanged, _1)); | 555 | gSavedSettings.getControl("VectorizePerfTest")->getSignal()->connect(boost::bind(&handleVectorizeChanged, _1)); |
564 | gSavedSettings.getControl("VectorizeEnable")->getSignal()->connect(boost::bind(&handleVectorizeChanged, _1)); | 556 | gSavedSettings.getControl("VectorizeEnable")->getSignal()->connect(boost::bind(&handleVectorizeChanged, _1)); |
565 | gSavedSettings.getControl("VectorizeProcessor")->getSignal()->connect(boost::bind(&handleVectorizeChanged, _1)); | 557 | gSavedSettings.getControl("VectorizeProcessor")->getSignal()->connect(boost::bind(&handleVectorizeChanged, _1)); |
diff --git a/linden/indra/newview/llviewermenu.cpp b/linden/indra/newview/llviewermenu.cpp index aa5e791..847336d 100644 --- a/linden/indra/newview/llviewermenu.cpp +++ b/linden/indra/newview/llviewermenu.cpp | |||
@@ -416,7 +416,6 @@ void handle_force_delete(void*); | |||
416 | void print_object_info(void*); | 416 | void print_object_info(void*); |
417 | void print_agent_nvpairs(void*); | 417 | void print_agent_nvpairs(void*); |
418 | void toggle_debug_menus(void*); | 418 | void toggle_debug_menus(void*); |
419 | void toggle_map( void* user_data ); | ||
420 | void export_info_callback(LLAssetInfo *info, void **user_data, S32 result); | 419 | void export_info_callback(LLAssetInfo *info, void **user_data, S32 result); |
421 | void export_data_callback(LLVFS *vfs, const LLUUID& uuid, LLAssetType::EType type, void **user_data, S32 result); | 420 | void export_data_callback(LLVFS *vfs, const LLUUID& uuid, LLAssetType::EType type, void **user_data, S32 result); |
422 | void upload_done_callback(const LLUUID& uuid, void* user_data, S32 result, LLExtStat ext_status); | 421 | void upload_done_callback(const LLUUID& uuid, void* user_data, S32 result, LLExtStat ext_status); |
@@ -4578,22 +4577,6 @@ void toggle_debug_menus(void*) | |||
4578 | } | 4577 | } |
4579 | 4578 | ||
4580 | 4579 | ||
4581 | void toggle_map( void* user_data ) | ||
4582 | { | ||
4583 | // Toggle the item | ||
4584 | BOOL checked = gSavedSettings.getBOOL( static_cast<char*>(user_data) ); | ||
4585 | gSavedSettings.setBOOL( static_cast<char*>(user_data), !checked ); | ||
4586 | if (checked) | ||
4587 | { | ||
4588 | gFloaterMap->close(); | ||
4589 | } | ||
4590 | else | ||
4591 | { | ||
4592 | gFloaterMap->open(); /* Flawfinder: ignore */ | ||
4593 | } | ||
4594 | } | ||
4595 | |||
4596 | |||
4597 | // LLUUID gExporterRequestID; | 4580 | // LLUUID gExporterRequestID; |
4598 | // std::string gExportDirectory; | 4581 | // std::string gExportDirectory; |
4599 | 4582 | ||
@@ -5116,7 +5099,7 @@ class LLShowFloater : public view_listener_t | |||
5116 | } | 5099 | } |
5117 | else if (floater_name == "mini map") | 5100 | else if (floater_name == "mini map") |
5118 | { | 5101 | { |
5119 | LLFloaterMap::toggle(NULL); | 5102 | LLFloaterMap::toggleInstance(); |
5120 | } | 5103 | } |
5121 | else if (floater_name == "stat bar") | 5104 | else if (floater_name == "stat bar") |
5122 | { | 5105 | { |
diff --git a/linden/indra/newview/llviewerobject.cpp b/linden/indra/newview/llviewerobject.cpp index b33b2bb..ca7055a 100644 --- a/linden/indra/newview/llviewerobject.cpp +++ b/linden/indra/newview/llviewerobject.cpp | |||
@@ -65,7 +65,6 @@ | |||
65 | #include "llface.h" | 65 | #include "llface.h" |
66 | #include "llfloaterproperties.h" | 66 | #include "llfloaterproperties.h" |
67 | #include "llfollowcam.h" | 67 | #include "llfollowcam.h" |
68 | #include "llnetmap.h" | ||
69 | #include "llselectmgr.h" | 68 | #include "llselectmgr.h" |
70 | #include "llrendersphere.h" | 69 | #include "llrendersphere.h" |
71 | #include "lltooldraganddrop.h" | 70 | #include "lltooldraganddrop.h" |
diff --git a/linden/indra/newview/llviewerregion.cpp b/linden/indra/newview/llviewerregion.cpp index 0018323..1c527e0 100644 --- a/linden/indra/newview/llviewerregion.cpp +++ b/linden/indra/newview/llviewerregion.cpp | |||
@@ -53,7 +53,6 @@ | |||
53 | #include "llfloaterreporter.h" | 53 | #include "llfloaterreporter.h" |
54 | #include "llfloaterregioninfo.h" | 54 | #include "llfloaterregioninfo.h" |
55 | #include "llhttpnode.h" | 55 | #include "llhttpnode.h" |
56 | #include "llnetmap.h" | ||
57 | #include "llsdutil.h" | 56 | #include "llsdutil.h" |
58 | #include "llstartup.h" | 57 | #include "llstartup.h" |
59 | #include "llviewerobjectlist.h" | 58 | #include "llviewerobjectlist.h" |
diff --git a/linden/indra/newview/llviewerwindow.cpp b/linden/indra/newview/llviewerwindow.cpp index 443bbd5..9b2c566 100644 --- a/linden/indra/newview/llviewerwindow.cpp +++ b/linden/indra/newview/llviewerwindow.cpp | |||
@@ -100,7 +100,6 @@ | |||
100 | #include "llfloatereditui.h" // HACK JAMESDEBUG for ui editor | 100 | #include "llfloatereditui.h" // HACK JAMESDEBUG for ui editor |
101 | #include "llfloaterland.h" | 101 | #include "llfloaterland.h" |
102 | #include "llfloaterinspect.h" | 102 | #include "llfloaterinspect.h" |
103 | #include "llfloatermap.h" | ||
104 | #include "llfloaternamedesc.h" | 103 | #include "llfloaternamedesc.h" |
105 | #include "llfloaterpreference.h" | 104 | #include "llfloaterpreference.h" |
106 | #include "llfloatersnapshot.h" | 105 | #include "llfloatersnapshot.h" |
@@ -1840,16 +1839,6 @@ void LLViewerWindow::initWorldUI() | |||
1840 | gHoverView = new LLHoverView(std::string("gHoverView"), full_window); | 1839 | gHoverView = new LLHoverView(std::string("gHoverView"), full_window); |
1841 | gHoverView->setVisible(TRUE); | 1840 | gHoverView->setVisible(TRUE); |
1842 | mRootView->addChild(gHoverView); | 1841 | mRootView->addChild(gHoverView); |
1843 | |||
1844 | // | ||
1845 | // Map | ||
1846 | // | ||
1847 | // TODO: Move instance management into class | ||
1848 | gFloaterMap = new LLFloaterMap(std::string("Map")); | ||
1849 | gFloaterMap->setFollows(FOLLOWS_TOP|FOLLOWS_RIGHT); | ||
1850 | |||
1851 | // keep onscreen | ||
1852 | gFloaterView->adjustToFitScreen(gFloaterMap, FALSE); | ||
1853 | 1842 | ||
1854 | gIMMgr = LLIMMgr::getInstance(); | 1843 | gIMMgr = LLIMMgr::getInstance(); |
1855 | 1844 | ||
@@ -1932,7 +1921,6 @@ void LLViewerWindow::shutdownViews() | |||
1932 | gFloaterView = NULL; | 1921 | gFloaterView = NULL; |
1933 | gMorphView = NULL; | 1922 | gMorphView = NULL; |
1934 | 1923 | ||
1935 | gFloaterMap = NULL; | ||
1936 | gHUDView = NULL; | 1924 | gHUDView = NULL; |
1937 | 1925 | ||
1938 | gNotifyBoxView = NULL; | 1926 | gNotifyBoxView = NULL; |
diff --git a/linden/indra/newview/llworldmapview.cpp b/linden/indra/newview/llworldmapview.cpp index 244ee22..73c2d8b 100644 --- a/linden/indra/newview/llworldmapview.cpp +++ b/linden/indra/newview/llworldmapview.cpp | |||
@@ -208,8 +208,6 @@ LLWorldMapView::LLWorldMapView(const std::string& name, const LLRect& rect ) | |||
208 | mTextBoxNorthWest = new LLTextBox( std::string("NW"), minor_dir_rect ); | 208 | mTextBoxNorthWest = new LLTextBox( std::string("NW"), minor_dir_rect ); |
209 | mTextBoxNorthWest->setColor( minor_color ); | 209 | mTextBoxNorthWest->setColor( minor_color ); |
210 | addChild( mTextBoxNorthWest ); | 210 | addChild( mTextBoxNorthWest ); |
211 | |||
212 | glyph_color_avatar = gColors.getColor("NetMapGlyphColorAvatar"); | ||
213 | } | 211 | } |
214 | 212 | ||
215 | 213 | ||
@@ -866,6 +864,9 @@ void LLWorldMapView::drawImageStack(const LLVector3d& global_pos, LLUIImagePtr i | |||
866 | void LLWorldMapView::drawAgents() | 864 | void LLWorldMapView::drawAgents() |
867 | { | 865 | { |
868 | F32 agents_scale = (gMapScale * 0.9f) / 256.f; | 866 | F32 agents_scale = (gMapScale * 0.9f) / 256.f; |
867 | |||
868 | LLColor4 avatar_color = gColors.getColor( "MapAvatar" ); | ||
869 | LLColor4 friend_color = gColors.getColor( "MapFriend" ); | ||
869 | 870 | ||
870 | for (handle_list_t::iterator iter = mVisibleRegions.begin(); iter != mVisibleRegions.end(); ++iter) | 871 | for (handle_list_t::iterator iter = mVisibleRegions.begin(); iter != mVisibleRegions.end(); ++iter) |
871 | { | 872 | { |
@@ -888,8 +889,8 @@ void LLWorldMapView::drawAgents() | |||
888 | S32 agent_count = info.mExtra; | 889 | S32 agent_count = info.mExtra; |
889 | sim_agent_count += info.mExtra; | 890 | sim_agent_count += info.mExtra; |
890 | // Here's how we'd choose the color if info.mID were available but it's not being sent: | 891 | // Here's how we'd choose the color if info.mID were available but it's not being sent: |
891 | //LLColor4 color = (agent_count == 1 && is_agent_friend(info.mID)) ? glyph_color_friend : glyph_color_avatar; | 892 | //LLColor4 color = (agent_count == 1 && is_agent_friend(info.mID)) ? friend_color : avatar_color; |
892 | drawImageStack(info.mPosGlobal, sAvatarSmallImage, agent_count, 3.f, glyph_color_avatar); | 893 | drawImageStack(info.mPosGlobal, sAvatarSmallImage, agent_count, 3.f, avatar_color); |
893 | } | 894 | } |
894 | LLWorldMap::getInstance()->mNumAgents[handle] = sim_agent_count; // override mNumAgents for this sim | 895 | LLWorldMap::getInstance()->mNumAgents[handle] = sim_agent_count; // override mNumAgents for this sim |
895 | } | 896 | } |
diff --git a/linden/indra/newview/skins/default/colors_base.xml b/linden/indra/newview/skins/default/colors_base.xml index ff3d53e..1f97a2e 100644 --- a/linden/indra/newview/skins/default/colors_base.xml +++ b/linden/indra/newview/skins/default/colors_base.xml | |||
@@ -155,8 +155,12 @@ | |||
155 | <!-- MEDIA ICONS --> | 155 | <!-- MEDIA ICONS --> |
156 | <IconEnabledColor value="255, 255, 255, 255"/> <!-- Media/music icon enabled --> | 156 | <IconEnabledColor value="255, 255, 255, 255"/> <!-- Media/music icon enabled --> |
157 | <IconDisabledColor value="147, 169, 213, 200"/> <!-- Media/music icon disabled --> | 157 | <IconDisabledColor value="147, 169, 213, 200"/> <!-- Media/music icon disabled --> |
158 | 158 | ||
159 | <!-- MINI-MAP --> | 159 | <!-- MAP --> |
160 | <MapAvatar value="0, 255, 0, 255" /> <!-- Your avatar's glyph color --> | ||
161 | <MapFriend value="255, 255, 0, 255" /> <!-- Your friends' glyph color --> | ||
162 | |||
163 | <!-- MINI-MAP --> | ||
160 | <NetMapBackgroundColor value="0, 0, 0, 77" /> <!-- Mini-map floater background --> | 164 | <NetMapBackgroundColor value="0, 0, 0, 77" /> <!-- Mini-map floater background --> |
161 | <NetMapYouOwnAboveWater value="0, 255, 255, 255" /> <!-- Objects owned by you above water --> | 165 | <NetMapYouOwnAboveWater value="0, 255, 255, 255" /> <!-- Objects owned by you above water --> |
162 | <NetMapYouOwnBelowWater value="0, 200, 200, 255" /> <!-- Objects owned by you below water --> | 166 | <NetMapYouOwnBelowWater value="0, 200, 200, 255" /> <!-- Objects owned by you below water --> |
@@ -164,10 +168,13 @@ | |||
164 | <NetMapGroupOwnBelowWater value="200, 0, 200, 255" /> <!-- Group owned objects below water --> | 168 | <NetMapGroupOwnBelowWater value="200, 0, 200, 255" /> <!-- Group owned objects below water --> |
165 | <NetMapOtherOwnAboveWater value="60, 60, 60, 255" /> <!-- Objects owned by others above water --> | 169 | <NetMapOtherOwnAboveWater value="60, 60, 60, 255" /> <!-- Objects owned by others above water --> |
166 | <NetMapOtherOwnBelowWater value="30, 30, 30, 255" /> <!-- Objects owned by others below water --> | 170 | <NetMapOtherOwnBelowWater value="30, 30, 30, 255" /> <!-- Objects owned by others below water --> |
167 | <NetMapGlyphColorAvatar value="0, 255, 0, 255" /> <!-- Also the color of avatar glyphs on the map --> | 171 | <NetMapThisRegion value="255, 255, 255, 255" /> |
168 | <NetMapGlyphColorFriend value="255, 255, 0, 255" /> | 172 | <NetMapLiveRegion value="204, 204, 204, 255" /> |
169 | 173 | <NetMapDeadRegion value="255, 128, 128, 255" /> | |
170 | <!-- INVENTORY --> | 174 | <NetMapFrustum value="255, 255, 255, 20" /> |
175 | <NetMapFrustumRotating value="255, 255, 255, 51" /> | ||
176 | |||
177 | <!-- INVENTORY --> | ||
171 | <InventoryBackgroundColor value="62, 62, 62, 80"/> <!-- Inventory floater background --> | 178 | <InventoryBackgroundColor value="62, 62, 62, 80"/> <!-- Inventory floater background --> |
172 | <FolderViewLoadingMessageTextColor value="240, 165, 90, 255"/> <!-- "loading..." --> | 179 | <FolderViewLoadingMessageTextColor value="240, 165, 90, 255"/> <!-- "loading..." --> |
173 | <InventoryItemSuffixColor value="191, 216, 216, 255"/> <!-- "worn", "no modify", etc --> | 180 | <InventoryItemSuffixColor value="191, 216, 216, 255"/> <!-- "worn", "no modify", etc --> |
diff --git a/linden/indra/newview/skins/silver/colors_base.xml b/linden/indra/newview/skins/silver/colors_base.xml index b6e77be..9ec721c 100644 --- a/linden/indra/newview/skins/silver/colors_base.xml +++ b/linden/indra/newview/skins/silver/colors_base.xml | |||
@@ -155,6 +155,10 @@ | |||
155 | <!-- MEDIA ICONS --> | 155 | <!-- MEDIA ICONS --> |
156 | <IconEnabledColor value="255, 255, 255, 255"/> <!-- Media/music icon enabled --> | 156 | <IconEnabledColor value="255, 255, 255, 255"/> <!-- Media/music icon enabled --> |
157 | <IconDisabledColor value="147, 169, 213, 200"/> <!-- Media/music icon disabled --> | 157 | <IconDisabledColor value="147, 169, 213, 200"/> <!-- Media/music icon disabled --> |
158 | |||
159 | <!-- MAP --> | ||
160 | <MapAvatar value="0, 255, 0, 255" /> <!-- Your avatar's glyph color --> | ||
161 | <MapFriend value="255, 255, 0, 255" /> <!-- Your friends' glyph color --> | ||
158 | 162 | ||
159 | <!-- MINI-MAP --> | 163 | <!-- MINI-MAP --> |
160 | <NetMapBackgroundColor value="0, 0, 0, 77" /> <!-- Mini-map floater background --> | 164 | <NetMapBackgroundColor value="0, 0, 0, 77" /> <!-- Mini-map floater background --> |
@@ -164,10 +168,13 @@ | |||
164 | <NetMapGroupOwnBelowWater value="200, 0, 200, 255" /> <!-- Group owned objects below water --> | 168 | <NetMapGroupOwnBelowWater value="200, 0, 200, 255" /> <!-- Group owned objects below water --> |
165 | <NetMapOtherOwnAboveWater value="60, 60, 60, 255" /> <!-- Objects owned by others above water --> | 169 | <NetMapOtherOwnAboveWater value="60, 60, 60, 255" /> <!-- Objects owned by others above water --> |
166 | <NetMapOtherOwnBelowWater value="30, 30, 30, 255" /> <!-- Objects owned by others below water --> | 170 | <NetMapOtherOwnBelowWater value="30, 30, 30, 255" /> <!-- Objects owned by others below water --> |
167 | <NetMapGlyphColorAvatar value="0, 255, 0, 255" /> <!-- Also the color of avatar glyphs on the map --> | 171 | <NetMapThisRegion value="255, 255, 255, 255" /> |
168 | <NetMapGlyphColorFriend value="255, 255, 0, 255" /> | 172 | <NetMapLiveRegion value="204, 204, 204, 255" /> |
169 | 173 | <NetMapDeadRegion value="255, 128, 128, 255" /> | |
170 | <!-- INVENTORY --> | 174 | <NetMapFrustum value="255, 255, 255, 20" /> |
175 | <NetMapFrustumRotating value="255, 255, 255, 51" /> | ||
176 | |||
177 | <!-- INVENTORY --> | ||
171 | <InventoryBackgroundColor value="255, 255, 255, 80"/> <!-- Inventory floater background --> | 178 | <InventoryBackgroundColor value="255, 255, 255, 80"/> <!-- Inventory floater background --> |
172 | <FolderViewLoadingMessageTextColor value="240, 165, 90, 255"/> <!-- "loading..." --> | 179 | <FolderViewLoadingMessageTextColor value="240, 165, 90, 255"/> <!-- "loading..." --> |
173 | <InventoryItemSuffixColor value="120, 70, 55, 255"/> <!-- "worn", "no modify", etc --> | 180 | <InventoryItemSuffixColor value="120, 70, 55, 255"/> <!-- "worn", "no modify", etc --> |