diff options
Diffstat (limited to 'linden/indra/newview/llviewerwindow.cpp')
-rw-r--r-- | linden/indra/newview/llviewerwindow.cpp | 439 |
1 files changed, 373 insertions, 66 deletions
diff --git a/linden/indra/newview/llviewerwindow.cpp b/linden/indra/newview/llviewerwindow.cpp index a4d38f8..9498dbd 100644 --- a/linden/indra/newview/llviewerwindow.cpp +++ b/linden/indra/newview/llviewerwindow.cpp | |||
@@ -4,6 +4,7 @@ | |||
4 | * | 4 | * |
5 | * Copyright (c) 2001-2007, Linden Research, Inc. | 5 | * Copyright (c) 2001-2007, Linden Research, Inc. |
6 | * | 6 | * |
7 | * Second Life Viewer Source Code | ||
7 | * The source code in this file ("Source Code") is provided by Linden Lab | 8 | * The source code in this file ("Source Code") is provided by Linden Lab |
8 | * to you under the terms of the GNU General Public License, version 2.0 | 9 | * to you under the terms of the GNU General Public License, version 2.0 |
9 | * ("GPL"), unless you have obtained a separate licensing agreement | 10 | * ("GPL"), unless you have obtained a separate licensing agreement |
@@ -62,7 +63,6 @@ | |||
62 | #include "llxfermanager.h" | 63 | #include "llxfermanager.h" |
63 | #include "message.h" | 64 | #include "message.h" |
64 | #include "object_flags.h" | 65 | #include "object_flags.h" |
65 | #include "text_out.h" | ||
66 | #include "lltimer.h" | 66 | #include "lltimer.h" |
67 | #include "timing.h" | 67 | #include "timing.h" |
68 | #include "llviewermenu.h" | 68 | #include "llviewermenu.h" |
@@ -353,7 +353,216 @@ void LLViewerWindow::printFeedback() | |||
353 | } | 353 | } |
354 | #endif //SABINRIG | 354 | #endif //SABINRIG |
355 | 355 | ||
356 | //////////////////////////////////////////////////////////////////////////// | ||
357 | // | ||
358 | // LLDebugText | ||
359 | // | ||
360 | |||
361 | class LLDebugText | ||
362 | { | ||
363 | private: | ||
364 | struct Line | ||
365 | { | ||
366 | Line(const std::string& in_text, S32 in_x, S32 in_y) : text(in_text), x(in_x), y(in_y) {} | ||
367 | std::string text; | ||
368 | S32 x,y; | ||
369 | }; | ||
370 | |||
371 | LLViewerWindow *mWindow; | ||
372 | |||
373 | typedef std::vector<Line> line_list_t; | ||
374 | line_list_t mLineList; | ||
375 | LLColor4 mTextColor; | ||
376 | |||
377 | public: | ||
378 | LLDebugText(LLViewerWindow* window) : mWindow(window) {} | ||
379 | |||
380 | void addText(S32 x, S32 y, const std::string &text) | ||
381 | { | ||
382 | mLineList.push_back(Line(text, x, y)); | ||
383 | } | ||
384 | |||
385 | void update() | ||
386 | { | ||
387 | std::string wind_vel_text; | ||
388 | std::string wind_vector_text; | ||
389 | std::string rwind_vel_text; | ||
390 | std::string rwind_vector_text; | ||
391 | std::string audio_text; | ||
392 | |||
393 | // Draw the statistics in a light gray | ||
394 | // and in a thin font | ||
395 | mTextColor = LLColor4( 0.86f, 0.86f, 0.86f, 1.f ); | ||
396 | |||
397 | // Draw stuff growing up from right lower corner of screen | ||
398 | U32 xpos = mWindow->getWindowWidth() - 350; | ||
399 | U32 ypos = 64; | ||
400 | const U32 y_inc = 20; | ||
401 | |||
402 | if (gSavedSettings.getBOOL("DebugShowTime")) | ||
403 | { | ||
404 | const U32 y_inc2 = 15; | ||
405 | for (std::map<S32,LLFrameTimer>::reverse_iterator iter = gDebugTimers.rbegin(); | ||
406 | iter != gDebugTimers.rend(); ++iter) | ||
407 | { | ||
408 | S32 idx = iter->first; | ||
409 | LLFrameTimer& timer = iter->second; | ||
410 | F32 time = timer.getElapsedTimeF32(); | ||
411 | S32 hours = (S32)(time / (60*60)); | ||
412 | S32 mins = (S32)((time - hours*(60*60)) / 60); | ||
413 | S32 secs = (S32)((time - hours*(60*60) - mins*60)); | ||
414 | addText(xpos, ypos, llformat(" Debug %d: %d:%02d:%02d", idx, hours,mins,secs)); ypos += y_inc2; | ||
415 | } | ||
416 | |||
417 | F32 time = gFrameTimeSeconds; | ||
418 | S32 hours = (S32)(time / (60*60)); | ||
419 | S32 mins = (S32)((time - hours*(60*60)) / 60); | ||
420 | S32 secs = (S32)((time - hours*(60*60) - mins*60)); | ||
421 | addText(xpos, ypos, llformat("Time: %d:%02d:%02d", hours,mins,secs)); ypos += y_inc; | ||
422 | } | ||
423 | |||
424 | if (gDisplayCameraPos) | ||
425 | { | ||
426 | std::string camera_view_text; | ||
427 | std::string camera_center_text; | ||
428 | std::string agent_view_text; | ||
429 | std::string agent_left_text; | ||
430 | std::string agent_center_text; | ||
431 | std::string agent_root_center_text; | ||
432 | |||
433 | LLVector3d tvector; // Temporary vector to hold data for printing. | ||
434 | |||
435 | // Update camera center, camera view, wind info every other frame | ||
436 | tvector = gAgent.getPositionGlobal(); | ||
437 | agent_center_text = llformat("AgentCenter %f %f %f", | ||
438 | (F32)(tvector.mdV[VX]), (F32)(tvector.mdV[VY]), (F32)(tvector.mdV[VZ])); | ||
439 | |||
440 | if (gAgent.getAvatarObject()) | ||
441 | { | ||
442 | tvector = gAgent.getPosGlobalFromAgent(gAgent.getAvatarObject()->mRoot.getWorldPosition()); | ||
443 | agent_root_center_text = llformat("AgentRootCenter %f %f %f", | ||
444 | (F32)(tvector.mdV[VX]), (F32)(tvector.mdV[VY]), (F32)(tvector.mdV[VZ])); | ||
445 | } | ||
446 | else | ||
447 | { | ||
448 | agent_root_center_text = "---"; | ||
449 | } | ||
450 | |||
356 | 451 | ||
452 | tvector = LLVector4(gAgent.getFrameAgent().getAtAxis()); | ||
453 | agent_view_text = llformat("AgentAtAxis %f %f %f", | ||
454 | (F32)(tvector.mdV[VX]), (F32)(tvector.mdV[VY]), (F32)(tvector.mdV[VZ])); | ||
455 | |||
456 | tvector = LLVector4(gAgent.getFrameAgent().getLeftAxis()); | ||
457 | agent_left_text = llformat("AgentLeftAxis %f %f %f", | ||
458 | (F32)(tvector.mdV[VX]), (F32)(tvector.mdV[VY]), (F32)(tvector.mdV[VZ])); | ||
459 | |||
460 | tvector = gAgent.getCameraPositionGlobal(); | ||
461 | camera_center_text = llformat("CameraCenter %f %f %f", | ||
462 | (F32)(tvector.mdV[VX]), (F32)(tvector.mdV[VY]), (F32)(tvector.mdV[VZ])); | ||
463 | |||
464 | tvector = LLVector4(gCamera->getAtAxis()); | ||
465 | camera_view_text = llformat("CameraAtAxis %f %f %f", | ||
466 | (F32)(tvector.mdV[VX]), (F32)(tvector.mdV[VY]), (F32)(tvector.mdV[VZ])); | ||
467 | |||
468 | addText(xpos, ypos, agent_center_text); ypos += y_inc; | ||
469 | addText(xpos, ypos, agent_root_center_text); ypos += y_inc; | ||
470 | addText(xpos, ypos, agent_view_text); ypos += y_inc; | ||
471 | addText(xpos, ypos, agent_left_text); ypos += y_inc; | ||
472 | addText(xpos, ypos, camera_center_text); ypos += y_inc; | ||
473 | addText(xpos, ypos, camera_view_text); ypos += y_inc; | ||
474 | } | ||
475 | |||
476 | if (gDisplayWindInfo) | ||
477 | { | ||
478 | wind_vel_text = llformat("Wind velocity %.2f m/s", gWindVec.magVec()); | ||
479 | wind_vector_text = llformat("Wind vector %.2f %.2f %.2f", gWindVec.mV[0], gWindVec.mV[1], gWindVec.mV[2]); | ||
480 | rwind_vel_text = llformat("RWind vel %.2f m/s", gRelativeWindVec.magVec()); | ||
481 | rwind_vector_text = llformat("RWind vec %.2f %.2f %.2f", gRelativeWindVec.mV[0], gRelativeWindVec.mV[1], gRelativeWindVec.mV[2]); | ||
482 | |||
483 | addText(xpos, ypos, wind_vel_text); ypos += y_inc; | ||
484 | addText(xpos, ypos, wind_vector_text); ypos += y_inc; | ||
485 | addText(xpos, ypos, rwind_vel_text); ypos += y_inc; | ||
486 | addText(xpos, ypos, rwind_vector_text); ypos += y_inc; | ||
487 | } | ||
488 | if (gDisplayWindInfo) | ||
489 | { | ||
490 | if (gAudiop) | ||
491 | { | ||
492 | audio_text= llformat("Audio for wind: %d", gAudiop->isWindEnabled()); | ||
493 | } | ||
494 | addText(xpos, ypos, audio_text); ypos += y_inc; | ||
495 | } | ||
496 | if (gDisplayFOV) | ||
497 | { | ||
498 | addText(xpos, ypos, llformat("FOV: %2.1f deg", RAD_TO_DEG * gCamera->getView())); | ||
499 | ypos += y_inc; | ||
500 | } | ||
501 | if (gSavedSettings.getBOOL("DebugShowRenderInfo")) | ||
502 | { | ||
503 | if (gPipeline.getUseVertexShaders() == 0) | ||
504 | { | ||
505 | addText(xpos, ypos, "Shaders Disabled"); | ||
506 | ypos += y_inc; | ||
507 | } | ||
508 | addText(xpos, ypos, llformat("%d MB Vertex Data", LLVertexBuffer::sAllocatedBytes/(1024*1024))); | ||
509 | ypos += y_inc; | ||
510 | |||
511 | addText(xpos, ypos, llformat("%d Pending Lock", LLVertexBuffer::sLockedList.size())); | ||
512 | ypos += y_inc; | ||
513 | |||
514 | addText(xpos, ypos, llformat("%d Vertex Buffers", LLVertexBuffer::sGLCount)); | ||
515 | ypos += y_inc; | ||
516 | } | ||
517 | |||
518 | if (LLPipeline::getRenderParticleBeacons(NULL)) | ||
519 | { | ||
520 | addText(xpos, ypos, "Viewing particle beacons (blue)"); | ||
521 | ypos += y_inc; | ||
522 | } | ||
523 | if (LLPipeline::toggleRenderTypeControlNegated((void*)LLPipeline::RENDER_TYPE_PARTICLES)) | ||
524 | { | ||
525 | addText(xpos, ypos, "Hiding particles"); | ||
526 | ypos += y_inc; | ||
527 | } | ||
528 | if (LLPipeline::getRenderPhysicalBeacons(NULL)) | ||
529 | { | ||
530 | addText(xpos, ypos, "Viewing physical object beacons (green)"); | ||
531 | ypos += y_inc; | ||
532 | } | ||
533 | if (LLPipeline::getRenderScriptedBeacons(NULL)) | ||
534 | { | ||
535 | addText(xpos, ypos, "Viewing scripted object beacons (red)"); | ||
536 | ypos += y_inc; | ||
537 | } | ||
538 | if (LLPipeline::getRenderSoundBeacons(NULL)) | ||
539 | { | ||
540 | addText(xpos, ypos, "Viewing sound beacons (yellow)"); | ||
541 | ypos += y_inc; | ||
542 | } | ||
543 | } | ||
544 | |||
545 | void draw() | ||
546 | { | ||
547 | for (line_list_t::iterator iter = mLineList.begin(); | ||
548 | iter != mLineList.end(); ++iter) | ||
549 | { | ||
550 | const Line& line = *iter; | ||
551 | LLFontGL::sMonospace->renderUTF8(line.text, 0, (F32)line.x, (F32)line.y, mTextColor, | ||
552 | LLFontGL::LEFT, LLFontGL::TOP, | ||
553 | LLFontGL::NORMAL, S32_MAX, S32_MAX, NULL, FALSE); | ||
554 | } | ||
555 | mLineList.clear(); | ||
556 | } | ||
557 | |||
558 | }; | ||
559 | |||
560 | void LLViewerWindow::updateDebugText() | ||
561 | { | ||
562 | mDebugText->update(); | ||
563 | } | ||
564 | |||
565 | //////////////////////////////////////////////////////////////////////////// | ||
357 | // | 566 | // |
358 | // LLViewerWindow | 567 | // LLViewerWindow |
359 | // | 568 | // |
@@ -420,12 +629,20 @@ BOOL LLViewerWindow::handleMouseDown(LLWindow *window, LLCoordGL pos, MASK mask | |||
420 | } | 629 | } |
421 | 630 | ||
422 | // Topmost view gets a chance before the hierarchy | 631 | // Topmost view gets a chance before the hierarchy |
423 | LLView* top_view = gFocusMgr.getTopView(); | 632 | LLUICtrl* top_ctrl = gFocusMgr.getTopCtrl(); |
424 | if (top_view) | 633 | BOOL mouse_over_top_ctrl = FALSE; |
634 | if (top_ctrl) | ||
425 | { | 635 | { |
426 | S32 local_x, local_y; | 636 | S32 local_x, local_y; |
427 | top_view->screenPointToLocal( x, y, &local_x, &local_y ); | 637 | top_ctrl->screenPointToLocal( x, y, &local_x, &local_y ); |
428 | if (top_view->pointInView(local_x, local_y) && top_view->handleMouseDown(local_x, local_y, mask)) return TRUE; | 638 | if (top_ctrl->pointInView(local_x, local_y)) |
639 | { | ||
640 | mouse_over_top_ctrl = TRUE; | ||
641 | if(top_ctrl->handleMouseDown(local_x, local_y, mask)) | ||
642 | { | ||
643 | return TRUE; | ||
644 | } | ||
645 | } | ||
429 | } | 646 | } |
430 | 647 | ||
431 | // Give the UI views a chance to process the click | 648 | // Give the UI views a chance to process the click |
@@ -436,6 +653,11 @@ BOOL LLViewerWindow::handleMouseDown(LLWindow *window, LLCoordGL pos, MASK mask | |||
436 | llinfos << "Left Mouse Down" << LLView::sMouseHandlerMessage << llendl; | 653 | llinfos << "Left Mouse Down" << LLView::sMouseHandlerMessage << llendl; |
437 | LLView::sMouseHandlerMessage = ""; | 654 | LLView::sMouseHandlerMessage = ""; |
438 | } | 655 | } |
656 | if (top_ctrl && top_ctrl->hasFocus() && !mouse_over_top_ctrl) | ||
657 | { | ||
658 | // always defocus top view if we click off of it | ||
659 | top_ctrl->setFocus(FALSE); | ||
660 | } | ||
439 | return TRUE; | 661 | return TRUE; |
440 | } | 662 | } |
441 | else if (LLView::sDebugMouseHandling) | 663 | else if (LLView::sDebugMouseHandling) |
@@ -443,6 +665,12 @@ BOOL LLViewerWindow::handleMouseDown(LLWindow *window, LLCoordGL pos, MASK mask | |||
443 | llinfos << "Left Mouse Down not handled by view" << llendl; | 665 | llinfos << "Left Mouse Down not handled by view" << llendl; |
444 | } | 666 | } |
445 | 667 | ||
668 | if (top_ctrl && top_ctrl->hasFocus() && !mouse_over_top_ctrl) | ||
669 | { | ||
670 | // always defocus top view if we click off of it | ||
671 | top_ctrl->setFocus(FALSE); | ||
672 | } | ||
673 | |||
446 | if (gDisconnected) | 674 | if (gDisconnected) |
447 | { | 675 | { |
448 | return FALSE; | 676 | return FALSE; |
@@ -498,12 +726,20 @@ BOOL LLViewerWindow::handleDoubleClick(LLWindow *window, LLCoordGL pos, MASK ma | |||
498 | } | 726 | } |
499 | 727 | ||
500 | // Check for hit on UI. | 728 | // Check for hit on UI. |
501 | LLView* top_view = gFocusMgr.getTopView(); | 729 | LLUICtrl* top_ctrl = gFocusMgr.getTopCtrl(); |
502 | if (top_view) | 730 | BOOL mouse_over_top_ctrl = FALSE; |
731 | if (top_ctrl) | ||
503 | { | 732 | { |
504 | S32 local_x, local_y; | 733 | S32 local_x, local_y; |
505 | top_view->screenPointToLocal( x, y, &local_x, &local_y ); | 734 | top_ctrl->screenPointToLocal( x, y, &local_x, &local_y ); |
506 | if (top_view->pointInView(local_x, local_y) && top_view->handleDoubleClick(local_x, local_y, mask)) return TRUE; | 735 | if (top_ctrl->pointInView(local_x, local_y)) |
736 | { | ||
737 | mouse_over_top_ctrl = TRUE; | ||
738 | if(top_ctrl->handleDoubleClick(local_x, local_y, mask)) | ||
739 | { | ||
740 | return TRUE; | ||
741 | } | ||
742 | } | ||
507 | } | 743 | } |
508 | 744 | ||
509 | if (mRootView->handleDoubleClick(x, y, mask)) | 745 | if (mRootView->handleDoubleClick(x, y, mask)) |
@@ -513,6 +749,11 @@ BOOL LLViewerWindow::handleDoubleClick(LLWindow *window, LLCoordGL pos, MASK ma | |||
513 | llinfos << "Left Mouse Down" << LLView::sMouseHandlerMessage << llendl; | 749 | llinfos << "Left Mouse Down" << LLView::sMouseHandlerMessage << llendl; |
514 | LLView::sMouseHandlerMessage = ""; | 750 | LLView::sMouseHandlerMessage = ""; |
515 | } | 751 | } |
752 | if (top_ctrl && top_ctrl->hasFocus() && !mouse_over_top_ctrl) | ||
753 | { | ||
754 | // always defocus top view if we click off of it | ||
755 | top_ctrl->setFocus(FALSE); | ||
756 | } | ||
516 | return TRUE; | 757 | return TRUE; |
517 | } | 758 | } |
518 | else if (LLView::sDebugMouseHandling) | 759 | else if (LLView::sDebugMouseHandling) |
@@ -520,7 +761,13 @@ BOOL LLViewerWindow::handleDoubleClick(LLWindow *window, LLCoordGL pos, MASK ma | |||
520 | llinfos << "Left Mouse Down not handled by view" << llendl; | 761 | llinfos << "Left Mouse Down not handled by view" << llendl; |
521 | } | 762 | } |
522 | 763 | ||
523 | // Why is this here? JC 9/3/2002 | 764 | if (top_ctrl && top_ctrl->hasFocus() && !mouse_over_top_ctrl) |
765 | { | ||
766 | // always defocus top view if we click off of it | ||
767 | top_ctrl->setFocus(FALSE); | ||
768 | } | ||
769 | |||
770 | // Why is this here? JC 9/3/2002 | ||
524 | if (gNoRender) | 771 | if (gNoRender) |
525 | { | 772 | { |
526 | return TRUE; | 773 | return TRUE; |
@@ -593,12 +840,12 @@ BOOL LLViewerWindow::handleMouseUp(LLWindow *window, LLCoordGL pos, MASK mask) | |||
593 | return mouse_captor->handleMouseUp(local_x, local_y, mask); | 840 | return mouse_captor->handleMouseUp(local_x, local_y, mask); |
594 | } | 841 | } |
595 | 842 | ||
596 | LLView* top_view = gFocusMgr.getTopView(); | 843 | LLUICtrl* top_ctrl = gFocusMgr.getTopCtrl(); |
597 | if (top_view) | 844 | if (top_ctrl) |
598 | { | 845 | { |
599 | S32 local_x, local_y; | 846 | S32 local_x, local_y; |
600 | top_view->screenPointToLocal( x, y, &local_x, &local_y ); | 847 | top_ctrl->screenPointToLocal( x, y, &local_x, &local_y ); |
601 | handled = top_view->pointInView(local_x, local_y) && top_view->handleMouseUp(local_x, local_y, mask); | 848 | handled = top_ctrl->pointInView(local_x, local_y) && top_ctrl->handleMouseUp(local_x, local_y, mask); |
602 | } | 849 | } |
603 | 850 | ||
604 | if( !handled ) | 851 | if( !handled ) |
@@ -689,12 +936,20 @@ BOOL LLViewerWindow::handleRightMouseDown(LLWindow *window, LLCoordGL pos, MASK | |||
689 | return mouse_captor->handleRightMouseDown(local_x, local_y, mask); | 936 | return mouse_captor->handleRightMouseDown(local_x, local_y, mask); |
690 | } | 937 | } |
691 | 938 | ||
692 | LLView* top_view = gFocusMgr.getTopView(); | 939 | LLUICtrl* top_ctrl = gFocusMgr.getTopCtrl(); |
693 | if (top_view) | 940 | BOOL mouse_over_top_ctrl = FALSE; |
941 | if (top_ctrl) | ||
694 | { | 942 | { |
695 | S32 local_x, local_y; | 943 | S32 local_x, local_y; |
696 | top_view->screenPointToLocal( x, y, &local_x, &local_y ); | 944 | top_ctrl->screenPointToLocal( x, y, &local_x, &local_y ); |
697 | if (top_view->pointInView(local_x, local_y) && top_view->handleRightMouseDown(local_x, local_y, mask)) return TRUE; | 945 | if (top_ctrl->pointInView(local_x, local_y)) |
946 | { | ||
947 | mouse_over_top_ctrl = TRUE; | ||
948 | if(top_ctrl->handleRightMouseDown(local_x, local_y, mask)) | ||
949 | { | ||
950 | return TRUE; | ||
951 | } | ||
952 | } | ||
698 | } | 953 | } |
699 | 954 | ||
700 | if( mRootView->handleRightMouseDown(x, y, mask) ) | 955 | if( mRootView->handleRightMouseDown(x, y, mask) ) |
@@ -704,6 +959,11 @@ BOOL LLViewerWindow::handleRightMouseDown(LLWindow *window, LLCoordGL pos, MASK | |||
704 | llinfos << "Right Mouse Down" << LLView::sMouseHandlerMessage << llendl; | 959 | llinfos << "Right Mouse Down" << LLView::sMouseHandlerMessage << llendl; |
705 | LLView::sMouseHandlerMessage = ""; | 960 | LLView::sMouseHandlerMessage = ""; |
706 | } | 961 | } |
962 | if (top_ctrl && top_ctrl->hasFocus() && !mouse_over_top_ctrl) | ||
963 | { | ||
964 | // always defocus top view if we click off of it | ||
965 | top_ctrl->setFocus(FALSE); | ||
966 | } | ||
707 | return TRUE; | 967 | return TRUE; |
708 | } | 968 | } |
709 | else if (LLView::sDebugMouseHandling) | 969 | else if (LLView::sDebugMouseHandling) |
@@ -711,6 +971,12 @@ BOOL LLViewerWindow::handleRightMouseDown(LLWindow *window, LLCoordGL pos, MASK | |||
711 | llinfos << "Right Mouse Down not handled by view" << llendl; | 971 | llinfos << "Right Mouse Down not handled by view" << llendl; |
712 | } | 972 | } |
713 | 973 | ||
974 | if (top_ctrl && top_ctrl->hasFocus() && !mouse_over_top_ctrl) | ||
975 | { | ||
976 | // always defocus top view if we click off of it | ||
977 | top_ctrl->setFocus(FALSE); | ||
978 | } | ||
979 | |||
714 | if (gToolMgr) | 980 | if (gToolMgr) |
715 | { | 981 | { |
716 | if(gToolMgr->getCurrentTool()->handleRightMouseDown( x, y, mask ) ) | 982 | if(gToolMgr->getCurrentTool()->handleRightMouseDown( x, y, mask ) ) |
@@ -792,12 +1058,12 @@ BOOL LLViewerWindow::handleRightMouseUp(LLWindow *window, LLCoordGL pos, MASK m | |||
792 | return mouse_captor->handleRightMouseUp(local_x, local_y, mask); | 1058 | return mouse_captor->handleRightMouseUp(local_x, local_y, mask); |
793 | } | 1059 | } |
794 | 1060 | ||
795 | LLView* top_view = gFocusMgr.getTopView(); | 1061 | LLUICtrl* top_ctrl = gFocusMgr.getTopCtrl(); |
796 | if (top_view) | 1062 | if (top_ctrl) |
797 | { | 1063 | { |
798 | S32 local_x, local_y; | 1064 | S32 local_x, local_y; |
799 | top_view->screenPointToLocal( x, y, &local_x, &local_y ); | 1065 | top_ctrl->screenPointToLocal( x, y, &local_x, &local_y ); |
800 | handled = top_view->pointInView(local_x, local_y) && top_view->handleRightMouseUp(local_x, local_y, mask); | 1066 | handled = top_ctrl->pointInView(local_x, local_y) && top_ctrl->handleRightMouseUp(local_x, local_y, mask); |
801 | } | 1067 | } |
802 | 1068 | ||
803 | if( !handled ) | 1069 | if( !handled ) |
@@ -931,7 +1197,7 @@ void LLViewerWindow::handleFocusLost(LLWindow *window) | |||
931 | { | 1197 | { |
932 | gToolMgr->onAppFocusLost(); | 1198 | gToolMgr->onAppFocusLost(); |
933 | } | 1199 | } |
934 | gFocusMgr.setMouseCapture( NULL, NULL ); | 1200 | gFocusMgr.setMouseCapture( NULL ); |
935 | 1201 | ||
936 | if (gMenuBarView) | 1202 | if (gMenuBarView) |
937 | { | 1203 | { |
@@ -1224,6 +1490,8 @@ LLViewerWindow::LLViewerWindow( | |||
1224 | 1490 | ||
1225 | LLFontManager::initClass(); | 1491 | LLFontManager::initClass(); |
1226 | 1492 | ||
1493 | // Initialize OpenGL Renderer | ||
1494 | |||
1227 | if (!gFeatureManagerp->isFeatureAvailable("RenderVBO") || | 1495 | if (!gFeatureManagerp->isFeatureAvailable("RenderVBO") || |
1228 | !gGLManager.mHasVertexBufferObject) | 1496 | !gGLManager.mHasVertexBufferObject) |
1229 | { | 1497 | { |
@@ -1236,8 +1504,27 @@ LLViewerWindow::LLViewerWindow( | |||
1236 | // stuff like AGP if we think that it'll crash the viewer. | 1504 | // stuff like AGP if we think that it'll crash the viewer. |
1237 | // | 1505 | // |
1238 | gFeatureManagerp->initGraphicsFeatureMasks(); | 1506 | gFeatureManagerp->initGraphicsFeatureMasks(); |
1507 | |||
1508 | // The ATI Mobility Radeon with 1.15.0 causes crashes in FMOD on startup for | ||
1509 | // unknown reasons, but only if you have an old settings.ini file. | ||
1510 | // In this case, force the graphics settings back to recommended, but only | ||
1511 | // do it once. JC | ||
1512 | std::string gpu_string = gFeatureManagerp->getGPUString(); | ||
1513 | LLString::toLower(gpu_string); | ||
1514 | bool upgrade_to_1_15 = (gSavedSettings.getString("LastRunVersion") != "1.15.0"); | ||
1515 | bool mobility_radeon = (gpu_string.find("mobility radeon") != std::string::npos); | ||
1516 | bool mobility_radeon_upgrade_hack = upgrade_to_1_15 && mobility_radeon; | ||
1517 | if (mobility_radeon_upgrade_hack) | ||
1518 | { | ||
1519 | llinfos << "1.15.0 update on Mobility Radeon" << llendl; | ||
1520 | llinfos << "Forcing recommended graphics settings" << llendl; | ||
1521 | llinfos << "Forcing audio off" << llendl; | ||
1522 | gUseAudio = FALSE; | ||
1523 | } | ||
1524 | |||
1239 | if (gFeatureManagerp->isSafe() | 1525 | if (gFeatureManagerp->isSafe() |
1240 | || (gSavedSettings.getS32("LastFeatureVersion") != gFeatureManagerp->getVersion())) | 1526 | || (gSavedSettings.getS32("LastFeatureVersion") != gFeatureManagerp->getVersion()) |
1527 | || mobility_radeon_upgrade_hack) | ||
1241 | { | 1528 | { |
1242 | gFeatureManagerp->applyRecommendedFeatures(); | 1529 | gFeatureManagerp->applyRecommendedFeatures(); |
1243 | } | 1530 | } |
@@ -1249,16 +1536,30 @@ LLViewerWindow::LLViewerWindow( | |||
1249 | idx = LLViewerImageList::getMaxVideoRamSetting(-2); // get max recommended setting | 1536 | idx = LLViewerImageList::getMaxVideoRamSetting(-2); // get max recommended setting |
1250 | gSavedSettings.setS32("GraphicsCardMemorySetting", idx); | 1537 | gSavedSettings.setS32("GraphicsCardMemorySetting", idx); |
1251 | } | 1538 | } |
1252 | 1539 | ||
1540 | // If we crashed while initializng GL stuff last time, disable certain features | ||
1541 | if (gSavedSettings.getBOOL("RenderInitError")) | ||
1542 | { | ||
1543 | mInitAlert = "DisplaySettingsNoShaders"; | ||
1544 | gSavedSettings.setBOOL("VertexShaderEnable", FALSE); | ||
1545 | } | ||
1546 | |||
1253 | if (!gNoRender) | 1547 | if (!gNoRender) |
1254 | { | 1548 | { |
1255 | // | 1549 | // |
1256 | // Initialize GL stuff | 1550 | // Initialize GL stuff |
1257 | // | 1551 | // |
1258 | 1552 | ||
1553 | // Set this flag in case we crash while initializing GL | ||
1554 | gSavedSettings.setBOOL("RenderInitError", TRUE); | ||
1555 | gSavedSettings.saveToFile( gSettingsFileName, TRUE ); | ||
1556 | |||
1259 | gPipeline.init(); | 1557 | gPipeline.init(); |
1260 | stop_glerror(); | 1558 | stop_glerror(); |
1261 | initGLDefaults(); | 1559 | initGLDefaults(); |
1560 | |||
1561 | gSavedSettings.setBOOL("RenderInitError", FALSE); | ||
1562 | gSavedSettings.saveToFile( gSettingsFileName, TRUE ); | ||
1262 | } | 1563 | } |
1263 | 1564 | ||
1264 | // | 1565 | // |
@@ -1303,6 +1604,9 @@ LLViewerWindow::LLViewerWindow( | |||
1303 | 1604 | ||
1304 | // sync the keyboard's setting with the saved setting | 1605 | // sync the keyboard's setting with the saved setting |
1305 | gSavedSettings.getControl("NumpadControl")->firePropertyChanged(); | 1606 | gSavedSettings.getControl("NumpadControl")->firePropertyChanged(); |
1607 | |||
1608 | mDebugText = new LLDebugText(this); | ||
1609 | |||
1306 | } | 1610 | } |
1307 | 1611 | ||
1308 | void LLViewerWindow::initGLDefaults() | 1612 | void LLViewerWindow::initGLDefaults() |
@@ -1651,6 +1955,8 @@ void LLViewerWindow::initWorldUI() | |||
1651 | 1955 | ||
1652 | LLViewerWindow::~LLViewerWindow() | 1956 | LLViewerWindow::~LLViewerWindow() |
1653 | { | 1957 | { |
1958 | delete mDebugText; | ||
1959 | |||
1654 | gSavedSettings.setS32("FloaterViewBottom", gFloaterView->getRect().mBottom); | 1960 | gSavedSettings.setS32("FloaterViewBottom", gFloaterView->getRect().mBottom); |
1655 | 1961 | ||
1656 | // Cleanup global views | 1962 | // Cleanup global views |
@@ -1864,6 +2170,10 @@ void LLViewerWindow::reshape(S32 width, S32 height) | |||
1864 | } | 2170 | } |
1865 | } | 2171 | } |
1866 | 2172 | ||
2173 | void LLViewerWindow::drawDebugText() | ||
2174 | { | ||
2175 | mDebugText->draw(); | ||
2176 | } | ||
1867 | 2177 | ||
1868 | void LLViewerWindow::draw() | 2178 | void LLViewerWindow::draw() |
1869 | { | 2179 | { |
@@ -1935,7 +2245,7 @@ void LLViewerWindow::draw() | |||
1935 | 2245 | ||
1936 | { | 2246 | { |
1937 | LLGLSTexture gls_texture; | 2247 | LLGLSTexture gls_texture; |
1938 | show_text_gl(); | 2248 | drawDebugText(); |
1939 | } | 2249 | } |
1940 | 2250 | ||
1941 | if (gToolMgr) | 2251 | if (gToolMgr) |
@@ -1947,7 +2257,7 @@ void LLViewerWindow::draw() | |||
1947 | if( gAgent.cameraMouselook() ) | 2257 | if( gAgent.cameraMouselook() ) |
1948 | { | 2258 | { |
1949 | drawMouselookInstructions(); | 2259 | drawMouselookInstructions(); |
1950 | stop_glerror(); | 2260 | stop_glerror(); |
1951 | } | 2261 | } |
1952 | 2262 | ||
1953 | // Draw all nested UI views. | 2263 | // Draw all nested UI views. |
@@ -1955,16 +2265,16 @@ void LLViewerWindow::draw() | |||
1955 | mRootView->draw(); | 2265 | mRootView->draw(); |
1956 | 2266 | ||
1957 | // Draw optional on-top-of-everyone view | 2267 | // Draw optional on-top-of-everyone view |
1958 | LLView* top_view = gFocusMgr.getTopView(); | 2268 | LLUICtrl* top_ctrl = gFocusMgr.getTopCtrl(); |
1959 | if (top_view && top_view->getVisible()) | 2269 | if (top_ctrl && top_ctrl->getVisible()) |
1960 | { | 2270 | { |
1961 | S32 screen_x, screen_y; | 2271 | S32 screen_x, screen_y; |
1962 | top_view->localPointToScreen(0, 0, &screen_x, &screen_y); | 2272 | top_ctrl->localPointToScreen(0, 0, &screen_x, &screen_y); |
1963 | 2273 | ||
1964 | glMatrixMode(GL_MODELVIEW); | 2274 | glMatrixMode(GL_MODELVIEW); |
1965 | LLUI::pushMatrix(); | 2275 | LLUI::pushMatrix(); |
1966 | LLUI::translate( (F32) screen_x, (F32) screen_y, 0.f); | 2276 | LLUI::translate( (F32) screen_x, (F32) screen_y, 0.f); |
1967 | top_view->draw(); | 2277 | top_ctrl->draw(); |
1968 | LLUI::popMatrix(); | 2278 | LLUI::popMatrix(); |
1969 | } | 2279 | } |
1970 | 2280 | ||
@@ -2084,7 +2394,7 @@ BOOL LLViewerWindow::handleKey(KEY key, MASK mask) | |||
2084 | // cursor modes, etc, and re-enable. | 2394 | // cursor modes, etc, and re-enable. |
2085 | //if (gFocusMgr.getMouseCapture()) | 2395 | //if (gFocusMgr.getMouseCapture()) |
2086 | //{ | 2396 | //{ |
2087 | // gFocusMgr.setMouseCapture(NULL, NULL); | 2397 | // gFocusMgr.setMouseCapture(NULL); |
2088 | // return TRUE; | 2398 | // return TRUE; |
2089 | //} | 2399 | //} |
2090 | } | 2400 | } |
@@ -2150,10 +2460,10 @@ BOOL LLViewerWindow::handleKey(KEY key, MASK mask) | |||
2150 | 2460 | ||
2151 | // Topmost view gets a chance before the hierarchy | 2461 | // Topmost view gets a chance before the hierarchy |
2152 | // *FIX: get rid of this? | 2462 | // *FIX: get rid of this? |
2153 | LLView* top_view = gFocusMgr.getTopView(); | 2463 | LLUICtrl* top_ctrl = gFocusMgr.getTopCtrl(); |
2154 | if (top_view) | 2464 | if (top_ctrl) |
2155 | { | 2465 | { |
2156 | if( top_view->handleKey( key, mask, TRUE ) ) | 2466 | if( top_ctrl->handleKey( key, mask, TRUE ) ) |
2157 | { | 2467 | { |
2158 | return TRUE; | 2468 | return TRUE; |
2159 | } | 2469 | } |
@@ -2226,8 +2536,8 @@ BOOL LLViewerWindow::handleUnicodeChar(llwchar uni_char, MASK mask) | |||
2226 | } | 2536 | } |
2227 | 2537 | ||
2228 | // Topmost view gets a chance before the hierarchy | 2538 | // Topmost view gets a chance before the hierarchy |
2229 | LLView* top_view = gFocusMgr.getTopView(); | 2539 | LLUICtrl* top_ctrl = gFocusMgr.getTopCtrl(); |
2230 | if (top_view && top_view->handleUnicodeChar( uni_char, FALSE ) ) | 2540 | if (top_ctrl && top_ctrl->handleUnicodeChar( uni_char, FALSE ) ) |
2231 | { | 2541 | { |
2232 | return TRUE; | 2542 | return TRUE; |
2233 | } | 2543 | } |
@@ -2263,13 +2573,13 @@ void LLViewerWindow::handleScrollWheel(S32 clicks) | |||
2263 | return; | 2573 | return; |
2264 | } | 2574 | } |
2265 | 2575 | ||
2266 | LLView* top_view = gFocusMgr.getTopView(); | 2576 | LLUICtrl* top_ctrl = gFocusMgr.getTopCtrl(); |
2267 | if (top_view) | 2577 | if (top_ctrl) |
2268 | { | 2578 | { |
2269 | S32 local_x; | 2579 | S32 local_x; |
2270 | S32 local_y; | 2580 | S32 local_y; |
2271 | top_view->screenPointToLocal( mCurrentMousePoint.mX, mCurrentMousePoint.mY, &local_x, &local_y ); | 2581 | top_ctrl->screenPointToLocal( mCurrentMousePoint.mX, mCurrentMousePoint.mY, &local_x, &local_y ); |
2272 | if (top_view->handleScrollWheel(local_x, local_y, clicks)) return; | 2582 | if (top_ctrl->handleScrollWheel(local_x, local_y, clicks)) return; |
2273 | } | 2583 | } |
2274 | 2584 | ||
2275 | if (mRootView->handleScrollWheel(mCurrentMousePoint.mX, mCurrentMousePoint.mY, clicks) ) | 2585 | if (mRootView->handleScrollWheel(mCurrentMousePoint.mX, mCurrentMousePoint.mY, clicks) ) |
@@ -2415,8 +2725,8 @@ BOOL LLViewerWindow::handlePerFrameHover() | |||
2415 | 2725 | ||
2416 | BOOL handled = FALSE; | 2726 | BOOL handled = FALSE; |
2417 | 2727 | ||
2418 | BOOL handled_by_top_view = FALSE; | 2728 | BOOL handled_by_top_ctrl = FALSE; |
2419 | LLView* top_view = gFocusMgr.getTopView(); | 2729 | LLUICtrl* top_ctrl = gFocusMgr.getTopCtrl(); |
2420 | 2730 | ||
2421 | LLMouseHandler* mouse_captor = gFocusMgr.getMouseCapture(); | 2731 | LLMouseHandler* mouse_captor = gFocusMgr.getMouseCapture(); |
2422 | if( mouse_captor ) | 2732 | if( mouse_captor ) |
@@ -2438,12 +2748,12 @@ BOOL LLViewerWindow::handlePerFrameHover() | |||
2438 | } | 2748 | } |
2439 | else | 2749 | else |
2440 | { | 2750 | { |
2441 | if (top_view) | 2751 | if (top_ctrl) |
2442 | { | 2752 | { |
2443 | S32 local_x, local_y; | 2753 | S32 local_x, local_y; |
2444 | top_view->screenPointToLocal( x, y, &local_x, &local_y ); | 2754 | top_ctrl->screenPointToLocal( x, y, &local_x, &local_y ); |
2445 | handled = top_view->pointInView(local_x, local_y) && top_view->handleHover(local_x, local_y, mask); | 2755 | handled = top_ctrl->pointInView(local_x, local_y) && top_ctrl->handleHover(local_x, local_y, mask); |
2446 | handled_by_top_view = TRUE; | 2756 | handled_by_top_ctrl = TRUE; |
2447 | } | 2757 | } |
2448 | 2758 | ||
2449 | if ( !handled ) | 2759 | if ( !handled ) |
@@ -2530,11 +2840,11 @@ BOOL LLViewerWindow::handlePerFrameHover() | |||
2530 | mouse_captor->screenPointToLocal( x, y, &local_x, &local_y ); | 2840 | mouse_captor->screenPointToLocal( x, y, &local_x, &local_y ); |
2531 | tool_tip_handled = mouse_captor->handleToolTip( local_x, local_y, tool_tip_msg, &screen_sticky_rect ); | 2841 | tool_tip_handled = mouse_captor->handleToolTip( local_x, local_y, tool_tip_msg, &screen_sticky_rect ); |
2532 | } | 2842 | } |
2533 | else if (handled_by_top_view) | 2843 | else if (handled_by_top_ctrl) |
2534 | { | 2844 | { |
2535 | S32 local_x, local_y; | 2845 | S32 local_x, local_y; |
2536 | top_view->screenPointToLocal( x, y, &local_x, &local_y ); | 2846 | top_ctrl->screenPointToLocal( x, y, &local_x, &local_y ); |
2537 | tool_tip_handled = top_view->handleToolTip( local_x, local_y, tool_tip_msg, &screen_sticky_rect ); | 2847 | tool_tip_handled = top_ctrl->handleToolTip( local_x, local_y, tool_tip_msg, &screen_sticky_rect ); |
2538 | } | 2848 | } |
2539 | else | 2849 | else |
2540 | { | 2850 | { |
@@ -3026,7 +3336,7 @@ void LLViewerWindow::hitObjectOrLandGlobalAsync(S32 x, S32 y_from_bot, MASK mask | |||
3026 | glViewport(scaled_x - (PICK_HALF_WIDTH + 2), scaled_y - (PICK_HALF_WIDTH + 2), PICK_DIAMETER + 4, PICK_DIAMETER + 4); | 3336 | glViewport(scaled_x - (PICK_HALF_WIDTH + 2), scaled_y - (PICK_HALF_WIDTH + 2), PICK_DIAMETER + 4, PICK_DIAMETER + 4); |
3027 | stop_glerror(); | 3337 | stop_glerror(); |
3028 | 3338 | ||
3029 | glClearColor(0.f, 0.f, 0.f, 1.f); | 3339 | glClearColor(0.f, 0.f, 0.f, 0.f); |
3030 | glClear(GL_DEPTH_BUFFER_BIT | GL_COLOR_BUFFER_BIT | GL_STENCIL_BUFFER_BIT); | 3340 | glClear(GL_DEPTH_BUFFER_BIT | GL_COLOR_BUFFER_BIT | GL_STENCIL_BUFFER_BIT); |
3031 | 3341 | ||
3032 | // Draw the objects so the user can select them. | 3342 | // Draw the objects so the user can select them. |
@@ -3117,7 +3427,7 @@ void LLViewerWindow::hitUIElementAsync(S32 x, S32 y_from_bot, MASK mask, void (* | |||
3117 | glViewport(x - (PICK_HALF_WIDTH + 2), y_from_bot - (PICK_HALF_WIDTH + 2), PICK_DIAMETER + 4, PICK_DIAMETER + 4); | 3427 | glViewport(x - (PICK_HALF_WIDTH + 2), y_from_bot - (PICK_HALF_WIDTH + 2), PICK_DIAMETER + 4, PICK_DIAMETER + 4); |
3118 | stop_glerror(); | 3428 | stop_glerror(); |
3119 | 3429 | ||
3120 | glClearColor(0.f, 0.f, 0.f, 1.f); | 3430 | glClearColor(0.f, 0.f, 0.f, 0.f); |
3121 | glClear(GL_DEPTH_BUFFER_BIT | GL_COLOR_BUFFER_BIT); | 3431 | glClear(GL_DEPTH_BUFFER_BIT | GL_COLOR_BUFFER_BIT); |
3122 | 3432 | ||
3123 | // Draw the objects so the user can select them. | 3433 | // Draw the objects so the user can select them. |
@@ -3993,7 +4303,7 @@ BOOL LLViewerWindow::rawSnapshot(LLImageRaw *raw, S32 image_width, S32 image_hei | |||
3993 | gDisplaySwapBuffers = FALSE; | 4303 | gDisplaySwapBuffers = FALSE; |
3994 | if (type == SNAPSHOT_TYPE_OBJECT_ID) | 4304 | if (type == SNAPSHOT_TYPE_OBJECT_ID) |
3995 | { | 4305 | { |
3996 | glClearColor(0.f, 0.f, 0.f, 1.f); | 4306 | glClearColor(0.f, 0.f, 0.f, 0.f); |
3997 | glClear(GL_DEPTH_BUFFER_BIT | GL_COLOR_BUFFER_BIT | GL_STENCIL_BUFFER_BIT); | 4307 | glClear(GL_DEPTH_BUFFER_BIT | GL_COLOR_BUFFER_BIT | GL_STENCIL_BUFFER_BIT); |
3998 | 4308 | ||
3999 | gCamera->setZoomParameters(scale_factor, subimage_x+(subimage_y*llceil(scale_factor))); | 4309 | gCamera->setZoomParameters(scale_factor, subimage_x+(subimage_y*llceil(scale_factor))); |
@@ -4174,9 +4484,9 @@ BOOL LLViewerWindow::childHasKeyboardFocus(const LLView* parent) const | |||
4174 | return gFocusMgr.childHasKeyboardFocus( parent ); | 4484 | return gFocusMgr.childHasKeyboardFocus( parent ); |
4175 | } | 4485 | } |
4176 | 4486 | ||
4177 | void LLViewerWindow::setMouseCapture(LLMouseHandler* new_captor,void (*on_capture_lost)(LLMouseHandler* old_captor)) | 4487 | void LLViewerWindow::setMouseCapture(LLMouseHandler* new_captor) |
4178 | { | 4488 | { |
4179 | gFocusMgr.setMouseCapture( new_captor, on_capture_lost ); | 4489 | gFocusMgr.setMouseCapture( new_captor ); |
4180 | } | 4490 | } |
4181 | 4491 | ||
4182 | LLMouseHandler* LLViewerWindow::getMouseCaptor() const | 4492 | LLMouseHandler* LLViewerWindow::getMouseCaptor() const |
@@ -4184,11 +4494,6 @@ LLMouseHandler* LLViewerWindow::getMouseCaptor() const | |||
4184 | return gFocusMgr.getMouseCapture(); | 4494 | return gFocusMgr.getMouseCapture(); |
4185 | } | 4495 | } |
4186 | 4496 | ||
4187 | BOOL LLViewerWindow::hasMouseCapture(const LLMouseHandler* possible_captor) const | ||
4188 | { | ||
4189 | return possible_captor == gFocusMgr.getMouseCapture(); | ||
4190 | } | ||
4191 | |||
4192 | S32 LLViewerWindow::getWindowHeight() const | 4497 | S32 LLViewerWindow::getWindowHeight() const |
4193 | { | 4498 | { |
4194 | return mVirtualWindowRect.getHeight(); | 4499 | return mVirtualWindowRect.getHeight(); |
@@ -4209,19 +4514,19 @@ S32 LLViewerWindow::getWindowDisplayWidth() const | |||
4209 | return mWindowRect.getWidth(); | 4514 | return mWindowRect.getWidth(); |
4210 | } | 4515 | } |
4211 | 4516 | ||
4212 | LLView* LLViewerWindow::getTopView() const | 4517 | LLUICtrl* LLViewerWindow::getTopCtrl() const |
4213 | { | 4518 | { |
4214 | return gFocusMgr.getTopView(); | 4519 | return gFocusMgr.getTopCtrl(); |
4215 | } | 4520 | } |
4216 | 4521 | ||
4217 | BOOL LLViewerWindow::hasTopView(LLView* view) const | 4522 | BOOL LLViewerWindow::hasTopCtrl(LLView* view) const |
4218 | { | 4523 | { |
4219 | return view == gFocusMgr.getTopView(); | 4524 | return view == gFocusMgr.getTopCtrl(); |
4220 | } | 4525 | } |
4221 | 4526 | ||
4222 | void LLViewerWindow::setTopView(LLView* new_top,void (*on_top_lost)(LLView* old_top)) | 4527 | void LLViewerWindow::setTopCtrl(LLUICtrl* new_top) |
4223 | { | 4528 | { |
4224 | gFocusMgr.setTopView( new_top, on_top_lost ); | 4529 | gFocusMgr.setTopCtrl( new_top ); |
4225 | } | 4530 | } |
4226 | 4531 | ||
4227 | void LLViewerWindow::setupViewport(S32 x_offset, S32 y_offset) | 4532 | void LLViewerWindow::setupViewport(S32 x_offset, S32 y_offset) |
@@ -4829,6 +5134,8 @@ LLAlertDialog* LLViewerWindow::alertXmlEditText(const std::string& xml_filename, | |||
4829 | return alert; | 5134 | return alert; |
4830 | } | 5135 | } |
4831 | 5136 | ||
5137 | //////////////////////////////////////////////////////////////////////////// | ||
5138 | |||
4832 | LLBottomPanel::LLBottomPanel(const LLString &name, const LLRect &rect) : | 5139 | LLBottomPanel::LLBottomPanel(const LLString &name, const LLRect &rect) : |
4833 | LLPanel(name, rect, FALSE), | 5140 | LLPanel(name, rect, FALSE), |
4834 | mIndicator(NULL) | 5141 | mIndicator(NULL) |