diff options
Diffstat (limited to 'linden/indra/newview/llviewerwindow.cpp')
-rw-r--r-- | linden/indra/newview/llviewerwindow.cpp | 68 |
1 files changed, 33 insertions, 35 deletions
diff --git a/linden/indra/newview/llviewerwindow.cpp b/linden/indra/newview/llviewerwindow.cpp index 4c76b8b..9f091dc 100644 --- a/linden/indra/newview/llviewerwindow.cpp +++ b/linden/indra/newview/llviewerwindow.cpp | |||
@@ -43,7 +43,7 @@ | |||
43 | #include "llviewquery.h" | 43 | #include "llviewquery.h" |
44 | #include "llxmltree.h" | 44 | #include "llxmltree.h" |
45 | //#include "llviewercamera.h" | 45 | //#include "llviewercamera.h" |
46 | #include "llglimmediate.h" | 46 | #include "llrender.h" |
47 | 47 | ||
48 | #include "llvoiceclient.h" // for push-to-talk button handling | 48 | #include "llvoiceclient.h" // for push-to-talk button handling |
49 | 49 | ||
@@ -182,6 +182,7 @@ | |||
182 | #include "llviewerdisplay.h" | 182 | #include "llviewerdisplay.h" |
183 | #include "llspatialpartition.h" | 183 | #include "llspatialpartition.h" |
184 | #include "llviewerjoystick.h" | 184 | #include "llviewerjoystick.h" |
185 | #include "llviewernetwork.h" | ||
185 | 186 | ||
186 | #if LL_WINDOWS | 187 | #if LL_WINDOWS |
187 | #include "llwindebug.h" | 188 | #include "llwindebug.h" |
@@ -1529,9 +1530,9 @@ LLViewerWindow::LLViewerWindow( | |||
1529 | ignore_pixel_depth, | 1530 | ignore_pixel_depth, |
1530 | gSavedSettings.getU32("RenderFSAASamples")); | 1531 | gSavedSettings.getU32("RenderFSAASamples")); |
1531 | #if LL_WINDOWS | 1532 | #if LL_WINDOWS |
1532 | if (!LLWinDebug::setupExceptionHandler()) | 1533 | if (!LLWinDebug::checkExceptionHandler()) |
1533 | { | 1534 | { |
1534 | llwarns << " Someone took over my exception handler (post createWindow)!" << llendl; | 1535 | LL_WARNS("Window") << " Someone took over my exception handler (post createWindow)!" << LL_ENDL; |
1535 | } | 1536 | } |
1536 | #endif | 1537 | #endif |
1537 | 1538 | ||
@@ -1542,8 +1543,8 @@ LLViewerWindow::LLViewerWindow( | |||
1542 | llwarns << "Unable to create window, be sure screen is set at 32-bit color and your graphics driver is configured correctly. See README-linux.txt or README-solaris.txt for further information." | 1543 | llwarns << "Unable to create window, be sure screen is set at 32-bit color and your graphics driver is configured correctly. See README-linux.txt or README-solaris.txt for further information." |
1543 | << llendl; | 1544 | << llendl; |
1544 | #else | 1545 | #else |
1545 | llwarns << "Unable to create window, be sure screen is set at 32-bit color in Control Panels->Display->Settings" | 1546 | LL_WARNS("Window") << "Unable to create window, be sure screen is set at 32-bit color in Control Panels->Display->Settings" |
1546 | << llendl; | 1547 | << LL_ENDL; |
1547 | #endif | 1548 | #endif |
1548 | LLAppViewer::instance()->forceExit(1); | 1549 | LLAppViewer::instance()->forceExit(1); |
1549 | } | 1550 | } |
@@ -1569,7 +1570,7 @@ LLViewerWindow::LLViewerWindow( | |||
1569 | // We want to set this stuff up BEFORE we initialize the pipeline, so we can turn off | 1570 | // We want to set this stuff up BEFORE we initialize the pipeline, so we can turn off |
1570 | // stuff like AGP if we think that it'll crash the viewer. | 1571 | // stuff like AGP if we think that it'll crash the viewer. |
1571 | // | 1572 | // |
1572 | llinfos << "Loading feature tables." << llendl; | 1573 | LL_DEBUGS("Window") << "Loading feature tables." << LL_ENDL; |
1573 | 1574 | ||
1574 | LLFeatureManager::getInstance()->init(); | 1575 | LLFeatureManager::getInstance()->init(); |
1575 | 1576 | ||
@@ -1638,7 +1639,7 @@ LLViewerWindow::LLViewerWindow( | |||
1638 | 1639 | ||
1639 | void LLViewerWindow::initGLDefaults() | 1640 | void LLViewerWindow::initGLDefaults() |
1640 | { | 1641 | { |
1641 | gGL.blendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 1642 | gGL.setSceneBlendType(LLRender::BT_ALPHA); |
1642 | glColorMaterial( GL_FRONT_AND_BACK, GL_AMBIENT_AND_DIFFUSE ); | 1643 | glColorMaterial( GL_FRONT_AND_BACK, GL_AMBIENT_AND_DIFFUSE ); |
1643 | 1644 | ||
1644 | F32 ambient[4] = {0.f,0.f,0.f,0.f }; | 1645 | F32 ambient[4] = {0.f,0.f,0.f,0.f }; |
@@ -1656,7 +1657,7 @@ void LLViewerWindow::initGLDefaults() | |||
1656 | 1657 | ||
1657 | glLightModelfv(GL_LIGHT_MODEL_AMBIENT, ambient); | 1658 | glLightModelfv(GL_LIGHT_MODEL_AMBIENT, ambient); |
1658 | 1659 | ||
1659 | glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); | 1660 | gGL.getTexUnit(0)->setTextureBlendType(LLTexUnit::TB_MULT); |
1660 | 1661 | ||
1661 | glCullFace(GL_BACK); | 1662 | glCullFace(GL_BACK); |
1662 | 1663 | ||
@@ -2198,7 +2199,7 @@ void LLViewerWindow::setNormalControlsVisible( BOOL visible ) | |||
2198 | 2199 | ||
2199 | // ...and set the menu color appropriately. | 2200 | // ...and set the menu color appropriately. |
2200 | setMenuBackgroundColor(gAgent.getGodLevel() > GOD_NOT, | 2201 | setMenuBackgroundColor(gAgent.getGodLevel() > GOD_NOT, |
2201 | LLAppViewer::instance()->isInProductionGrid()); | 2202 | LLViewerLogin::getInstance()->isInProductionGrid()); |
2202 | } | 2203 | } |
2203 | 2204 | ||
2204 | if ( gStatusBar ) | 2205 | if ( gStatusBar ) |
@@ -2213,15 +2214,15 @@ void LLViewerWindow::setMenuBackgroundColor(bool god_mode, bool dev_grid) | |||
2213 | LLString::format_map_t args; | 2214 | LLString::format_map_t args; |
2214 | LLColor4 new_bg_color; | 2215 | LLColor4 new_bg_color; |
2215 | 2216 | ||
2216 | if(god_mode && LLAppViewer::instance()->isInProductionGrid()) | 2217 | if(god_mode && LLViewerLogin::getInstance()->isInProductionGrid()) |
2217 | { | 2218 | { |
2218 | new_bg_color = gColors.getColor( "MenuBarGodBgColor" ); | 2219 | new_bg_color = gColors.getColor( "MenuBarGodBgColor" ); |
2219 | } | 2220 | } |
2220 | else if(god_mode && !LLAppViewer::instance()->isInProductionGrid()) | 2221 | else if(god_mode && !LLViewerLogin::getInstance()->isInProductionGrid()) |
2221 | { | 2222 | { |
2222 | new_bg_color = gColors.getColor( "MenuNonProductionGodBgColor" ); | 2223 | new_bg_color = gColors.getColor( "MenuNonProductionGodBgColor" ); |
2223 | } | 2224 | } |
2224 | else if(!god_mode && !LLAppViewer::instance()->isInProductionGrid()) | 2225 | else if(!god_mode && !LLViewerLogin::getInstance()->isInProductionGrid()) |
2225 | { | 2226 | { |
2226 | new_bg_color = gColors.getColor( "MenuNonProductionBgColor" ); | 2227 | new_bg_color = gColors.getColor( "MenuNonProductionBgColor" ); |
2227 | } | 2228 | } |
@@ -3538,7 +3539,7 @@ void LLViewerWindow::hitUIElementAsync(S32 x, S32 y_from_bot, MASK mask, void (* | |||
3538 | const LLVector2& display_scale = getDisplayScale(); | 3539 | const LLVector2& display_scale = getDisplayScale(); |
3539 | glScalef(display_scale.mV[VX], display_scale.mV[VY], 1.f); | 3540 | glScalef(display_scale.mV[VX], display_scale.mV[VY], 1.f); |
3540 | 3541 | ||
3541 | glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); | 3542 | gGL.getTexUnit(0)->setTextureBlendType(LLTexUnit::TB_MULT); |
3542 | 3543 | ||
3543 | // make viewport big enough to handle antialiased frame buffers | 3544 | // make viewport big enough to handle antialiased frame buffers |
3544 | glViewport(x - (PICK_HALF_WIDTH + 2), y_from_bot - (PICK_HALF_WIDTH + 2), PICK_DIAMETER + 4, PICK_DIAMETER + 4); | 3545 | glViewport(x - (PICK_HALF_WIDTH + 2), y_from_bot - (PICK_HALF_WIDTH + 2), PICK_DIAMETER + 4, PICK_DIAMETER + 4); |
@@ -4185,8 +4186,9 @@ void LLViewerWindow::movieSize(S32 new_width, S32 new_height) | |||
4185 | if ( (size.mX != new_width + BORDERWIDTH) | 4186 | if ( (size.mX != new_width + BORDERWIDTH) |
4186 | ||(size.mY != new_height + BORDERHEIGHT)) | 4187 | ||(size.mY != new_height + BORDERHEIGHT)) |
4187 | { | 4188 | { |
4188 | S32 x = gViewerWindow->getWindowWidth(); | 4189 | // use actual display dimensions, not virtual UI dimensions |
4189 | S32 y = gViewerWindow->getWindowHeight(); | 4190 | S32 x = gViewerWindow->getWindowDisplayWidth(); |
4191 | S32 y = gViewerWindow->getWindowDisplayHeight(); | ||
4190 | BORDERWIDTH = size.mX - x; | 4192 | BORDERWIDTH = size.mX - x; |
4191 | BORDERHEIGHT = size.mY- y; | 4193 | BORDERHEIGHT = size.mY- y; |
4192 | LLCoordScreen new_size(new_width + BORDERWIDTH, | 4194 | LLCoordScreen new_size(new_width + BORDERWIDTH, |
@@ -4938,7 +4940,7 @@ void LLViewerWindow::restoreGL(const LLString& progress_message) | |||
4938 | } | 4940 | } |
4939 | llinfos << "...Restoring GL done" << llendl; | 4941 | llinfos << "...Restoring GL done" << llendl; |
4940 | #if LL_WINDOWS | 4942 | #if LL_WINDOWS |
4941 | if (SetUnhandledExceptionFilter(LLWinDebug::handleException) != LLWinDebug::handleException) | 4943 | if(!LLWinDebug::checkExceptionHandler()) |
4942 | { | 4944 | { |
4943 | llwarns << " Someone took over my exception handler (post restoreGL)!" << llendl; | 4945 | llwarns << " Someone took over my exception handler (post restoreGL)!" << llendl; |
4944 | } | 4946 | } |
@@ -4951,21 +4953,21 @@ void LLViewerWindow::initFonts(F32 zoom_factor) | |||
4951 | { | 4953 | { |
4952 | LLFontGL::destroyGL(); | 4954 | LLFontGL::destroyGL(); |
4953 | LLFontGL::initDefaultFonts( gSavedSettings.getF32("FontScreenDPI"), | 4955 | LLFontGL::initDefaultFonts( gSavedSettings.getF32("FontScreenDPI"), |
4954 | mDisplayScale.mV[VX] * zoom_factor, | 4956 | mDisplayScale.mV[VX] * zoom_factor, |
4955 | mDisplayScale.mV[VY] * zoom_factor, | 4957 | mDisplayScale.mV[VY] * zoom_factor, |
4956 | gSavedSettings.getString("FontMonospace"), | 4958 | gSavedSettings.getString("FontMonospace"), |
4957 | gSavedSettings.getF32("FontSizeMonospace"), | 4959 | gSavedSettings.getF32("FontSizeMonospace"), |
4958 | gSavedSettings.getString("FontSansSerif"), | 4960 | gSavedSettings.getString("FontSansSerif"), |
4959 | gSavedSettings.getString("FontSansSerifFallback"), | 4961 | gSavedSettings.getString("FontSansSerifFallback"), |
4960 | gSavedSettings.getF32("FontSansSerifFallbackScale"), | 4962 | gSavedSettings.getF32("FontSansSerifFallbackScale"), |
4961 | gSavedSettings.getF32("FontSizeSmall"), | 4963 | gSavedSettings.getF32("FontSizeSmall"), |
4962 | gSavedSettings.getF32("FontSizeMedium"), | 4964 | gSavedSettings.getF32("FontSizeMedium"), |
4963 | gSavedSettings.getF32("FontSizeLarge"), | 4965 | gSavedSettings.getF32("FontSizeLarge"), |
4964 | gSavedSettings.getF32("FontSizeHuge"), | 4966 | gSavedSettings.getF32("FontSizeHuge"), |
4965 | gSavedSettings.getString("FontSansSerifBold"), | 4967 | gSavedSettings.getString("FontSansSerifBold"), |
4966 | gSavedSettings.getF32("FontSizeMedium"), | 4968 | gSavedSettings.getF32("FontSizeMedium"), |
4967 | gDirUtilp->getAppRODataDir() | 4969 | gDirUtilp->getAppRODataDir() |
4968 | ); | 4970 | ); |
4969 | } | 4971 | } |
4970 | void LLViewerWindow::toggleFullscreen(BOOL show_progress) | 4972 | void LLViewerWindow::toggleFullscreen(BOOL show_progress) |
4971 | { | 4973 | { |
@@ -5018,20 +5020,16 @@ BOOL LLViewerWindow::checkSettings() | |||
5018 | return FALSE; | 5020 | return FALSE; |
5019 | } | 5021 | } |
5020 | 5022 | ||
5021 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
5022 | LLGLState::checkStates(); | 5023 | LLGLState::checkStates(); |
5023 | LLGLState::checkTextureChannels(); | 5024 | LLGLState::checkTextureChannels(); |
5024 | #endif | ||
5025 | changeDisplaySettings(TRUE, | 5025 | changeDisplaySettings(TRUE, |
5026 | LLCoordScreen(gSavedSettings.getS32("FullScreenWidth"), | 5026 | LLCoordScreen(gSavedSettings.getS32("FullScreenWidth"), |
5027 | gSavedSettings.getS32("FullScreenHeight")), | 5027 | gSavedSettings.getS32("FullScreenHeight")), |
5028 | gSavedSettings.getBOOL("DisableVerticalSync"), | 5028 | gSavedSettings.getBOOL("DisableVerticalSync"), |
5029 | mShowFullscreenProgress); | 5029 | mShowFullscreenProgress); |
5030 | 5030 | ||
5031 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
5032 | LLGLState::checkStates(); | 5031 | LLGLState::checkStates(); |
5033 | LLGLState::checkTextureChannels(); | 5032 | LLGLState::checkTextureChannels(); |
5034 | #endif | ||
5035 | return TRUE; | 5033 | return TRUE; |
5036 | } | 5034 | } |
5037 | return FALSE; | 5035 | return FALSE; |