diff options
Diffstat (limited to 'linden/indra/newview/llfloatermap.cpp')
-rw-r--r-- | linden/indra/newview/llfloatermap.cpp | 291 |
1 files changed, 245 insertions, 46 deletions
diff --git a/linden/indra/newview/llfloatermap.cpp b/linden/indra/newview/llfloatermap.cpp index 6d23ab4..0ee0f2b 100644 --- a/linden/indra/newview/llfloatermap.cpp +++ b/linden/indra/newview/llfloatermap.cpp | |||
@@ -43,8 +43,10 @@ | |||
43 | #include "lluictrlfactory.h" | 43 | #include "lluictrlfactory.h" |
44 | 44 | ||
45 | // radar | 45 | // radar |
46 | #include "llchat.h" | ||
46 | #include "llfirstuse.h" | 47 | #include "llfirstuse.h" |
47 | #include "llfloateravatarinfo.h" | 48 | #include "llfloateravatarinfo.h" |
49 | #include "llfloaterchat.h" | ||
48 | #include "llfloaterfriends.h" | 50 | #include "llfloaterfriends.h" |
49 | #include "llfloatergroupinvite.h" | 51 | #include "llfloatergroupinvite.h" |
50 | #include "llfloatergroups.h" | 52 | #include "llfloatergroups.h" |
@@ -69,13 +71,16 @@ LLFloaterMap::LLFloaterMap(const LLSD& key) | |||
69 | : | 71 | : |
70 | LLFloater(std::string("minimap")), | 72 | LLFloater(std::string("minimap")), |
71 | mPanelMap(NULL), | 73 | mPanelMap(NULL), |
72 | mUpdate(TRUE) | 74 | mUpdate(TRUE), |
75 | mSelectedAvatar(LLUUID::null) | ||
76 | |||
73 | { | 77 | { |
74 | LLCallbackMap::map_t factory_map; | 78 | LLCallbackMap::map_t factory_map; |
75 | factory_map["mini_mapview"] = LLCallbackMap(createPanelMiniMap, this); | 79 | factory_map["mini_mapview"] = LLCallbackMap(createPanelMiniMap, this); |
76 | LLUICtrlFactory::getInstance()->buildFloater(this, "floater_mini_map.xml", &factory_map, FALSE); | 80 | LLUICtrlFactory::getInstance()->buildFloater(this, "floater_mini_map.xml", &factory_map, FALSE); |
77 | 81 | ||
78 | mSelectedAvatar.setNull(); | 82 | mChatAvatars.clear(); |
83 | mTypingAvatars.clear(); | ||
79 | } | 84 | } |
80 | 85 | ||
81 | 86 | ||
@@ -194,6 +199,21 @@ void LLFloaterMap::open() | |||
194 | */ | 199 | */ |
195 | 200 | ||
196 | //static | 201 | //static |
202 | bool LLFloaterMap::isImpDev(LLUUID agent_id) | ||
203 | { | ||
204 | // We use strings here as avatar keys change across grids. | ||
205 | // Feel free to add/remove yourself. | ||
206 | std::string agent_name = getSelectedName(agent_id); | ||
207 | if (agent_name == "McCabe Maxsted" || | ||
208 | agent_name == "Jacek Antonelli" || | ||
209 | agent_name == "Armin Weatherwax") | ||
210 | { | ||
211 | return true; | ||
212 | } | ||
213 | return false; | ||
214 | } | ||
215 | |||
216 | //static | ||
197 | void LLFloaterMap::updateRadar() | 217 | void LLFloaterMap::updateRadar() |
198 | { | 218 | { |
199 | LLFloaterMap::getInstance()->populateRadar(); | 219 | LLFloaterMap::getInstance()->populateRadar(); |
@@ -217,78 +237,257 @@ void LLFloaterMap::populateRadar() | |||
217 | 237 | ||
218 | S32 scroll_pos = mRadarList->getScrollPos(); | 238 | S32 scroll_pos = mRadarList->getScrollPos(); |
219 | 239 | ||
220 | LLVector3d current_pos = gAgent.getPositionGlobal(); | 240 | // clear count |
241 | std::stringstream avatar_count; | ||
242 | avatar_count.str(""); | ||
221 | 243 | ||
222 | // find what avatars you can see | 244 | // find what avatars you can see |
245 | F32 range = gSavedSettings.getF32("NearMeRange"); | ||
246 | LLVector3d current_pos = gAgent.getPositionGlobal(); | ||
223 | std::vector<LLUUID> avatar_ids; | 247 | std::vector<LLUUID> avatar_ids; |
224 | std::vector<LLVector3d> positions; | 248 | std::vector<LLVector3d> positions; |
225 | LLWorld::getInstance()->getAvatars(&avatar_ids, &positions, current_pos, gSavedSettings.getF32("NearMeRange")); | 249 | LLWorld::getInstance()->getAvatars(&avatar_ids, &positions); |
226 | 250 | ||
227 | LLSD element; | 251 | LLSD element; |
228 | 252 | ||
229 | mRadarList->deleteAllItems(); | 253 | mRadarList->deleteAllItems(); |
230 | 254 | ||
231 | for (U32 i=0; i<avatar_ids.size(); i++) | 255 | if (!avatar_ids.empty()) |
232 | { | 256 | { |
233 | if (avatar_ids[i] == gAgent.getID() || | 257 | for (U32 i=0; i<avatar_ids.size(); i++) |
234 | avatar_ids[i].isNull()) | ||
235 | { | 258 | { |
236 | continue; | 259 | if (avatar_ids[i] == gAgent.getID() || |
237 | } | 260 | avatar_ids[i].isNull()) |
261 | { | ||
262 | continue; | ||
263 | } | ||
238 | 264 | ||
239 | // Add to list only if we get their name | 265 | // Add to list only if we get their name |
240 | std::string fullname = getSelectedName(avatar_ids[i]); | 266 | std::string fullname = getSelectedName(avatar_ids[i]); |
241 | if (!fullname.empty()) | 267 | if (!fullname.empty()) |
242 | { | ||
243 | // [RLVa:KB] - Alternate: Imprudence-1.2.0 | ||
244 | if (gRlvHandler.hasBehaviour(RLV_BHVR_SHOWNAMES)) | ||
245 | { | 268 | { |
246 | fullname = gRlvHandler.getAnonym(fullname); | 269 | bool notify_chat = gSavedSettings.getBOOL("MiniMapNotifyChatRange"); |
270 | bool notify_sim = gSavedSettings.getBOOL("MiniMapNotifySimRange"); | ||
271 | // [RLVa:KB] - Alternate: Imprudence-1.2.0 | ||
272 | if (gRlvHandler.hasBehaviour(RLV_BHVR_SHOWNAMES)) | ||
273 | { | ||
274 | fullname = gRlvHandler.getAnonym(fullname); | ||
275 | notify_chat = false; | ||
276 | notify_sim = false; | ||
277 | } | ||
278 | // [/RLVa:KB] | ||
279 | |||
280 | // check if they're in certain ranges and notify user if we've enabled that | ||
281 | LLVector3d temp = positions[i] - current_pos; | ||
282 | F32 distance = llround((F32)temp.magVec(), 0.1f); | ||
283 | /*char dist[32]; | ||
284 | sprintf(dist, "%.1f", distance); | ||
285 | std::string dist_string = dist;*/ | ||
286 | std::string dist_string = llformat("%.1f", distance); | ||
287 | |||
288 | if (notify_chat) | ||
289 | { | ||
290 | if (distance < 20.0f) | ||
291 | { | ||
292 | if (!getInChatList(avatar_ids[i])) | ||
293 | { | ||
294 | addToChatList(avatar_ids[i], dist_string); | ||
295 | } | ||
296 | } | ||
297 | else | ||
298 | { | ||
299 | if (getInChatList(avatar_ids[i])) | ||
300 | { | ||
301 | removeFromChatList(avatar_ids[i]); | ||
302 | } | ||
303 | } | ||
304 | updateChatList(avatar_ids); | ||
305 | } | ||
306 | else if (!mChatAvatars.empty()) | ||
307 | { | ||
308 | mChatAvatars.clear(); | ||
309 | } | ||
310 | |||
311 | if (notify_sim) | ||
312 | { | ||
313 | if (!getInChatList(avatar_ids[i]) && !getInSimAvList(avatar_ids[i])) | ||
314 | { | ||
315 | LLViewerObject *av_obj = gObjectList.findObject(avatar_ids[i]); | ||
316 | if (av_obj != NULL && av_obj->isAvatar()) | ||
317 | { | ||
318 | LLVOAvatar* avatarp = (LLVOAvatar*)av_obj; | ||
319 | if (avatarp != NULL) | ||
320 | { | ||
321 | if (avatarp->getRegion() == gAgent.getRegion()) | ||
322 | { | ||
323 | addToSimAvList(avatar_ids[i], dist_string); | ||
324 | } | ||
325 | } | ||
326 | } | ||
327 | } | ||
328 | updateSimAvList(avatar_ids); | ||
329 | } | ||
330 | else if (!mSimAvatars.empty()) | ||
331 | { | ||
332 | mSimAvatars.clear(); | ||
333 | } | ||
334 | |||
335 | // only display avatars in range | ||
336 | if (distance <= range) | ||
337 | { | ||
338 | // append typing string | ||
339 | std::string typing = ""; | ||
340 | if (getIsTyping(avatar_ids[i])) | ||
341 | { | ||
342 | typing = getString("is_typing")+ " "; | ||
343 | } | ||
344 | |||
345 | std::string mute_text = LLMuteList::getInstance()->isMuted(avatar_ids[i]) ? getString("is_muted") : ""; | ||
346 | element["id"] = avatar_ids[i]; | ||
347 | element["columns"][0]["column"] = "avatar_name"; | ||
348 | element["columns"][0]["type"] = "text"; | ||
349 | element["columns"][0]["value"] = typing + fullname + " " + mute_text; | ||
350 | element["columns"][1]["column"] = "avatar_distance"; | ||
351 | element["columns"][1]["type"] = "text"; | ||
352 | element["columns"][1]["value"] = dist_string+"m"; | ||
353 | |||
354 | mRadarList->addElement(element, ADD_BOTTOM); | ||
355 | } | ||
247 | } | 356 | } |
248 | // [/RLVa:KB] | 357 | } |
249 | 358 | ||
250 | std::string mute_text = LLMuteList::getInstance()->isMuted(avatar_ids[i]) ? getString("muted") : ""; | 359 | mRadarList->sortItems(); |
251 | element["id"] = avatar_ids[i]; | 360 | mRadarList->setScrollPos(scroll_pos); |
252 | element["columns"][0]["column"] = "avatar_name"; | 361 | if (mSelectedAvatar.notNull()) |
253 | element["columns"][0]["type"] = "text"; | 362 | { |
254 | element["columns"][0]["value"] = fullname + " " + mute_text; | 363 | mRadarList->selectByID(mSelectedAvatar); |
255 | element["columns"][1]["column"] = "avatar_distance"; | ||
256 | element["columns"][1]["type"] = "text"; | ||
257 | |||
258 | LLVector3d temp = positions[i] - current_pos; | ||
259 | F32 distance = (F32)temp.magVec(); | ||
260 | char dist[32]; | ||
261 | snprintf(dist, sizeof(dist), "%.1f", distance); | ||
262 | element["columns"][1]["value"] = strcat(dist,"m"); | ||
263 | |||
264 | mRadarList->addElement(element, ADD_BOTTOM); | ||
265 | } | 364 | } |
365 | avatar_count << (int)avatar_ids.size(); | ||
366 | } | ||
367 | else | ||
368 | { | ||
369 | mTypingAvatars.clear(); | ||
370 | mRadarList->addCommentText(getString("no_one_near"), ADD_TOP); | ||
371 | avatar_count << "0"; | ||
266 | } | 372 | } |
267 | 373 | ||
268 | mRadarList->sortItems(); | 374 | childSetText("lblAvatarCount", avatar_count.str()); |
269 | mRadarList->setScrollPos(scroll_pos); | 375 | |
270 | if (mSelectedAvatar.notNull()) | 376 | toggleButtons(); |
377 | |||
378 | //llinfos << "mSelectedAvatar: " << mSelectedAvatar.asString() << llendl; | ||
379 | } | ||
380 | |||
381 | void LLFloaterMap::updateChatList(std::vector<LLUUID> agent_ids) | ||
382 | { | ||
383 | std::set<LLUUID>::iterator it; | ||
384 | std::vector<LLUUID>::iterator result; | ||
385 | for (it = mChatAvatars.begin(); it != mChatAvatars.end(); ) | ||
271 | { | 386 | { |
272 | mRadarList->selectByID(mSelectedAvatar); | 387 | result = find(agent_ids.begin(), agent_ids.end(), *it); |
388 | if (result == agent_ids.end()) | ||
389 | { | ||
390 | mChatAvatars.erase(it++); | ||
391 | } | ||
392 | else | ||
393 | { | ||
394 | it++; | ||
395 | } | ||
273 | } | 396 | } |
397 | } | ||
274 | 398 | ||
275 | // set count | 399 | bool LLFloaterMap::getInChatList(LLUUID agent_id) |
276 | std::stringstream avatar_count; | 400 | { |
277 | avatar_count.str(""); | 401 | if (mChatAvatars.count(agent_id) > 0) |
278 | if (avatar_ids.empty()) | ||
279 | { | 402 | { |
280 | mRadarList->addCommentText(getString("no_one_near"), ADD_TOP); | 403 | return true; |
281 | avatar_count << "0"; | 404 | } |
405 | return false; | ||
406 | } | ||
407 | |||
408 | void LLFloaterMap::addToChatList(LLUUID agent_id, std::string distance) | ||
409 | { | ||
410 | mChatAvatars.insert(agent_id); | ||
411 | LLChat chat; | ||
412 | |||
413 | LLUIString notify = getString("entering_chat_range"); | ||
414 | notify.setArg("[NAME]", getSelectedName(agent_id)); | ||
415 | notify.setArg("[DISTANCE]", distance); | ||
416 | |||
417 | chat.mText = notify; | ||
418 | chat.mSourceType = CHAT_SOURCE_SYSTEM; | ||
419 | LLFloaterChat::addChat(chat, FALSE, FALSE); | ||
420 | } | ||
421 | |||
422 | void LLFloaterMap::removeFromChatList(LLUUID agent_id) | ||
423 | { | ||
424 | // Do we want to add a notice? | ||
425 | mChatAvatars.erase(agent_id); | ||
426 | } | ||
427 | |||
428 | bool LLFloaterMap::getIsTyping(LLUUID agent_id) | ||
429 | { | ||
430 | if (mTypingAvatars.count(agent_id) > 0) | ||
431 | { | ||
432 | return true; | ||
433 | } | ||
434 | return false; | ||
435 | } | ||
436 | |||
437 | void LLFloaterMap::updateTypingList(LLUUID agent_id, bool remove) | ||
438 | { | ||
439 | if (remove) | ||
440 | { | ||
441 | if (getIsTyping(agent_id)) | ||
442 | { | ||
443 | mTypingAvatars.erase(agent_id); | ||
444 | } | ||
282 | } | 445 | } |
283 | else | 446 | else |
284 | { | 447 | { |
285 | avatar_count << (int)avatar_ids.size(); | 448 | mTypingAvatars.insert(agent_id); |
286 | } | 449 | } |
287 | childSetText("lblAvatarCount", avatar_count.str()); | 450 | } |
288 | 451 | ||
289 | toggleButtons(); | 452 | void LLFloaterMap::updateSimAvList(std::vector<LLUUID> agent_ids) |
453 | { | ||
454 | std::set<LLUUID>::iterator it; | ||
455 | std::vector<LLUUID>::iterator result; | ||
456 | for (it = mSimAvatars.begin(); it != mSimAvatars.end(); ) | ||
457 | { | ||
458 | result = find(agent_ids.begin(), agent_ids.end(), *it); | ||
459 | if (result == agent_ids.end()) | ||
460 | { | ||
461 | mSimAvatars.erase(it++); | ||
462 | } | ||
463 | else | ||
464 | { | ||
465 | it++; | ||
466 | } | ||
467 | } | ||
468 | } | ||
290 | 469 | ||
291 | //llinfos << "mSelectedAvatar: " << mSelectedAvatar.asString() << llendl; | 470 | void LLFloaterMap::addToSimAvList(LLUUID agent_id, std::string distance) |
471 | { | ||
472 | mSimAvatars.insert(agent_id); | ||
473 | LLChat chat; | ||
474 | |||
475 | LLUIString notify = getString("entering_sim_range"); | ||
476 | notify.setArg("[NAME]", getSelectedName(agent_id)); | ||
477 | notify.setArg("[DISTANCE]", distance); | ||
478 | |||
479 | chat.mText = notify; | ||
480 | chat.mSourceType = CHAT_SOURCE_SYSTEM; | ||
481 | LLFloaterChat::addChat(chat, FALSE, FALSE); | ||
482 | } | ||
483 | |||
484 | bool LLFloaterMap::getInSimAvList(LLUUID agent_id) | ||
485 | { | ||
486 | if (mSimAvatars.count(agent_id) > 0) | ||
487 | { | ||
488 | return true; | ||
489 | } | ||
490 | return false; | ||
292 | } | 491 | } |
293 | 492 | ||
294 | void LLFloaterMap::toggleButtons() | 493 | void LLFloaterMap::toggleButtons() |