diff options
Diffstat (limited to 'linden/indra/newview/llstatusbar.cpp')
-rw-r--r-- | linden/indra/newview/llstatusbar.cpp | 148 |
1 files changed, 130 insertions, 18 deletions
diff --git a/linden/indra/newview/llstatusbar.cpp b/linden/indra/newview/llstatusbar.cpp index bdaf133..4e31151 100644 --- a/linden/indra/newview/llstatusbar.cpp +++ b/linden/indra/newview/llstatusbar.cpp | |||
@@ -49,6 +49,7 @@ | |||
49 | #include "llfloaterbuycurrency.h" | 49 | #include "llfloaterbuycurrency.h" |
50 | #include "llfloaterchat.h" | 50 | #include "llfloaterchat.h" |
51 | #include "llfloaterdirectory.h" // to spawn search | 51 | #include "llfloaterdirectory.h" // to spawn search |
52 | #include "llfloaterlagmeter.h" | ||
52 | #include "llfloaterland.h" | 53 | #include "llfloaterland.h" |
53 | #include "llfloaterregioninfo.h" | 54 | #include "llfloaterregioninfo.h" |
54 | #include "llfloaterscriptdebug.h" | 55 | #include "llfloaterscriptdebug.h" |
@@ -126,7 +127,7 @@ LLStatusBar::LLStatusBar(const std::string& name, const LLRect& rect) | |||
126 | mSquareMetersCommitted(0) | 127 | mSquareMetersCommitted(0) |
127 | { | 128 | { |
128 | // status bar can possible overlay menus? | 129 | // status bar can possible overlay menus? |
129 | mMouseOpaque = FALSE; | 130 | setMouseOpaque(FALSE); |
130 | setIsChrome(TRUE); | 131 | setIsChrome(TRUE); |
131 | 132 | ||
132 | // size of day of the weeks and year | 133 | // size of day of the weeks and year |
@@ -163,8 +164,49 @@ LLStatusBar::LLStatusBar(const std::string& name, const LLRect& rect) | |||
163 | childSetCommitCallback("search_editor", onCommitSearch, this); | 164 | childSetCommitCallback("search_editor", onCommitSearch, this); |
164 | childSetAction("search_btn", onClickSearch, this); | 165 | childSetAction("search_btn", onClickSearch, this); |
165 | 166 | ||
167 | childSetVisible("search_editor", gSavedSettings.getBOOL("ShowSearchBar")); | ||
168 | childSetVisible("search_btn", gSavedSettings.getBOOL("ShowSearchBar")); | ||
169 | |||
166 | childSetActionTextbox("ParcelNameText", onClickParcelInfo ); | 170 | childSetActionTextbox("ParcelNameText", onClickParcelInfo ); |
167 | childSetActionTextbox("BalanceText", onClickBalance ); | 171 | childSetActionTextbox("BalanceText", onClickBalance ); |
172 | |||
173 | // Adding Net Stat Graph | ||
174 | S32 x = getRect().getWidth() - 2; | ||
175 | S32 y = 0; | ||
176 | LLRect r; | ||
177 | r.set( x-SIM_STAT_WIDTH, y+MENU_BAR_HEIGHT-1, x, y+1); | ||
178 | mSGBandwidth = new LLStatGraph("BandwidthGraph", r); | ||
179 | mSGBandwidth->setFollows(FOLLOWS_BOTTOM | FOLLOWS_RIGHT); | ||
180 | mSGBandwidth->setStat(&gViewerStats->mKBitStat); | ||
181 | LLString text = childGetText("bandwidth_tooltip") + " "; | ||
182 | LLUIString bandwidth_tooltip = text; // get the text from XML until this widget is XML driven | ||
183 | mSGBandwidth->setLabel(bandwidth_tooltip.getString().c_str()); | ||
184 | mSGBandwidth->setUnits("Kbps"); | ||
185 | mSGBandwidth->setPrecision(0); | ||
186 | mSGBandwidth->setMouseOpaque(FALSE); | ||
187 | addChild(mSGBandwidth); | ||
188 | x -= SIM_STAT_WIDTH + 2; | ||
189 | |||
190 | r.set( x-SIM_STAT_WIDTH, y+MENU_BAR_HEIGHT-1, x, y+1); | ||
191 | mSGPacketLoss = new LLStatGraph("PacketLossPercent", r); | ||
192 | mSGPacketLoss->setFollows(FOLLOWS_BOTTOM | FOLLOWS_RIGHT); | ||
193 | mSGPacketLoss->setStat(&gViewerStats->mPacketsLostPercentStat); | ||
194 | text = childGetText("packet_loss_tooltip") + " "; | ||
195 | LLUIString packet_loss_tooltip = text; // get the text from XML until this widget is XML driven | ||
196 | mSGPacketLoss->setLabel(packet_loss_tooltip.getString().c_str()); | ||
197 | mSGPacketLoss->setUnits("%"); | ||
198 | mSGPacketLoss->setMin(0.f); | ||
199 | mSGPacketLoss->setMax(5.f); | ||
200 | mSGPacketLoss->setThreshold(0, 0.5f); | ||
201 | mSGPacketLoss->setThreshold(1, 1.f); | ||
202 | mSGPacketLoss->setThreshold(2, 3.f); | ||
203 | mSGPacketLoss->setPrecision(1); | ||
204 | mSGPacketLoss->setMouseOpaque(FALSE); | ||
205 | mSGPacketLoss->mPerSec = FALSE; | ||
206 | addChild(mSGPacketLoss); | ||
207 | |||
208 | childSetActionTextbox("stat_btn", onClickStatGraph); | ||
209 | |||
168 | } | 210 | } |
169 | 211 | ||
170 | LLStatusBar::~LLStatusBar() | 212 | LLStatusBar::~LLStatusBar() |
@@ -199,9 +241,9 @@ void LLStatusBar::draw() | |||
199 | { | 241 | { |
200 | refresh(); | 242 | refresh(); |
201 | 243 | ||
202 | if (mBgVisible) | 244 | if (isBackgroundVisible()) |
203 | { | 245 | { |
204 | gl_drop_shadow(0, mRect.getHeight(), mRect.getWidth(), 0, | 246 | gl_drop_shadow(0, getRect().getHeight(), getRect().getWidth(), 0, |
205 | LLUI::sColorsGroup->getColor("ColorDropShadow"), | 247 | LLUI::sColorsGroup->getColor("ColorDropShadow"), |
206 | LLUI::sConfigGroup->getS32("DropShadowFloater") ); | 248 | LLUI::sConfigGroup->getS32("DropShadowFloater") ); |
207 | } | 249 | } |
@@ -212,6 +254,14 @@ void LLStatusBar::draw() | |||
212 | // Per-frame updates of visibility | 254 | // Per-frame updates of visibility |
213 | void LLStatusBar::refresh() | 255 | void LLStatusBar::refresh() |
214 | { | 256 | { |
257 | // Adding Net Stat Meter back in | ||
258 | F32 bwtotal = gViewerThrottle.getMaxBandwidth() / 1000.f; | ||
259 | mSGBandwidth->setMin(0.f); | ||
260 | mSGBandwidth->setMax(bwtotal*1.25f); | ||
261 | mSGBandwidth->setThreshold(0, bwtotal*0.75f); | ||
262 | mSGBandwidth->setThreshold(1, bwtotal); | ||
263 | mSGBandwidth->setThreshold(2, bwtotal); | ||
264 | |||
215 | // *TODO: Localize / translate time | 265 | // *TODO: Localize / translate time |
216 | 266 | ||
217 | // Get current UTC time, adjusted for the user's clock | 267 | // Get current UTC time, adjusted for the user's clock |
@@ -262,6 +312,8 @@ void LLStatusBar::refresh() | |||
262 | S32 x = MENU_RIGHT + MENU_PARCEL_SPACING; | 312 | S32 x = MENU_RIGHT + MENU_PARCEL_SPACING; |
263 | S32 y = 0; | 313 | S32 y = 0; |
264 | 314 | ||
315 | bool search_visible = gSavedSettings.getBOOL("ShowSearchBar"); | ||
316 | |||
265 | // reshape menu bar to its content's width | 317 | // reshape menu bar to its content's width |
266 | if (MENU_RIGHT != gMenuBarView->getRect().getWidth()) | 318 | if (MENU_RIGHT != gMenuBarView->getRect().getWidth()) |
267 | { | 319 | { |
@@ -454,7 +506,7 @@ void LLStatusBar::refresh() | |||
454 | 506 | ||
455 | mRegionDetails.mTime = mTextTime->getText(); | 507 | mRegionDetails.mTime = mTextTime->getText(); |
456 | mRegionDetails.mBalance = mBalance; | 508 | mRegionDetails.mBalance = mBalance; |
457 | mRegionDetails.mAccesString = (char *)region->getSimAccessString(); | 509 | mRegionDetails.mAccesString = region->getSimAccessString(); |
458 | mRegionDetails.mPing = region->getNetDetailsForLCD(); | 510 | mRegionDetails.mPing = region->getNetDetailsForLCD(); |
459 | if (parcel && !parcel->getName().empty()) | 511 | if (parcel && !parcel->getName().empty()) |
460 | { | 512 | { |
@@ -466,7 +518,7 @@ void LLStatusBar::refresh() | |||
466 | 518 | ||
467 | // keep these around for the LCD to use | 519 | // keep these around for the LCD to use |
468 | mRegionDetails.mRegionName = region->getName(); | 520 | mRegionDetails.mRegionName = region->getName(); |
469 | mRegionDetails.mParcelName = (char *)parcel->getName().c_str(); | 521 | mRegionDetails.mParcelName = parcel->getName(); |
470 | mRegionDetails.mX = pos_x; | 522 | mRegionDetails.mX = pos_x; |
471 | mRegionDetails.mY = pos_y; | 523 | mRegionDetails.mY = pos_y; |
472 | mRegionDetails.mZ = pos_z; | 524 | mRegionDetails.mZ = pos_z; |
@@ -476,7 +528,7 @@ void LLStatusBar::refresh() | |||
476 | 528 | ||
477 | if (parcel->isPublic()) | 529 | if (parcel->isPublic()) |
478 | { | 530 | { |
479 | snprintf(mRegionDetails.mOwner, MAX_STRING, "Public"); | 531 | mRegionDetails.mOwner = "Public"; |
480 | } | 532 | } |
481 | else | 533 | else |
482 | { | 534 | { |
@@ -488,16 +540,13 @@ void LLStatusBar::refresh() | |||
488 | } | 540 | } |
489 | else | 541 | else |
490 | { | 542 | { |
491 | snprintf(mRegionDetails.mOwner, MAX_STRING, "Group Owned"); | 543 | mRegionDetails.mOwner = "Group Owned"; |
492 | } | 544 | } |
493 | } | 545 | } |
494 | else | 546 | else |
495 | { | 547 | { |
496 | // Figure out the owner's name | 548 | // Figure out the owner's name |
497 | char owner_first[MAX_STRING]; /*Flawfinder: ignore*/ | 549 | gCacheName->getFullName(parcel->getOwnerID(), mRegionDetails.mOwner); |
498 | char owner_last[MAX_STRING]; /*Flawfinder: ignore*/ | ||
499 | gCacheName->getName(parcel->getOwnerID(), owner_first, owner_last); | ||
500 | snprintf(mRegionDetails.mOwner, MAX_STRING, "%s %s", owner_first, owner_last); /* Flawfinder: ignore */ | ||
501 | } | 550 | } |
502 | } | 551 | } |
503 | } | 552 | } |
@@ -516,7 +565,7 @@ void LLStatusBar::refresh() | |||
516 | mRegionDetails.mZ = pos_z; | 565 | mRegionDetails.mZ = pos_z; |
517 | mRegionDetails.mArea = 0; | 566 | mRegionDetails.mArea = 0; |
518 | mRegionDetails.mForSale = FALSE; | 567 | mRegionDetails.mForSale = FALSE; |
519 | snprintf(mRegionDetails.mOwner, MAX_STRING, "Unknown"); | 568 | mRegionDetails.mOwner = "Unknown"; |
520 | mRegionDetails.mTraffic = 0.0f; | 569 | mRegionDetails.mTraffic = 0.0f; |
521 | } | 570 | } |
522 | } | 571 | } |
@@ -525,7 +574,7 @@ void LLStatusBar::refresh() | |||
525 | // no region | 574 | // no region |
526 | location_name = "(Unknown)"; | 575 | location_name = "(Unknown)"; |
527 | // keep these around for the LCD to use | 576 | // keep these around for the LCD to use |
528 | mRegionDetails.mRegionName = LLString("Unknown"); | 577 | mRegionDetails.mRegionName = "Unknown"; |
529 | mRegionDetails.mParcelName = "Unknown"; | 578 | mRegionDetails.mParcelName = "Unknown"; |
530 | mRegionDetails.mAccesString = "Unknown"; | 579 | mRegionDetails.mAccesString = "Unknown"; |
531 | mRegionDetails.mX = 0; | 580 | mRegionDetails.mX = 0; |
@@ -533,17 +582,72 @@ void LLStatusBar::refresh() | |||
533 | mRegionDetails.mZ = 0; | 582 | mRegionDetails.mZ = 0; |
534 | mRegionDetails.mArea = 0; | 583 | mRegionDetails.mArea = 0; |
535 | mRegionDetails.mForSale = FALSE; | 584 | mRegionDetails.mForSale = FALSE; |
536 | snprintf(mRegionDetails.mOwner, MAX_STRING, "Unknown"); | 585 | mRegionDetails.mOwner = "Unknown"; |
537 | mRegionDetails.mTraffic = 0.0f; | 586 | mRegionDetails.mTraffic = 0.0f; |
538 | } | 587 | } |
588 | |||
539 | mTextParcelName->setText(location_name); | 589 | mTextParcelName->setText(location_name); |
540 | 590 | ||
591 | |||
592 | |||
593 | // x = right edge | ||
594 | // loop through: stat graphs, search btn, search text editor, money, buy money, clock | ||
595 | // adjust rect | ||
596 | // finally adjust parcel name rect | ||
597 | |||
598 | S32 new_right = getRect().getWidth(); | ||
599 | if (search_visible) | ||
600 | { | ||
601 | childGetRect("search_btn", r); | ||
602 | r.translate( new_right - r.mRight, 0); | ||
603 | childSetRect("search_btn", r); | ||
604 | new_right -= r.getWidth(); | ||
605 | |||
606 | childGetRect("search_editor", r); | ||
607 | r.translate( new_right - r.mRight, 0); | ||
608 | childSetRect("search_editor", r); | ||
609 | new_right -= r.getWidth() + 6; | ||
610 | |||
611 | } | ||
612 | else | ||
613 | { | ||
614 | childGetRect("stat_btn", r); | ||
615 | r.translate( new_right - r.mRight, 0); | ||
616 | childSetRect("stat_btn", r); | ||
617 | new_right -= r.getWidth() + 6; | ||
618 | } | ||
619 | |||
620 | // Set rects of money, buy money, time | ||
621 | childGetRect("BalanceText", r); | ||
622 | r.translate( new_right - r.mRight, 0); | ||
623 | childSetRect("BalanceText", r); | ||
624 | new_right -= r.getWidth() - 18; | ||
625 | |||
626 | childGetRect("buycurrency", r); | ||
627 | r.translate( new_right - r.mRight, 0); | ||
628 | childSetRect("buycurrency", r); | ||
629 | new_right -= r.getWidth() + 6; | ||
630 | |||
631 | childGetRect("TimeText", r); | ||
632 | // mTextTime->getTextPixelWidth(); | ||
633 | r.translate( new_right - r.mRight, 0); | ||
634 | childSetRect("TimeText", r); | ||
635 | // new_right -= r.getWidth() + MENU_PARCEL_SPACING; | ||
636 | |||
637 | |||
541 | // Adjust region name and parcel name | 638 | // Adjust region name and parcel name |
542 | x += 8; | 639 | x += 8; |
543 | 640 | ||
544 | const S32 PARCEL_RIGHT = llmin(mTextTime->getRect().mLeft, mTextParcelName->getTextPixelWidth() + x + 5); | 641 | const S32 PARCEL_RIGHT = llmin(mTextTime->getRect().mLeft, mTextParcelName->getTextPixelWidth() + x + 5); |
545 | r.set(x+4, mRect.getHeight() - 2, PARCEL_RIGHT, 0); | 642 | r.set(x+4, getRect().getHeight() - 2, PARCEL_RIGHT, 0); |
546 | mTextParcelName->setRect(r); | 643 | mTextParcelName->setRect(r); |
644 | |||
645 | // Set search bar visibility | ||
646 | childSetVisible("search_editor", search_visible); | ||
647 | childSetVisible("search_btn", search_visible); | ||
648 | mSGBandwidth->setVisible(! search_visible); | ||
649 | mSGPacketLoss->setVisible(! search_visible); | ||
650 | childSetEnabled("stat_btn", ! search_visible); | ||
547 | } | 651 | } |
548 | 652 | ||
549 | void LLStatusBar::setVisibleForMouselook(bool visible) | 653 | void LLStatusBar::setVisibleForMouselook(bool visible) |
@@ -553,6 +657,8 @@ void LLStatusBar::setVisibleForMouselook(bool visible) | |||
553 | childSetVisible("buycurrency", visible); | 657 | childSetVisible("buycurrency", visible); |
554 | childSetVisible("search_editor", visible); | 658 | childSetVisible("search_editor", visible); |
555 | childSetVisible("search_btn", visible); | 659 | childSetVisible("search_btn", visible); |
660 | mSGBandwidth->setVisible(visible); | ||
661 | mSGPacketLoss->setVisible(visible); | ||
556 | setBackgroundVisible(visible); | 662 | setBackgroundVisible(visible); |
557 | } | 663 | } |
558 | 664 | ||
@@ -664,7 +770,7 @@ static void onClickParcelInfo(void* data) | |||
664 | { | 770 | { |
665 | gParcelMgr->selectParcelAt(gAgent.getPositionGlobal()); | 771 | gParcelMgr->selectParcelAt(gAgent.getPositionGlobal()); |
666 | 772 | ||
667 | LLFloaterLand::show(); | 773 | LLFloaterLand::showInstance(); |
668 | } | 774 | } |
669 | 775 | ||
670 | static void onClickBalance(void* data) | 776 | static void onClickBalance(void* data) |
@@ -734,7 +840,7 @@ static void onClickBuyLand(void*) | |||
734 | void LLStatusBar::setupDate() | 840 | void LLStatusBar::setupDate() |
735 | { | 841 | { |
736 | // fill the day array with what's in the xui | 842 | // fill the day array with what's in the xui |
737 | LLString day_list = getFormattedUIString("StatBarDaysOfWeek"); | 843 | LLString day_list = getString("StatBarDaysOfWeek"); |
738 | size_t length = day_list.size(); | 844 | size_t length = day_list.size(); |
739 | 845 | ||
740 | // quick input check | 846 | // quick input check |
@@ -758,7 +864,7 @@ void LLStatusBar::setupDate() | |||
758 | } | 864 | } |
759 | 865 | ||
760 | // fill the day array with what's in the xui | 866 | // fill the day array with what's in the xui |
761 | LLString month_list = getFormattedUIString( "StatBarMonthsOfYear" ); | 867 | LLString month_list = getString( "StatBarMonthsOfYear" ); |
762 | length = month_list.size(); | 868 | length = month_list.size(); |
763 | 869 | ||
764 | // quick input check | 870 | // quick input check |
@@ -808,6 +914,12 @@ void LLStatusBar::onClickSearch(void* data) | |||
808 | LLFloaterDirectory::showFindAll(search_text); | 914 | LLFloaterDirectory::showFindAll(search_text); |
809 | } | 915 | } |
810 | 916 | ||
917 | // static | ||
918 | void LLStatusBar::onClickStatGraph(void* data) | ||
919 | { | ||
920 | LLFloaterLagMeter::show(data); | ||
921 | } | ||
922 | |||
811 | BOOL can_afford_transaction(S32 cost) | 923 | BOOL can_afford_transaction(S32 cost) |
812 | { | 924 | { |
813 | return((cost <= 0)||((gStatusBar) && (gStatusBar->getBalance() >=cost))); | 925 | return((cost <= 0)||((gStatusBar) && (gStatusBar->getBalance() >=cost))); |