diff options
author | Jacek Antonelli | 2008-08-15 23:44:50 -0500 |
---|---|---|
committer | Jacek Antonelli | 2008-08-15 23:44:50 -0500 |
commit | 89fe5dab825a62a0e3fd8d248cbc91c65eb2a426 (patch) | |
tree | bcff14b7888d04a2fec799c59369f6095224bd08 /linden/indra/newview/llviewerdisplay.cpp | |
parent | Second Life viewer sources 1.13.3.2 (diff) | |
download | meta-impy-89fe5dab825a62a0e3fd8d248cbc91c65eb2a426.zip meta-impy-89fe5dab825a62a0e3fd8d248cbc91c65eb2a426.tar.gz meta-impy-89fe5dab825a62a0e3fd8d248cbc91c65eb2a426.tar.bz2 meta-impy-89fe5dab825a62a0e3fd8d248cbc91c65eb2a426.tar.xz |
Second Life viewer sources 1.14.0.0
Diffstat (limited to '')
-rw-r--r-- | linden/indra/newview/llviewerdisplay.cpp | 245 |
1 files changed, 190 insertions, 55 deletions
diff --git a/linden/indra/newview/llviewerdisplay.cpp b/linden/indra/newview/llviewerdisplay.cpp index f09e34c..071b699 100644 --- a/linden/indra/newview/llviewerdisplay.cpp +++ b/linden/indra/newview/llviewerdisplay.cpp | |||
@@ -63,6 +63,9 @@ | |||
63 | #include "llfloatertools.h" | 63 | #include "llfloatertools.h" |
64 | #include "llviewerimagelist.h" | 64 | #include "llviewerimagelist.h" |
65 | #include "llfocusmgr.h" | 65 | #include "llfocusmgr.h" |
66 | #include "llcubemap.h" | ||
67 | #include "llviewerregion.h" | ||
68 | #include "lldrawpoolwater.h" | ||
66 | 69 | ||
67 | extern U32 gFrameCount; | 70 | extern U32 gFrameCount; |
68 | extern LLPointer<LLImageGL> gStartImageGL; | 71 | extern LLPointer<LLImageGL> gStartImageGL; |
@@ -103,8 +106,12 @@ void display_startup() | |||
103 | return; | 106 | return; |
104 | } | 107 | } |
105 | 108 | ||
106 | LLDynamicTexture::updateAllInstances(); | 109 | // Required for HTML update in login screen |
107 | 110 | static S32 frame_count = 0; | |
111 | if (frame_count++ > 1) // make sure we have rendered a frame first | ||
112 | { | ||
113 | LLDynamicTexture::updateAllInstances(); | ||
114 | } | ||
108 | glClear(GL_DEPTH_BUFFER_BIT | GL_COLOR_BUFFER_BIT | GL_STENCIL_BUFFER_BIT); | 115 | glClear(GL_DEPTH_BUFFER_BIT | GL_COLOR_BUFFER_BIT | GL_STENCIL_BUFFER_BIT); |
109 | LLGLSDefault gls_default; | 116 | LLGLSDefault gls_default; |
110 | LLGLSUIDefault gls_ui; | 117 | LLGLSUIDefault gls_ui; |
@@ -174,11 +181,8 @@ void display(BOOL rebuild, F32 zoom_factor, int subfield) | |||
174 | // Clean up memory the pools may have allocated | 181 | // Clean up memory the pools may have allocated |
175 | if (rebuild) | 182 | if (rebuild) |
176 | { | 183 | { |
177 | if (!gViewerWindow->renderingFastFrame()) | 184 | gFrameStats.start(LLFrameStats::REBUILD); |
178 | { | 185 | gPipeline.rebuildPools(); |
179 | gFrameStats.start(LLFrameStats::REBUILD); | ||
180 | gPipeline.rebuildPools(); | ||
181 | } | ||
182 | } | 186 | } |
183 | return; | 187 | return; |
184 | } | 188 | } |
@@ -378,14 +382,6 @@ void display(BOOL rebuild, F32 zoom_factor, int subfield) | |||
378 | } | 382 | } |
379 | } | 383 | } |
380 | 384 | ||
381 | if (rebuild) | ||
382 | { | ||
383 | if (gViewerWindow->renderingFastFrame()) | ||
384 | { | ||
385 | gFrameStats.start(LLFrameStats::STATE_SORT); | ||
386 | gFrameStats.start(LLFrameStats::REBUILD); | ||
387 | } | ||
388 | } | ||
389 | 385 | ||
390 | ///////////////////////////// | 386 | ///////////////////////////// |
391 | // | 387 | // |
@@ -394,6 +390,7 @@ void display(BOOL rebuild, F32 zoom_factor, int subfield) | |||
394 | // | 390 | // |
395 | 391 | ||
396 | gCamera->setZoomParameters(zoom_factor, subfield); | 392 | gCamera->setZoomParameters(zoom_factor, subfield); |
393 | gCamera->setNear(MIN_NEAR_PLANE); | ||
397 | 394 | ||
398 | ////////////////////////// | 395 | ////////////////////////// |
399 | // | 396 | // |
@@ -409,6 +406,8 @@ void display(BOOL rebuild, F32 zoom_factor, int subfield) | |||
409 | else if (!gViewerWindow->isPickPending()) | 406 | else if (!gViewerWindow->isPickPending()) |
410 | { | 407 | { |
411 | glClear( GL_DEPTH_BUFFER_BIT | GL_STENCIL_BUFFER_BIT ); | 408 | glClear( GL_DEPTH_BUFFER_BIT | GL_STENCIL_BUFFER_BIT ); |
409 | //DEBUG TEMPORARY | ||
410 | glClear(GL_COLOR_BUFFER_BIT); | ||
412 | } | 411 | } |
413 | gViewerWindow->setupViewport(); | 412 | gViewerWindow->setupViewport(); |
414 | 413 | ||
@@ -429,7 +428,13 @@ void display(BOOL rebuild, F32 zoom_factor, int subfield) | |||
429 | glClearColor(0.5f, 0.5f, 0.5f, 0.f); | 428 | glClearColor(0.5f, 0.5f, 0.5f, 0.f); |
430 | glClear(GL_COLOR_BUFFER_BIT); | 429 | glClear(GL_COLOR_BUFFER_BIT); |
431 | glPolygonMode(GL_FRONT_AND_BACK, GL_LINE); | 430 | glPolygonMode(GL_FRONT_AND_BACK, GL_LINE); |
431 | LLPipeline::sUseOcclusion = FALSE; | ||
432 | } | 432 | } |
433 | else | ||
434 | { | ||
435 | LLPipeline::sUseOcclusion = gSavedSettings.getBOOL("UseOcclusion") && gGLManager.mHasOcclusionQuery; | ||
436 | } | ||
437 | |||
433 | stop_glerror(); | 438 | stop_glerror(); |
434 | 439 | ||
435 | /////////////////////////////////////// | 440 | /////////////////////////////////////// |
@@ -442,7 +447,8 @@ void display(BOOL rebuild, F32 zoom_factor, int subfield) | |||
442 | glLightModelfv (GL_LIGHT_MODEL_AMBIENT,one); | 447 | glLightModelfv (GL_LIGHT_MODEL_AMBIENT,one); |
443 | stop_glerror(); | 448 | stop_glerror(); |
444 | 449 | ||
445 | //LLGLState::verify(); | 450 | //Increment drawable frame counter |
451 | LLDrawable::incrementVisible(); | ||
446 | 452 | ||
447 | ///////////////////////////////////// | 453 | ///////////////////////////////////// |
448 | // | 454 | // |
@@ -452,6 +458,11 @@ void display(BOOL rebuild, F32 zoom_factor, int subfield) | |||
452 | // | 458 | // |
453 | if (!gDisconnected) | 459 | if (!gDisconnected) |
454 | { | 460 | { |
461 | if (gPipeline.hasRenderType(LLPipeline::RENDER_TYPE_HUD)) | ||
462 | { //don't draw hud objects in this frame | ||
463 | gPipeline.toggleRenderType(LLPipeline::RENDER_TYPE_HUD); | ||
464 | } | ||
465 | |||
455 | LLFastTimer t(LLFastTimer::FTM_WORLD_UPDATE); | 466 | LLFastTimer t(LLFastTimer::FTM_WORLD_UPDATE); |
456 | stop_glerror(); | 467 | stop_glerror(); |
457 | display_update_camera(); | 468 | display_update_camera(); |
@@ -467,34 +478,41 @@ void display(BOOL rebuild, F32 zoom_factor, int subfield) | |||
467 | gPipeline.updateGeom(max_geom_update_time); | 478 | gPipeline.updateGeom(max_geom_update_time); |
468 | stop_glerror(); | 479 | stop_glerror(); |
469 | 480 | ||
481 | LLSpatialPartition* part = gPipeline.getSpatialPartition(LLPipeline::PARTITION_VOLUME); | ||
482 | part->processImagery(gCamera); | ||
483 | |||
484 | display_update_camera(); | ||
485 | |||
470 | gFrameStats.start(LLFrameStats::UPDATE_CULL); | 486 | gFrameStats.start(LLFrameStats::UPDATE_CULL); |
471 | gPipeline.updateCull(); | 487 | gPipeline.updateCull(*gCamera); |
472 | stop_glerror(); | 488 | stop_glerror(); |
473 | 489 | ||
474 | if (rebuild && !gViewerWindow->renderingFastFrame()) | 490 | /////////////////////////////////// |
491 | // | ||
492 | // StateSort | ||
493 | // | ||
494 | // Responsible for taking visible objects, and adding them to the appropriate draw orders. | ||
495 | // In the case of alpha objects, z-sorts them first. | ||
496 | // Also creates special lists for outlines and selected face rendering. | ||
497 | // | ||
475 | { | 498 | { |
476 | LLFastTimer t(LLFastTimer::FTM_REBUILD); | 499 | LLFastTimer t(LLFastTimer::FTM_REBUILD); |
477 | |||
478 | /////////////////////////////////// | ||
479 | // | ||
480 | // StateSort | ||
481 | // | ||
482 | // Responsible for taking visible objects, and adding them to the appropriate draw orders. | ||
483 | // In the case of alpha objects, z-sorts them first. | ||
484 | // Also creates special lists for outlines and selected face rendering. | ||
485 | // | ||
486 | gFrameStats.start(LLFrameStats::STATE_SORT); | ||
487 | gPipeline.stateSort(); | ||
488 | stop_glerror(); | ||
489 | 500 | ||
490 | ////////////////////////////////////// | 501 | gFrameStats.start(LLFrameStats::STATE_SORT); |
491 | // | 502 | gPipeline.stateSort(*gCamera); |
492 | // rebuildPools | ||
493 | // | ||
494 | // | ||
495 | gFrameStats.start(LLFrameStats::REBUILD); | ||
496 | gPipeline.rebuildPools(); | ||
497 | stop_glerror(); | 503 | stop_glerror(); |
504 | |||
505 | if (rebuild) | ||
506 | { | ||
507 | ////////////////////////////////////// | ||
508 | // | ||
509 | // rebuildPools | ||
510 | // | ||
511 | // | ||
512 | gFrameStats.start(LLFrameStats::REBUILD); | ||
513 | gPipeline.rebuildPools(); | ||
514 | stop_glerror(); | ||
515 | } | ||
498 | } | 516 | } |
499 | } | 517 | } |
500 | 518 | ||
@@ -535,19 +553,74 @@ void display(BOOL rebuild, F32 zoom_factor, int subfield) | |||
535 | // glPopMatrix(); | 553 | // glPopMatrix(); |
536 | //} | 554 | //} |
537 | 555 | ||
538 | if (gViewerWindow->renderingFastFrame()) | 556 | if (!(gLogoutRequestSent && gHaveSavedSnapshot) |
539 | { | ||
540 | gFrameStats.start(LLFrameStats::RENDER_SYNC); | ||
541 | gFrameStats.start(LLFrameStats::RENDER_GEOM); | ||
542 | } | ||
543 | else if (!(gLogoutRequestSent && gHaveSavedSnapshot) | ||
544 | && !gRestoreGL | 557 | && !gRestoreGL |
545 | && !gDisconnected) | 558 | && !gDisconnected) |
546 | { | 559 | { |
547 | gPipeline.renderGeom(); | 560 | gPipeline.renderGeom(*gCamera); |
548 | stop_glerror(); | 561 | stop_glerror(); |
549 | } | 562 | } |
550 | 563 | ||
564 | //render hud attachments | ||
565 | glMatrixMode(GL_PROJECTION); | ||
566 | glPushMatrix(); | ||
567 | glMatrixMode(GL_MODELVIEW); | ||
568 | glPushMatrix(); | ||
569 | if (LLPipeline::sShowHUDAttachments && !gDisconnected && setup_hud_matrices(FALSE)) | ||
570 | { | ||
571 | LLCamera hud_cam = *gCamera; | ||
572 | glClear(GL_DEPTH_BUFFER_BIT); | ||
573 | LLVector3 origin = hud_cam.getOrigin(); | ||
574 | hud_cam.setOrigin(-1.f,0,0); | ||
575 | hud_cam.setAxes(LLVector3(1,0,0), LLVector3(0,1,0), LLVector3(0,0,1)); | ||
576 | LLViewerCamera::updateFrustumPlanes(hud_cam, TRUE); | ||
577 | //only render hud objects | ||
578 | U32 mask = gPipeline.getRenderTypeMask(); | ||
579 | gPipeline.setRenderTypeMask(0); | ||
580 | gPipeline.toggleRenderType(LLPipeline::RENDER_TYPE_HUD); | ||
581 | |||
582 | BOOL has_ui = gPipeline.hasRenderDebugFeatureMask(LLPipeline::RENDER_DEBUG_FEATURE_UI); | ||
583 | if (has_ui) | ||
584 | { | ||
585 | gPipeline.toggleRenderDebugFeature((void*) LLPipeline::RENDER_DEBUG_FEATURE_UI); | ||
586 | } | ||
587 | |||
588 | BOOL use_occlusion = gSavedSettings.getBOOL("UseOcclusion"); | ||
589 | gSavedSettings.setBOOL("UseOcclusion", FALSE); | ||
590 | |||
591 | //cull, sort, and render hud objects | ||
592 | gPipeline.updateCull(hud_cam); | ||
593 | |||
594 | gPipeline.toggleRenderType(LLDrawPool::POOL_ALPHA_POST_WATER); | ||
595 | gPipeline.toggleRenderType(LLPipeline::RENDER_TYPE_BUMP); | ||
596 | gPipeline.toggleRenderType(LLPipeline::RENDER_TYPE_SIMPLE); | ||
597 | gPipeline.toggleRenderType(LLPipeline::RENDER_TYPE_VOLUME); | ||
598 | |||
599 | { | ||
600 | LLFastTimer ftm(LLFastTimer::FTM_REBUILD); | ||
601 | gPipeline.stateSort(hud_cam); | ||
602 | } | ||
603 | |||
604 | if (LLVertexBuffer::sEnableVBOs) | ||
605 | { | ||
606 | LLImageGL::sBoundTextureMemory += LLVertexBuffer::sAllocatedBytes; | ||
607 | } | ||
608 | |||
609 | gPipeline.renderGeom(hud_cam); | ||
610 | |||
611 | //restore type mask | ||
612 | gPipeline.setRenderTypeMask(mask); | ||
613 | if (has_ui) | ||
614 | { | ||
615 | gPipeline.toggleRenderDebugFeature((void*) LLPipeline::RENDER_DEBUG_FEATURE_UI); | ||
616 | } | ||
617 | gSavedSettings.setBOOL("UseOcclusion", use_occlusion); | ||
618 | } | ||
619 | glMatrixMode(GL_PROJECTION); | ||
620 | glPopMatrix(); | ||
621 | glMatrixMode(GL_MODELVIEW); | ||
622 | glPopMatrix(); | ||
623 | |||
551 | gFrameStats.start(LLFrameStats::RENDER_UI); | 624 | gFrameStats.start(LLFrameStats::RENDER_UI); |
552 | 625 | ||
553 | if (gHandleKeysAsync) | 626 | if (gHandleKeysAsync) |
@@ -570,6 +643,64 @@ void display(BOOL rebuild, F32 zoom_factor, int subfield) | |||
570 | 643 | ||
571 | } | 644 | } |
572 | 645 | ||
646 | BOOL setup_hud_matrices(BOOL for_select) | ||
647 | { | ||
648 | LLVOAvatar* my_avatarp = gAgent.getAvatarObject(); | ||
649 | if (my_avatarp && my_avatarp->hasHUDAttachment()) | ||
650 | { | ||
651 | if (!for_select) | ||
652 | { | ||
653 | // clamp target zoom level to reasonable values | ||
654 | my_avatarp->mHUDTargetZoom = llclamp(my_avatarp->mHUDTargetZoom, 0.1f, 1.f); | ||
655 | // smoothly interpolate current zoom level | ||
656 | my_avatarp->mHUDCurZoom = lerp(my_avatarp->mHUDCurZoom, my_avatarp->mHUDTargetZoom, LLCriticalDamp::getInterpolant(0.03f)); | ||
657 | } | ||
658 | |||
659 | F32 zoom_level = my_avatarp->mHUDCurZoom; | ||
660 | // clear z buffer and set up transform for hud | ||
661 | if (!for_select) | ||
662 | { | ||
663 | glClear(GL_DEPTH_BUFFER_BIT); | ||
664 | } | ||
665 | LLBBox hud_bbox = my_avatarp->getHUDBBox(); | ||
666 | |||
667 | // set up transform to encompass bounding box of HUD | ||
668 | glMatrixMode(GL_PROJECTION); | ||
669 | glLoadIdentity(); | ||
670 | F32 hud_depth = llmax(1.f, hud_bbox.getExtentLocal().mV[VX] * 1.1f); | ||
671 | if (for_select) | ||
672 | { | ||
673 | //RN: reset viewport to window extents so ortho screen is calculated with proper reference frame | ||
674 | gViewerWindow->setupViewport(); | ||
675 | } | ||
676 | glOrtho(-0.5f * gCamera->getAspect(), 0.5f * gCamera->getAspect(), -0.5f, 0.5f, 0.f, hud_depth); | ||
677 | |||
678 | // apply camera zoom transform (for high res screenshots) | ||
679 | F32 zoom_factor = gCamera->getZoomFactor(); | ||
680 | S16 sub_region = gCamera->getZoomSubRegion(); | ||
681 | if (zoom_factor > 1.f) | ||
682 | { | ||
683 | float offset = zoom_factor - 1.f; | ||
684 | int pos_y = sub_region / llceil(zoom_factor); | ||
685 | int pos_x = sub_region - (pos_y*llceil(zoom_factor)); | ||
686 | glTranslatef(gCamera->getAspect() * 0.5f * (offset - (F32)pos_x * 2.f), 0.5f * (offset - (F32)pos_y * 2.f), 0.f); | ||
687 | glScalef(zoom_factor, zoom_factor, 1.f); | ||
688 | } | ||
689 | |||
690 | glMatrixMode(GL_MODELVIEW); | ||
691 | glLoadIdentity(); | ||
692 | glLoadMatrixf(OGL_TO_CFR_ROTATION); // Load Cory's favorite reference frame | ||
693 | glTranslatef(-hud_bbox.getCenterLocal().mV[VX] + (hud_depth * 0.5f), 0.f, 0.f); | ||
694 | glScalef(zoom_level, zoom_level, zoom_level); | ||
695 | |||
696 | return TRUE; | ||
697 | } | ||
698 | else | ||
699 | { | ||
700 | return FALSE; | ||
701 | } | ||
702 | } | ||
703 | |||
573 | 704 | ||
574 | void render_ui_and_swap() | 705 | void render_ui_and_swap() |
575 | { | 706 | { |
@@ -581,11 +712,11 @@ void render_ui_and_swap() | |||
581 | { | 712 | { |
582 | LLGLSUIDefault gls_ui; | 713 | LLGLSUIDefault gls_ui; |
583 | gPipeline.disableLights(); | 714 | gPipeline.disableLights(); |
584 | 715 | LLVertexBuffer::startRender(); | |
585 | if (gPipeline.hasRenderDebugFeatureMask(LLPipeline::RENDER_DEBUG_FEATURE_UI)) | 716 | if (gPipeline.hasRenderDebugFeatureMask(LLPipeline::RENDER_DEBUG_FEATURE_UI)) |
586 | { | 717 | { |
587 | LLFastTimer t(LLFastTimer::FTM_RENDER_UI); | 718 | LLFastTimer t(LLFastTimer::FTM_RENDER_UI); |
588 | if (!gViewerWindow->renderingFastFrame() && !gDisconnected) | 719 | if (!gDisconnected) |
589 | { | 720 | { |
590 | render_ui_3d(); | 721 | render_ui_3d(); |
591 | #ifndef LL_RELEASE_FOR_DOWNLOAD | 722 | #ifndef LL_RELEASE_FOR_DOWNLOAD |
@@ -598,6 +729,8 @@ void render_ui_and_swap() | |||
598 | LLGLState::checkStates(); | 729 | LLGLState::checkStates(); |
599 | #endif | 730 | #endif |
600 | } | 731 | } |
732 | LLVertexBuffer::stopRender(); | ||
733 | glFlush(); | ||
601 | 734 | ||
602 | // now do the swap buffer | 735 | // now do the swap buffer |
603 | if (gDisplaySwapBuffers) | 736 | if (gDisplaySwapBuffers) |
@@ -605,9 +738,13 @@ void render_ui_and_swap() | |||
605 | LLFastTimer t(LLFastTimer::FTM_SWAP); | 738 | LLFastTimer t(LLFastTimer::FTM_SWAP); |
606 | gViewerWindow->mWindow->swapBuffers(); | 739 | gViewerWindow->mWindow->swapBuffers(); |
607 | } | 740 | } |
608 | } | ||
609 | 741 | ||
610 | gViewerWindow->finishFirstFastFrame(); | 742 | { |
743 | LLFastTimer ftm(LLFastTimer::FTM_CLIENT_COPY); | ||
744 | LLVertexBuffer::clientCopy(0.016); | ||
745 | } | ||
746 | |||
747 | } | ||
611 | } | 748 | } |
612 | 749 | ||
613 | void render_ui_3d() | 750 | void render_ui_3d() |
@@ -622,8 +759,6 @@ void render_ui_3d() | |||
622 | // | 759 | // |
623 | 760 | ||
624 | // Render selections | 761 | // Render selections |
625 | |||
626 | glDisableClientState(GL_VERTEX_ARRAY); | ||
627 | glDisableClientState(GL_COLOR_ARRAY); | 762 | glDisableClientState(GL_COLOR_ARRAY); |
628 | glDisableClientState(GL_TEXTURE_COORD_ARRAY); | 763 | glDisableClientState(GL_TEXTURE_COORD_ARRAY); |
629 | glDisableClientState(GL_NORMAL_ARRAY); | 764 | glDisableClientState(GL_NORMAL_ARRAY); |
@@ -680,7 +815,6 @@ void render_ui_2d() | |||
680 | LLFontGL::sCurOrigin.mY -= llround((F32)gViewerWindow->getWindowHeight() * (F32)pos_y / zoom_factor); | 815 | LLFontGL::sCurOrigin.mY -= llround((F32)gViewerWindow->getWindowHeight() * (F32)pos_y / zoom_factor); |
681 | } | 816 | } |
682 | 817 | ||
683 | |||
684 | stop_glerror(); | 818 | stop_glerror(); |
685 | glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); | 819 | glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); |
686 | 820 | ||
@@ -781,11 +915,12 @@ void render_disconnected_background() | |||
781 | { | 915 | { |
782 | llinfos << "Loading last bitmap..." << llendl; | 916 | llinfos << "Loading last bitmap..." << llendl; |
783 | 917 | ||
784 | char temp_str[MAX_PATH]; | 918 | char temp_str[MAX_PATH]; /* Flawfinder: ignore */ |
785 | strcpy(temp_str, gDirUtilp->getLindenUserDir().c_str()); | 919 | strncpy(temp_str, gDirUtilp->getLindenUserDir().c_str(), MAX_PATH -1); /* Flawfinder: ignore */ |
786 | strcat(temp_str, gDirUtilp->getDirDelimiter().c_str()); | 920 | temp_str[MAX_PATH -1] = '\0'; |
921 | strncat(temp_str, gDirUtilp->getDirDelimiter().c_str(), MAX_PATH - strlen(temp_str) -1); /* Flawfinder: ignore */ | ||
787 | 922 | ||
788 | strcat(temp_str, SCREEN_LAST_FILENAME); | 923 | strcat(temp_str, SCREEN_LAST_FILENAME); /* Flawfinder: ignore */ |
789 | 924 | ||
790 | LLPointer<LLImageBMP> image_bmp = new LLImageBMP; | 925 | LLPointer<LLImageBMP> image_bmp = new LLImageBMP; |
791 | if( !image_bmp->load(temp_str) ) | 926 | if( !image_bmp->load(temp_str) ) |