diff options
Diffstat (limited to 'linden/indra/newview/llfloatermap.cpp')
-rw-r--r-- | linden/indra/newview/llfloatermap.cpp | 79 |
1 files changed, 27 insertions, 52 deletions
diff --git a/linden/indra/newview/llfloatermap.cpp b/linden/indra/newview/llfloatermap.cpp index 1ec2020..e70f4f1 100644 --- a/linden/indra/newview/llfloatermap.cpp +++ b/linden/indra/newview/llfloatermap.cpp | |||
@@ -70,7 +70,6 @@ LLFloaterMap::LLFloaterMap(const LLSD& key) | |||
70 | LLUICtrlFactory::getInstance()->buildFloater(this, "floater_mini_map.xml", &factory_map, FALSE); | 70 | LLUICtrlFactory::getInstance()->buildFloater(this, "floater_mini_map.xml", &factory_map, FALSE); |
71 | 71 | ||
72 | mSelectedAvatar.setNull(); | 72 | mSelectedAvatar.setNull(); |
73 | mAvatars.clear(); | ||
74 | } | 73 | } |
75 | 74 | ||
76 | 75 | ||
@@ -195,7 +194,7 @@ void LLFloaterMap::updateRadar() | |||
195 | 194 | ||
196 | void LLFloaterMap::populateRadar() | 195 | void LLFloaterMap::populateRadar() |
197 | { | 196 | { |
198 | if (!mUpdate) | 197 | if (!mUpdate || !LLFloaterMap::getInstance()->getVisible()) |
199 | { | 198 | { |
200 | return; | 199 | return; |
201 | } | 200 | } |
@@ -218,8 +217,10 @@ void LLFloaterMap::populateRadar() | |||
218 | std::vector<LLVector3d> positions; | 217 | std::vector<LLVector3d> positions; |
219 | LLWorld::getInstance()->getAvatars(&avatar_ids, &positions, current_pos, gSavedSettings.getF32("NearMeRange")); | 218 | LLWorld::getInstance()->getAvatars(&avatar_ids, &positions, current_pos, gSavedSettings.getF32("NearMeRange")); |
220 | 219 | ||
221 | // Add avatars to the list. If they're already there, update positions | 220 | LLSD element; |
222 | std::pair<std::map<LLUUID, LLVector3d>::iterator, bool> ret; | 221 | |
222 | mRadarList->deleteAllItems(); | ||
223 | |||
223 | for (U32 i=0; i<avatar_ids.size(); i++) | 224 | for (U32 i=0; i<avatar_ids.size(); i++) |
224 | { | 225 | { |
225 | if (avatar_ids[i] == gAgent.getID() || | 226 | if (avatar_ids[i] == gAgent.getID() || |
@@ -228,50 +229,25 @@ void LLFloaterMap::populateRadar() | |||
228 | continue; | 229 | continue; |
229 | } | 230 | } |
230 | 231 | ||
231 | ret = mAvatars.insert(std::pair<LLUUID, LLVector3d>(avatar_ids[i], positions[i])); | 232 | // Add to list only if we get their name |
232 | if (ret.second == false) | 233 | std::string fullname = getSelectedName(avatar_ids[i]); |
234 | if (!fullname.empty() && fullname != " ") | ||
233 | { | 235 | { |
234 | mAvatars[avatar_ids[i]] = positions[i]; | 236 | std::string mute_text = LLMuteList::getInstance()->isMuted(avatar_ids[i]) ? getString("muted") : ""; |
235 | } | 237 | element["id"] = avatar_ids[i]; |
236 | } | 238 | element["columns"][0]["column"] = "avatar_name"; |
237 | 239 | element["columns"][0]["type"] = "text"; | |
238 | LLSD element; | 240 | element["columns"][0]["value"] = fullname + " " + mute_text; |
239 | 241 | element["columns"][1]["column"] = "avatar_distance"; | |
240 | mRadarList->deleteAllItems(); | 242 | element["columns"][1]["type"] = "text"; |
241 | 243 | ||
242 | // if an avatar's not in range anymore, kill it. Otherwise, populate radar | 244 | LLVector3d temp = positions[i] - current_pos; |
243 | std::map<LLUUID, LLVector3d>::iterator mIt; | 245 | F32 distance = (F32)temp.magVec(); |
244 | std::vector<LLUUID>::iterator result; | 246 | char dist[32]; |
245 | for (mIt = mAvatars.begin(); mIt != mAvatars.end(); ) | 247 | snprintf(dist, sizeof(dist), "%.1f", distance); |
246 | { | 248 | element["columns"][1]["value"] = strcat(dist,"m"); |
247 | result = find(avatar_ids.begin(), avatar_ids.end(), mIt->first); | 249 | |
248 | if (result == avatar_ids.end()) | 250 | mRadarList->addElement(element, ADD_BOTTOM); |
249 | { | ||
250 | mAvatars.erase(mIt++); | ||
251 | } | ||
252 | else | ||
253 | { | ||
254 | // Add to list only if we get their name | ||
255 | std::string fullname = getSelectedName(mIt->first); | ||
256 | if (!fullname.empty() && fullname != " ") | ||
257 | { | ||
258 | std::string mute_text = LLMuteList::getInstance()->isMuted(mIt->first) ? getString("muted") : ""; | ||
259 | element["id"] = mIt->first; | ||
260 | element["columns"][0]["column"] = "avatar_name"; | ||
261 | element["columns"][0]["type"] = "text"; | ||
262 | element["columns"][0]["value"] = fullname + " " + mute_text; | ||
263 | element["columns"][1]["column"] = "avatar_distance"; | ||
264 | element["columns"][1]["type"] = "text"; | ||
265 | |||
266 | F64 distance = dist_vec(current_pos, mIt->second); | ||
267 | std::stringstream dist_formatted; | ||
268 | dist_formatted.str(""); | ||
269 | dist_formatted << (double)((int)((distance + 0.05)*10.0))/10.0 << "m"; | ||
270 | element["columns"][1]["value"] = dist_formatted.str(); | ||
271 | |||
272 | mRadarList->addElement(element, ADD_BOTTOM); | ||
273 | } | ||
274 | ++mIt; | ||
275 | } | 251 | } |
276 | } | 252 | } |
277 | 253 | ||
@@ -285,28 +261,27 @@ void LLFloaterMap::populateRadar() | |||
285 | // set count | 261 | // set count |
286 | std::stringstream avatar_count; | 262 | std::stringstream avatar_count; |
287 | avatar_count.str(""); | 263 | avatar_count.str(""); |
288 | if (mAvatars.empty()) | 264 | if (avatar_ids.empty()) |
289 | { | 265 | { |
290 | mRadarList->addCommentText(getString("no_one_near"), ADD_TOP); | 266 | mRadarList->addCommentText(getString("no_one_near"), ADD_TOP); |
291 | avatar_count << "0"; | 267 | avatar_count << "0"; |
292 | } | 268 | } |
293 | else | 269 | else |
294 | { | 270 | { |
295 | avatar_count << (int)mAvatars.size(); | 271 | avatar_count << (int)avatar_ids.size(); |
296 | } | 272 | } |
297 | childSetText("lblAvatarCount", avatar_count.str()); | 273 | childSetText("lblAvatarCount", avatar_count.str()); |
298 | 274 | ||
299 | toggleButtons(); | 275 | toggleButtons(); |
300 | 276 | ||
301 | //llinfos << "mSelectedAvatar: " << mSelectedAvatar.asString() << llendl; | 277 | //llinfos << "mSelectedAvatar: " << mSelectedAvatar.asString() << llendl; |
302 | } | 278 | } |
303 | 279 | ||
304 | void LLFloaterMap::toggleButtons() | 280 | void LLFloaterMap::toggleButtons() |
305 | { | 281 | { |
306 | BOOL enabled = FALSE; | 282 | BOOL enabled = FALSE; |
307 | BOOL unmute_enabled = FALSE; | 283 | BOOL unmute_enabled = FALSE; |
308 | LLPanel* panelp = getChild<LLPanel>("RadarPanel"); | 284 | if (childHasFocus("RadarPanel")) |
309 | if (panelp->hasFocus()) | ||
310 | { | 285 | { |
311 | enabled = mSelectedAvatar.notNull() ? visibleItemsSelected() : FALSE; | 286 | enabled = mSelectedAvatar.notNull() ? visibleItemsSelected() : FALSE; |
312 | unmute_enabled = mSelectedAvatar.notNull() ? LLMuteList::getInstance()->isMuted(mSelectedAvatar) : FALSE; | 287 | unmute_enabled = mSelectedAvatar.notNull() ? LLMuteList::getInstance()->isMuted(mSelectedAvatar) : FALSE; |