aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llfloaterimagepreview.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llfloaterimagepreview.cpp')
-rw-r--r--linden/indra/newview/llfloaterimagepreview.cpp150
1 files changed, 66 insertions, 84 deletions
diff --git a/linden/indra/newview/llfloaterimagepreview.cpp b/linden/indra/newview/llfloaterimagepreview.cpp
index 912a4fc..4a8c66e 100644
--- a/linden/indra/newview/llfloaterimagepreview.cpp
+++ b/linden/indra/newview/llfloaterimagepreview.cpp
@@ -4,7 +4,7 @@
4 * 4 *
5 * $LicenseInfo:firstyear=2004&license=viewergpl$ 5 * $LicenseInfo:firstyear=2004&license=viewergpl$
6 * 6 *
7 * Copyright (c) 2004-2008, Linden Research, Inc. 7 * Copyright (c) 2004-2009, Linden Research, Inc.
8 * 8 *
9 * Second Life Viewer Source Code 9 * Second Life Viewer Source Code
10 * The source code in this file ("Source Code") is provided by Linden Lab 10 * The source code in this file ("Source Code") is provided by Linden Lab
@@ -75,7 +75,7 @@ LLFloaterImagePreview::LLFloaterImagePreview(const std::string& filename) :
75{ 75{
76 mLastMouseX = 0; 76 mLastMouseX = 0;
77 mLastMouseY = 0; 77 mLastMouseY = 0;
78 mGLName = 0; 78 mImagep = NULL ;
79 loadImage(mFilenameAndPath); 79 loadImage(mFilenameAndPath);
80} 80}
81 81
@@ -138,10 +138,7 @@ LLFloaterImagePreview::~LLFloaterImagePreview()
138 delete mAvatarPreview; 138 delete mAvatarPreview;
139 delete mSculptedPreview; 139 delete mSculptedPreview;
140 140
141 if (mGLName) 141 mImagep = NULL ;
142 {
143 glDeleteTextures(1, &mGLName );
144 }
145} 142}
146 143
147//static 144//static
@@ -224,44 +221,31 @@ void LLFloaterImagePreview::draw()
224 gl_rect_2d_checkerboard(mPreviewRect); 221 gl_rect_2d_checkerboard(mPreviewRect);
225 LLGLDisable gls_alpha(GL_ALPHA_TEST); 222 LLGLDisable gls_alpha(GL_ALPHA_TEST);
226 223
227 GLenum format_options[4] = { GL_LUMINANCE, GL_LUMINANCE_ALPHA, GL_RGB, GL_RGBA }; 224 if(mImagep.notNull())
228 GLenum format = format_options[mRawImagep->getComponents()-1];
229
230 GLenum internal_format_options[4] = { GL_LUMINANCE8, GL_LUMINANCE8_ALPHA8, GL_RGB8, GL_RGBA8 };
231 GLenum internal_format = internal_format_options[mRawImagep->getComponents()-1];
232
233 if (mGLName)
234 { 225 {
235 LLImageGL::bindExternalTexture( mGLName, 0, GL_TEXTURE_2D ); 226 gGL.getTexUnit(0)->bindManual(LLTexUnit::TT_TEXTURE, mImagep->getTexName());
236 } 227 }
237 else 228 else
238 { 229 {
239 glGenTextures(1, &mGLName ); 230 mImagep = new LLImageGL(mRawImagep, FALSE) ;
240 stop_glerror(); 231
241 232 gGL.getTexUnit(0)->unbind(mImagep->getTarget()) ;
242 LLImageGL::bindExternalTexture( mGLName, 0, GL_TEXTURE_2D ); 233 gGL.getTexUnit(0)->bindManual(LLTexUnit::TT_TEXTURE, mImagep->getTexName());
243 stop_glerror();
244
245 glTexImage2D(
246 GL_TEXTURE_2D, 0, internal_format,
247 mRawImagep->getWidth(), mRawImagep->getHeight(),
248 0, format, GL_UNSIGNED_BYTE, mRawImagep->getData());
249 stop_glerror(); 234 stop_glerror();
250 235
251 glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); 236 glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
252 glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); 237 glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
253 238
254 glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); 239 gGL.getTexUnit(0)->setTextureAddressMode(LLTexUnit::TAM_CLAMP);
255 glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
256 if (mAvatarPreview) 240 if (mAvatarPreview)
257 { 241 {
258 mAvatarPreview->setTexture(mGLName); 242 mAvatarPreview->setTexture(mImagep->getTexName());
259 mSculptedPreview->setTexture(mGLName); 243 mSculptedPreview->setTexture(mImagep->getTexName());
260 } 244 }
261 } 245 }
262 246
263 gGL.color3f(1.f, 1.f, 1.f); 247 gGL.color3f(1.f, 1.f, 1.f);
264 gGL.begin( LLVertexBuffer::QUADS ); 248 gGL.begin( LLRender::QUADS );
265 { 249 {
266 gGL.texCoord2f(mPreviewImageRect.mLeft, mPreviewImageRect.mTop); 250 gGL.texCoord2f(mPreviewImageRect.mLeft, mPreviewImageRect.mTop);
267 gGL.vertex2i(PREVIEW_HPAD, PREVIEW_TEXTURE_HEIGHT); 251 gGL.vertex2i(PREVIEW_HPAD, PREVIEW_TEXTURE_HEIGHT);
@@ -274,7 +258,7 @@ void LLFloaterImagePreview::draw()
274 } 258 }
275 gGL.end(); 259 gGL.end();
276 260
277 LLImageGL::unbindTexture(0, GL_TEXTURE_2D); 261 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
278 262
279 stop_glerror(); 263 stop_glerror();
280 } 264 }
@@ -285,11 +269,15 @@ void LLFloaterImagePreview::draw()
285 gGL.color3f(1.f, 1.f, 1.f); 269 gGL.color3f(1.f, 1.f, 1.f);
286 270
287 if (selected == 9) 271 if (selected == 9)
288 mSculptedPreview->bindTexture(); 272 {
273 gGL.getTexUnit(0)->bind(mSculptedPreview->getTexture());
274 }
289 else 275 else
290 mAvatarPreview->bindTexture(); 276 {
277 gGL.getTexUnit(0)->bind(mAvatarPreview->getTexture());
278 }
291 279
292 gGL.begin( LLVertexBuffer::QUADS ); 280 gGL.begin( LLRender::QUADS );
293 { 281 {
294 gGL.texCoord2f(0.f, 1.f); 282 gGL.texCoord2f(0.f, 1.f);
295 gGL.vertex2i(PREVIEW_HPAD, PREVIEW_TEXTURE_HEIGHT); 283 gGL.vertex2i(PREVIEW_HPAD, PREVIEW_TEXTURE_HEIGHT);
@@ -302,10 +290,7 @@ void LLFloaterImagePreview::draw()
302 } 290 }
303 gGL.end(); 291 gGL.end();
304 292
305 if (selected == 9) 293 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
306 mSculptedPreview->unbindTexture();
307 else
308 mAvatarPreview->unbindTexture();
309 } 294 }
310 } 295 }
311 } 296 }
@@ -774,7 +759,9 @@ LLImagePreviewSculpted::LLImagePreviewSculpted(S32 width, S32 height) : LLDynami
774 LLVolumeParams volume_params; 759 LLVolumeParams volume_params;
775 volume_params.setType(LL_PCODE_PROFILE_CIRCLE, LL_PCODE_PATH_CIRCLE); 760 volume_params.setType(LL_PCODE_PROFILE_CIRCLE, LL_PCODE_PATH_CIRCLE);
776 volume_params.setSculptID(LLUUID::null, LL_SCULPT_TYPE_SPHERE); 761 volume_params.setSculptID(LLUUID::null, LL_SCULPT_TYPE_SPHERE);
777 mVolume = new LLVolume(volume_params, (F32) MAX_LOD); 762
763 F32 const HIGHEST_LOD = 4.0f;
764 mVolume = new LLVolume(volume_params, HIGHEST_LOD);
778 765
779 /* 766 /*
780 mDummyAvatar = new LLVOAvatar(LLUUID::null, LL_PCODE_LEGACY_AVATAR, gAgent.getRegion()); 767 mDummyAvatar = new LLVOAvatar(LLUUID::null, LL_PCODE_LEGACY_AVATAR, gAgent.getRegion());
@@ -811,7 +798,36 @@ void LLImagePreviewSculpted::setPreviewTarget(LLImageRaw* imagep, F32 distance)
811 { 798 {
812 mVolume->sculpt(imagep->getWidth(), imagep->getHeight(), imagep->getComponents(), imagep->getData(), 0); 799 mVolume->sculpt(imagep->getWidth(), imagep->getHeight(), imagep->getComponents(), imagep->getData(), 0);
813 } 800 }
814 801
802 const LLVolumeFace &vf = mVolume->getVolumeFace(0);
803 U32 num_indices = vf.mIndices.size();
804 U32 num_vertices = vf.mVertices.size();
805
806 mVertexBuffer = new LLVertexBuffer(LLVertexBuffer::MAP_VERTEX | LLVertexBuffer::MAP_NORMAL, 0);
807 mVertexBuffer->allocateBuffer(num_vertices, num_indices, TRUE);
808
809 LLStrider<LLVector3> vertex_strider;
810 LLStrider<LLVector3> normal_strider;
811 LLStrider<U16> index_strider;
812
813 mVertexBuffer->getVertexStrider(vertex_strider);
814 mVertexBuffer->getNormalStrider(normal_strider);
815 mVertexBuffer->getIndexStrider(index_strider);
816
817 // build vertices and normals
818 for (U32 i = 0; (S32)i < num_vertices; i++)
819 {
820 *(vertex_strider++) = vf.mVertices[i].mPosition;
821 LLVector3 normal = vf.mVertices[i].mNormal;
822 normal.normalize();
823 *(normal_strider++) = normal;
824 }
825
826 // build indices
827 for (U16 i = 0; i < num_indices; i++)
828 {
829 *(index_strider++) = vf.mIndices[i];
830 }
815} 831}
816 832
817 833
@@ -846,7 +862,7 @@ BOOL LLImagePreviewSculpted::render()
846 glMatrixMode(GL_MODELVIEW); 862 glMatrixMode(GL_MODELVIEW);
847 gGL.popMatrix(); 863 gGL.popMatrix();
848 864
849 glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); 865 glClear(GL_DEPTH_BUFFER_BIT);
850 866
851 LLVector3 target_pos(0, 0, 0); 867 LLVector3 target_pos(0, 0, 0);
852 868
@@ -865,55 +881,21 @@ BOOL LLImagePreviewSculpted::render()
865 LLViewerCamera::getInstance()->setView(LLViewerCamera::getInstance()->getDefaultFOV() / mCameraZoom); 881 LLViewerCamera::getInstance()->setView(LLViewerCamera::getInstance()->getDefaultFOV() / mCameraZoom);
866 LLViewerCamera::getInstance()->setPerspective(FALSE, mOrigin.mX, mOrigin.mY, mWidth, mHeight, FALSE); 882 LLViewerCamera::getInstance()->setPerspective(FALSE, mOrigin.mX, mOrigin.mY, mWidth, mHeight, FALSE);
867 883
868 gPipeline.enableLightsAvatar();
869
870 gGL.pushMatrix();
871 glScalef(0.5, 0.5, 0.5);
872
873 const LLVolumeFace &vf = mVolume->getVolumeFace(0); 884 const LLVolumeFace &vf = mVolume->getVolumeFace(0);
874 U32 num_indices = vf.mIndices.size(); 885 U32 num_indices = vf.mIndices.size();
875 U32 num_vertices = vf.mVertices.size(); 886
876 887 mVertexBuffer->setBuffer(LLVertexBuffer::MAP_VERTEX | LLVertexBuffer::MAP_NORMAL);
877 if (num_vertices > 0 && num_indices > 0)
878 {
879 glEnableClientState(GL_NORMAL_ARRAY);
880 // build vertices and normals
881 F32* vertices = new F32[num_vertices * 3];
882 F32* normals = new F32[num_vertices * 3];
883
884 for (U32 i = 0; (S32)i < num_vertices; i++)
885 {
886 LLVector3 position = vf.mVertices[i].mPosition;
887 vertices[i*3] = position.mV[VX];
888 vertices[i*3+1] = position.mV[VY];
889 vertices[i*3+2] = position.mV[VZ];
890
891 LLVector3 normal = vf.mVertices[i].mNormal;
892 normals[i*3] = normal.mV[VX];
893 normals[i*3+1] = normal.mV[VY];
894 normals[i*3+2] = normal.mV[VZ];
895 }
896 888
897 // build indices 889 gPipeline.enableLightsAvatar();
898 U16* indices = new U16[num_indices]; 890 gGL.pushMatrix();
899 for (U16 i = 0; i < num_indices; i++) 891 const F32 SCALE = 1.25f;
900 { 892 gGL.scalef(SCALE, SCALE, SCALE);
901 indices[i] = vf.mIndices[i]; 893 const F32 BRIGHTNESS = 0.9f;
902 } 894 gGL.color3f(BRIGHTNESS, BRIGHTNESS, BRIGHTNESS);
895 mVertexBuffer->draw(LLRender::TRIANGLES, num_indices, 0);
903 896
904 gGL.color3f(0.4f, 0.4f, 0.4f); 897 gGL.popMatrix();
905 glVertexPointer(3, GL_FLOAT, 0, (void *)vertices);
906 glNormalPointer(GL_FLOAT, 0, (void *)normals);
907 glDrawRangeElements(GL_TRIANGLES, 0, num_vertices-1, num_indices, GL_UNSIGNED_SHORT, (void *)indices);
908 898
909 gGL.popMatrix();
910 glDisableClientState(GL_NORMAL_ARRAY);
911
912 delete [] indices;
913 delete [] vertices;
914 delete [] normals;
915 }
916
917 return TRUE; 899 return TRUE;
918} 900}
919 901