diff options
author | McCabe Maxsted | 2009-10-08 02:01:55 -0700 |
---|---|---|
committer | McCabe Maxsted | 2009-10-08 02:01:55 -0700 |
commit | 64d298ac17b47805f3deec99fc911bd8f73a9d2d (patch) | |
tree | 27e9a8e783c8e93129f8759e80bbef1f6d43640c /linden/indra | |
parent | Added typing info to mini-map radar (diff) | |
download | meta-impy-64d298ac17b47805f3deec99fc911bd8f73a9d2d.zip meta-impy-64d298ac17b47805f3deec99fc911bd8f73a9d2d.tar.gz meta-impy-64d298ac17b47805f3deec99fc911bd8f73a9d2d.tar.bz2 meta-impy-64d298ac17b47805f3deec99fc911bd8f73a9d2d.tar.xz |
Mini-map radar now can notify you when someone enters the sim
Diffstat (limited to 'linden/indra')
-rw-r--r-- | linden/indra/newview/app_settings/settings.xml | 13 | ||||
-rw-r--r-- | linden/indra/newview/llfloatermap.cpp | 73 | ||||
-rw-r--r-- | linden/indra/newview/llfloatermap.h | 12 | ||||
-rw-r--r-- | linden/indra/newview/llpanelgeneral.cpp | 6 | ||||
-rw-r--r-- | linden/indra/newview/skins/default/xui/en-us/floater_mini_map.xml | 3 | ||||
-rw-r--r-- | linden/indra/newview/skins/default/xui/en-us/panel_preferences_general.xml | 17 |
6 files changed, 116 insertions, 8 deletions
diff --git a/linden/indra/newview/app_settings/settings.xml b/linden/indra/newview/app_settings/settings.xml index 8ffcb19..f167840 100644 --- a/linden/indra/newview/app_settings/settings.xml +++ b/linden/indra/newview/app_settings/settings.xml | |||
@@ -5088,7 +5088,7 @@ | |||
5088 | <key>Value</key> | 5088 | <key>Value</key> |
5089 | <integer>1</integer> | 5089 | <integer>1</integer> |
5090 | </map> | 5090 | </map> |
5091 | <key>MiniMapNotify</key> | 5091 | <key>MiniMapNotifyChatRange</key> |
5092 | <map> | 5092 | <map> |
5093 | <key>Comment</key> | 5093 | <key>Comment</key> |
5094 | <string>Notify when avatars enter chat range</string> | 5094 | <string>Notify when avatars enter chat range</string> |
@@ -5099,6 +5099,17 @@ | |||
5099 | <key>Value</key> | 5099 | <key>Value</key> |
5100 | <integer>1</integer> | 5100 | <integer>1</integer> |
5101 | </map> | 5101 | </map> |
5102 | <key>MiniMapNotifySimRange</key> | ||
5103 | <map> | ||
5104 | <key>Comment</key> | ||
5105 | <string>Notify when avatars enters the current sim</string> | ||
5106 | <key>Persist</key> | ||
5107 | <integer>1</integer> | ||
5108 | <key>Type</key> | ||
5109 | <string>Boolean</string> | ||
5110 | <key>Value</key> | ||
5111 | <integer>0</integer> | ||
5112 | </map> | ||
5102 | <key>MiniMapPrimMaxRadius</key> | 5113 | <key>MiniMapPrimMaxRadius</key> |
5103 | <map> | 5114 | <map> |
5104 | <key>Comment</key> | 5115 | <key>Comment</key> |
diff --git a/linden/indra/newview/llfloatermap.cpp b/linden/indra/newview/llfloatermap.cpp index ae5b2b6..142d8fe 100644 --- a/linden/indra/newview/llfloatermap.cpp +++ b/linden/indra/newview/llfloatermap.cpp | |||
@@ -266,10 +266,14 @@ void LLFloaterMap::populateRadar() | |||
266 | std::string fullname = getSelectedName(avatar_ids[i]); | 266 | std::string fullname = getSelectedName(avatar_ids[i]); |
267 | if (!fullname.empty()) | 267 | if (!fullname.empty()) |
268 | { | 268 | { |
269 | bool notify_chat = gSavedSettings.getBOOL("MiniMapNotifyChatRange"); | ||
270 | bool notify_sim = gSavedSettings.getBOOL("MiniMapNotifySimRange"); | ||
269 | // [RLVa:KB] - Alternate: Imprudence-1.2.0 | 271 | // [RLVa:KB] - Alternate: Imprudence-1.2.0 |
270 | if (gRlvHandler.hasBehaviour(RLV_BHVR_SHOWNAMES)) | 272 | if (gRlvHandler.hasBehaviour(RLV_BHVR_SHOWNAMES)) |
271 | { | 273 | { |
272 | fullname = gRlvHandler.getAnonym(fullname); | 274 | fullname = gRlvHandler.getAnonym(fullname); |
275 | notify_chat = false; | ||
276 | notify_sim = false; | ||
273 | } | 277 | } |
274 | // [/RLVa:KB] | 278 | // [/RLVa:KB] |
275 | 279 | ||
@@ -280,7 +284,7 @@ void LLFloaterMap::populateRadar() | |||
280 | sprintf(dist, "%.1f", distance); | 284 | sprintf(dist, "%.1f", distance); |
281 | std::string dist_string = dist; | 285 | std::string dist_string = dist; |
282 | 286 | ||
283 | if (gSavedSettings.getBOOL("MiniMapNotify")) | 287 | if (notify_chat) |
284 | { | 288 | { |
285 | if (distance < 20.0f) | 289 | if (distance < 20.0f) |
286 | { | 290 | { |
@@ -304,6 +308,31 @@ void LLFloaterMap::populateRadar() | |||
304 | mChatAvatars.clear(); | 308 | mChatAvatars.clear(); |
305 | } | 309 | } |
306 | 310 | ||
311 | // announce their presence in the sim if we've enabled that | ||
312 | if (notify_sim) | ||
313 | { | ||
314 | if (!getInChatList(avatar_ids[i]) && !getInSimAvList(avatar_ids[i])) | ||
315 | { | ||
316 | LLViewerObject *av_obj = gObjectList.findObject(avatar_ids[i]); | ||
317 | if (av_obj != NULL && av_obj->isAvatar()) | ||
318 | { | ||
319 | LLVOAvatar* avatarp = (LLVOAvatar*)av_obj; | ||
320 | if (avatarp != NULL) | ||
321 | { | ||
322 | if (avatarp->getRegion() == gAgent.getRegion()) | ||
323 | { | ||
324 | addToSimAvList(avatar_ids[i], dist_string); | ||
325 | } | ||
326 | } | ||
327 | } | ||
328 | } | ||
329 | updateSimAvList(avatar_ids); | ||
330 | } | ||
331 | else if (!mSimAvatars.empty()) | ||
332 | { | ||
333 | mSimAvatars.clear(); | ||
334 | } | ||
335 | |||
307 | // append typing string | 336 | // append typing string |
308 | std::string typing = ""; | 337 | std::string typing = ""; |
309 | if (getIsTyping(avatar_ids[i])) | 338 | if (getIsTyping(avatar_ids[i])) |
@@ -334,6 +363,7 @@ void LLFloaterMap::populateRadar() | |||
334 | } | 363 | } |
335 | else | 364 | else |
336 | { | 365 | { |
366 | mTypingAvatars.clear(); | ||
337 | mRadarList->addCommentText(getString("no_one_near"), ADD_TOP); | 367 | mRadarList->addCommentText(getString("no_one_near"), ADD_TOP); |
338 | avatar_count << "0"; | 368 | avatar_count << "0"; |
339 | } | 369 | } |
@@ -416,6 +446,47 @@ void LLFloaterMap::updateTypingList(LLUUID agent_id, bool remove) | |||
416 | } | 446 | } |
417 | } | 447 | } |
418 | 448 | ||
449 | void LLFloaterMap::updateSimAvList(std::vector<LLUUID> agent_ids) | ||
450 | { | ||
451 | std::set<LLUUID>::iterator it; | ||
452 | std::vector<LLUUID>::iterator result; | ||
453 | for (it = mSimAvatars.begin(); it != mSimAvatars.end(); ) | ||
454 | { | ||
455 | result = find(agent_ids.begin(), agent_ids.end(), *it); | ||
456 | if (result == agent_ids.end()) | ||
457 | { | ||
458 | mSimAvatars.erase(it++); | ||
459 | } | ||
460 | else | ||
461 | { | ||
462 | it++; | ||
463 | } | ||
464 | } | ||
465 | } | ||
466 | |||
467 | void LLFloaterMap::addToSimAvList(LLUUID agent_id, std::string distance) | ||
468 | { | ||
469 | mSimAvatars.insert(agent_id); | ||
470 | LLChat chat; | ||
471 | |||
472 | LLUIString notify = getString("entering_sim_range"); | ||
473 | notify.setArg("[NAME]", getSelectedName(agent_id)); | ||
474 | notify.setArg("[DISTANCE]", distance); | ||
475 | |||
476 | chat.mText = notify; | ||
477 | chat.mSourceType = CHAT_SOURCE_SYSTEM; | ||
478 | LLFloaterChat::addChat(chat, FALSE, FALSE); | ||
479 | } | ||
480 | |||
481 | bool LLFloaterMap::getInSimAvList(LLUUID agent_id) | ||
482 | { | ||
483 | if (mSimAvatars.count(agent_id) > 0) | ||
484 | { | ||
485 | return true; | ||
486 | } | ||
487 | return false; | ||
488 | } | ||
489 | |||
419 | void LLFloaterMap::toggleButtons() | 490 | void LLFloaterMap::toggleButtons() |
420 | { | 491 | { |
421 | BOOL enable = FALSE; | 492 | BOOL enable = FALSE; |
diff --git a/linden/indra/newview/llfloatermap.h b/linden/indra/newview/llfloatermap.h index 6e44a1e..af4d1cc 100644 --- a/linden/indra/newview/llfloatermap.h +++ b/linden/indra/newview/llfloatermap.h | |||
@@ -67,13 +67,19 @@ public: | |||
67 | 67 | ||
68 | 68 | ||
69 | private: | 69 | private: |
70 | |||
70 | LLFloaterMap(const LLSD& key = LLSD()); | 71 | LLFloaterMap(const LLSD& key = LLSD()); |
71 | 72 | ||
72 | LLNetMap* mPanelMap; | 73 | LLNetMap* mPanelMap; |
73 | LLScrollListCtrl* mRadarList; | 74 | LLScrollListCtrl* mRadarList; |
74 | LLUUID mSelectedAvatar; | 75 | LLUUID mSelectedAvatar; |
76 | |||
77 | // TODO: move all this info into its own object. It's stupid | ||
78 | // and bug-prone to keep it all in separate containers, but | ||
79 | // I want to get this out for 1.2 -- McCabe | ||
75 | std::set<LLUUID> mChatAvatars; | 80 | std::set<LLUUID> mChatAvatars; |
76 | std::set<LLUUID> mTypingAvatars; | 81 | std::set<LLUUID> mTypingAvatars; |
82 | std::set<LLUUID> mSimAvatars; | ||
77 | bool mUpdate; | 83 | bool mUpdate; |
78 | 84 | ||
79 | static void onList(LLUICtrl* ctrl, void* user_data); | 85 | static void onList(LLUICtrl* ctrl, void* user_data); |
@@ -88,6 +94,10 @@ private: | |||
88 | void addToChatList(LLUUID agent_id, std::string distance); | 94 | void addToChatList(LLUUID agent_id, std::string distance); |
89 | void removeFromChatList(LLUUID agent_id); | 95 | void removeFromChatList(LLUUID agent_id); |
90 | 96 | ||
97 | bool getInSimAvList(LLUUID agent_id); | ||
98 | void addToSimAvList(LLUUID agent_id, std::string distance); | ||
99 | void updateSimAvList(std::vector<LLUUID> agent_ids); | ||
100 | |||
91 | static void onClickProfile(void* user_data); | 101 | static void onClickProfile(void* user_data); |
92 | static void onClickIM(void* user_data); | 102 | static void onClickIM(void* user_data); |
93 | static void onClickAddFriend(void* user_data); | 103 | static void onClickAddFriend(void* user_data); |
diff --git a/linden/indra/newview/llpanelgeneral.cpp b/linden/indra/newview/llpanelgeneral.cpp index 4cf4091..04b7afe 100644 --- a/linden/indra/newview/llpanelgeneral.cpp +++ b/linden/indra/newview/llpanelgeneral.cpp | |||
@@ -60,7 +60,8 @@ BOOL LLPanelGeneral::postBuild() | |||
60 | childSetValue("small_avatar_names_checkbox", gSavedSettings.getBOOL("SmallAvatarNames")); | 60 | childSetValue("small_avatar_names_checkbox", gSavedSettings.getBOOL("SmallAvatarNames")); |
61 | childSetValue("show_my_title_checkbox", gSavedSettings.getBOOL("RenderHideGroupTitle")); | 61 | childSetValue("show_my_title_checkbox", gSavedSettings.getBOOL("RenderHideGroupTitle")); |
62 | childSetValue("afk_timeout_spinner", gSavedSettings.getF32("AFKTimeout")); | 62 | childSetValue("afk_timeout_spinner", gSavedSettings.getF32("AFKTimeout")); |
63 | childSetValue("mini_map_notify", gSavedSettings.getBOOL("MiniMapNotify")); | 63 | childSetValue("mini_map_notify_chat", gSavedSettings.getBOOL("MiniMapNotifyChatRange")); |
64 | childSetValue("mini_map_notify_sim", gSavedSettings.getBOOL("MiniMapNotifySimRange")); | ||
64 | childSetValue("notify_money_change_checkbox", gSavedSettings.getBOOL("NotifyMoneyChange")); | 65 | childSetValue("notify_money_change_checkbox", gSavedSettings.getBOOL("NotifyMoneyChange")); |
65 | childSetValue("use_system_color_picker_checkbox", gSavedSettings.getBOOL("UseDefaultColorPicker")); | 66 | childSetValue("use_system_color_picker_checkbox", gSavedSettings.getBOOL("UseDefaultColorPicker")); |
66 | childSetValue("show_search_panel", gSavedSettings.getBOOL("ShowSearchBar")); | 67 | childSetValue("show_search_panel", gSavedSettings.getBOOL("ShowSearchBar")); |
@@ -98,7 +99,8 @@ void LLPanelGeneral::apply() | |||
98 | gSavedSettings.setBOOL("SmallAvatarNames", childGetValue("small_avatar_names_checkbox")); | 99 | gSavedSettings.setBOOL("SmallAvatarNames", childGetValue("small_avatar_names_checkbox")); |
99 | gSavedSettings.setBOOL("RenderHideGroupTitle", childGetValue("show_my_title_checkbox")); | 100 | gSavedSettings.setBOOL("RenderHideGroupTitle", childGetValue("show_my_title_checkbox")); |
100 | gSavedSettings.setF32("AFKTimeout", childGetValue("afk_timeout_spinner").asReal()); | 101 | gSavedSettings.setF32("AFKTimeout", childGetValue("afk_timeout_spinner").asReal()); |
101 | gSavedSettings.setBOOL("MiniMapNotify", childGetValue("mini_map_notify")); | 102 | gSavedSettings.setBOOL("MiniMapNotifyChatRange", childGetValue("mini_map_notify_chat")); |
103 | gSavedSettings.setBOOL("MiniMapNotifySimRange", childGetValue("mini_map_notify_sim")); | ||
102 | gSavedSettings.setBOOL("NotifyMoneyChange", childGetValue("notify_money_change_checkbox")); | 104 | gSavedSettings.setBOOL("NotifyMoneyChange", childGetValue("notify_money_change_checkbox")); |
103 | gSavedSettings.setBOOL("UseDefaultColorPicker", childGetValue("use_system_color_picker_checkbox")); | 105 | gSavedSettings.setBOOL("UseDefaultColorPicker", childGetValue("use_system_color_picker_checkbox")); |
104 | gSavedSettings.setBOOL("ShowSearchBar", childGetValue("show_search_panel")); | 106 | gSavedSettings.setBOOL("ShowSearchBar", childGetValue("show_search_panel")); |
diff --git a/linden/indra/newview/skins/default/xui/en-us/floater_mini_map.xml b/linden/indra/newview/skins/default/xui/en-us/floater_mini_map.xml index dd9c324..3baec3f 100644 --- a/linden/indra/newview/skins/default/xui/en-us/floater_mini_map.xml +++ b/linden/indra/newview/skins/default/xui/en-us/floater_mini_map.xml | |||
@@ -101,4 +101,7 @@ | |||
101 | <string name="entering_chat_range"> | 101 | <string name="entering_chat_range"> |
102 | [NAME] has entered chat range ([DISTANCE]m) | 102 | [NAME] has entered chat range ([DISTANCE]m) |
103 | </string> | 103 | </string> |
104 | <string name="entering_sim_range"> | ||
105 | [NAME] has entered the sim ([DISTANCE]m) | ||
106 | </string> | ||
104 | </floater> | 107 | </floater> |
diff --git a/linden/indra/newview/skins/default/xui/en-us/panel_preferences_general.xml b/linden/indra/newview/skins/default/xui/en-us/panel_preferences_general.xml index 56bdb28..0c18a62 100644 --- a/linden/indra/newview/skins/default/xui/en-us/panel_preferences_general.xml +++ b/linden/indra/newview/skins/default/xui/en-us/panel_preferences_general.xml | |||
@@ -77,11 +77,22 @@ | |||
77 | follows="left|top" height="16" increment="1" initial_val="300" | 77 | follows="left|top" height="16" increment="1" initial_val="300" |
78 | label="Away Timeout:" label_width="141" left="10" max_val="600" | 78 | label="Away Timeout:" label_width="141" left="10" max_val="600" |
79 | min_val="30" mouse_opaque="true" name="afk_timeout_spinner" width="202" /> | 79 | min_val="30" mouse_opaque="true" name="afk_timeout_spinner" width="202" /> |
80 | <check_box bottom_delta="-25" enabled="true" | 80 | <text type="string" length="1" bg_visible="false" border_drop_shadow_visible="false" border_visible="false" |
81 | bottom_delta="-25" drop_shadow_visible="true" enabled="true" follows="left|top" | ||
82 | font="SansSerifSmall" h_pad="0" halign="left" height="12" left="10" | ||
83 | mouse_opaque="true" name="UI Size:" v_pad="0" width="128"> | ||
84 | Mini-map notify: | ||
85 | </text> | ||
86 | <check_box bottom_delta="0" enabled="true" | ||
81 | follows="left|top" font="SansSerifSmall" height="16" initial_value="false" | 87 | follows="left|top" font="SansSerifSmall" height="16" initial_value="false" |
82 | label="Display mini-map messages in chat" left="151" | 88 | label="Entering chat range" left="151" |
83 | mouse_opaque="true" name="mini_map_notify" radio_style="false" | 89 | mouse_opaque="true" name="mini_map_notify_chat" radio_style="false" |
84 | width="256" /> | 90 | width="256" /> |
91 | <check_box bottom_delta="0" enabled="true" | ||
92 | follows="left|top" font="SansSerifSmall" height="16" initial_value="false" | ||
93 | label="Entering sim" left="330" | ||
94 | mouse_opaque="true" name="mini_map_notify_sim" radio_style="false" | ||
95 | width="256" /> | ||
85 | <check_box bottom="-304" enabled="true" | 96 | <check_box bottom="-304" enabled="true" |
86 | follows="left|top" font="SansSerifSmall" height="16" initial_value="false" | 97 | follows="left|top" font="SansSerifSmall" height="16" initial_value="false" |
87 | label="Notify when Linden dollars (L$) spent or received" left="151" | 98 | label="Notify when Linden dollars (L$) spent or received" left="151" |