aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llrender
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llrender')
-rw-r--r--linden/indra/llrender/llfontgl.cpp6
-rw-r--r--linden/indra/llrender/llfontgl.h5
-rw-r--r--linden/indra/llrender/llrendertarget.cpp59
-rw-r--r--linden/indra/llrender/llrendertarget.h27
4 files changed, 79 insertions, 18 deletions
diff --git a/linden/indra/llrender/llfontgl.cpp b/linden/indra/llrender/llfontgl.cpp
index 9298e8c..53e8c2b 100644
--- a/linden/indra/llrender/llfontgl.cpp
+++ b/linden/indra/llrender/llfontgl.cpp
@@ -47,6 +47,7 @@ F32 LLFontGL::sVertDPI = 96.f;
47F32 LLFontGL::sHorizDPI = 96.f; 47F32 LLFontGL::sHorizDPI = 96.f;
48F32 LLFontGL::sScaleX = 1.f; 48F32 LLFontGL::sScaleX = 1.f;
49F32 LLFontGL::sScaleY = 1.f; 49F32 LLFontGL::sScaleY = 1.f;
50BOOL LLFontGL::sDisplayFont = TRUE ;
50LLString LLFontGL::sAppDir; 51LLString LLFontGL::sAppDir;
51 52
52LLFontGL* LLFontGL::sMonospace = NULL; 53LLFontGL* LLFontGL::sMonospace = NULL;
@@ -559,6 +560,11 @@ S32 LLFontGL::render(const LLWString &wstr,
559 BOOL use_embedded, 560 BOOL use_embedded,
560 BOOL use_ellipses) const 561 BOOL use_ellipses) const
561{ 562{
563 if(!sDisplayFont) //do not display texts
564 {
565 return wstr.length() ;
566 }
567
562 LLGLEnable tex(GL_TEXTURE_2D); 568 LLGLEnable tex(GL_TEXTURE_2D);
563 569
564 if (wstr.empty()) 570 if (wstr.empty())
diff --git a/linden/indra/llrender/llfontgl.h b/linden/indra/llrender/llfontgl.h
index ce55385..4df1063 100644
--- a/linden/indra/llrender/llfontgl.h
+++ b/linden/indra/llrender/llfontgl.h
@@ -204,6 +204,8 @@ public:
204 static LLString nameFromVAlign(LLFontGL::VAlign align); 204 static LLString nameFromVAlign(LLFontGL::VAlign align);
205 static LLFontGL::VAlign vAlignFromName(const LLString& name); 205 static LLFontGL::VAlign vAlignFromName(const LLString& name);
206 206
207 static void setFontDisplay(BOOL flag) { sDisplayFont = flag ; }
208
207protected: 209protected:
208 struct embedded_data_t 210 struct embedded_data_t
209 { 211 {
@@ -222,6 +224,7 @@ public:
222 static F32 sHorizDPI; 224 static F32 sHorizDPI;
223 static F32 sScaleX; 225 static F32 sScaleX;
224 static F32 sScaleY; 226 static F32 sScaleY;
227 static BOOL sDisplayFont ;
225 static LLString sAppDir; // For loading fonts 228 static LLString sAppDir; // For loading fonts
226 229
227 static LLFontGL* sMonospace; // medium 230 static LLFontGL* sMonospace; // medium
@@ -246,7 +249,7 @@ public:
246protected: 249protected:
247 /*virtual*/ BOOL addChar(const llwchar wch); 250 /*virtual*/ BOOL addChar(const llwchar wch);
248 static LLString getFontPathLocal(); 251 static LLString getFontPathLocal();
249 static LLString getFontPathSystem(); 252 static LLString getFontPathSystem();
250 253
251protected: 254protected:
252 LLPointer<LLImageRaw> mRawImageGLp; 255 LLPointer<LLImageRaw> mRawImageGLp;
diff --git a/linden/indra/llrender/llrendertarget.cpp b/linden/indra/llrender/llrendertarget.cpp
index 974e0a2..d95c8aa 100644
--- a/linden/indra/llrender/llrendertarget.cpp
+++ b/linden/indra/llrender/llrendertarget.cpp
@@ -49,8 +49,9 @@ LLRenderTarget::~LLRenderTarget()
49 release(); 49 release();
50} 50}
51 51
52void LLRenderTarget::allocate(U32 resx, U32 resy, U32 color_fmt, BOOL depth, U32 usage, BOOL force_fbo) 52void LLRenderTarget::allocate(U32 resx, U32 resy, U32 color_fmt, BOOL depth, U32 usage, BOOL use_fbo)
53{ 53{
54 stop_glerror();
54 mResX = resx; 55 mResX = resx;
55 mResY = resy; 56 mResY = resy;
56 57
@@ -79,32 +80,45 @@ void LLRenderTarget::allocate(U32 resx, U32 resy, U32 color_fmt, BOOL depth, U32
79 80
80 stop_glerror(); 81 stop_glerror();
81 82
82 if (sUseFBO || force_fbo) 83 if ((sUseFBO || use_fbo) && gGLManager.mHasFramebufferObject)
83 { 84 {
85
84 if (depth) 86 if (depth)
85 { 87 {
86 glGenRenderbuffersEXT(1, (GLuint *) &mDepth); 88 stop_glerror();
87 glBindRenderbufferEXT(GL_RENDERBUFFER_EXT, mDepth); 89 allocateDepth();
88 glRenderbufferStorageEXT(GL_RENDERBUFFER_EXT,GL_DEPTH_COMPONENT,mResX,mResY); 90 stop_glerror();
89 glBindRenderbufferEXT(GL_RENDERBUFFER_EXT, 0);
90 } 91 }
91 92
92 glGenFramebuffersEXT(1, (GLuint *) &mFBO); 93 glGenFramebuffersEXT(1, (GLuint *) &mFBO);
94
93 glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, mFBO); 95 glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, mFBO);
94 96
95 if (mDepth) 97 if (mDepth)
96 { 98 {
97 glFramebufferRenderbufferEXT(GL_FRAMEBUFFER_EXT, GL_DEPTH_ATTACHMENT_EXT, 99 glFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT, GL_DEPTH_ATTACHMENT_EXT, mUsage, mDepth, 0);
98 GL_RENDERBUFFER_EXT, mDepth); 100 glFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT, GL_STENCIL_ATTACHMENT_EXT, mUsage, mDepth, 0);
101 stop_glerror();
99 } 102 }
103
100 glFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT, GL_COLOR_ATTACHMENT0_EXT, 104 glFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT, GL_COLOR_ATTACHMENT0_EXT,
101 mUsage, mTex, 0); 105 mUsage, mTex, 0);
102 106 stop_glerror();
103 107
104 glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0); 108 glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0);
109 stop_glerror();
105 } 110 }
106} 111}
107 112
113void LLRenderTarget::allocateDepth()
114{
115 glGenTextures(1, (GLuint *) &mDepth);
116 glBindTexture(mUsage, mDepth);
117 glTexParameteri(mUsage, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
118 glTexParameteri(mUsage, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
119 glTexImage2D(mUsage, 0, GL_DEPTH24_STENCIL8_EXT, mResX, mResY, 0, GL_DEPTH_STENCIL_EXT, GL_UNSIGNED_INT_24_8_EXT, NULL);
120}
121
108void LLRenderTarget::release() 122void LLRenderTarget::release()
109{ 123{
110 if (mFBO) 124 if (mFBO)
@@ -121,7 +135,7 @@ void LLRenderTarget::release()
121 135
122 if (mDepth) 136 if (mDepth)
123 { 137 {
124 glDeleteRenderbuffersEXT(1, (GLuint *) &mDepth); 138 glDeleteTextures(1, (GLuint *) &mDepth);
125 mDepth = 0; 139 mDepth = 0;
126 } 140 }
127} 141}
@@ -141,7 +155,7 @@ void LLRenderTarget::clear()
141 U32 mask = GL_COLOR_BUFFER_BIT; 155 U32 mask = GL_COLOR_BUFFER_BIT;
142 if (mUseDepth) 156 if (mUseDepth)
143 { 157 {
144 mask |= GL_DEPTH_BUFFER_BIT; 158 mask |= GL_DEPTH_BUFFER_BIT | GL_STENCIL_BUFFER_BIT;
145 } 159 }
146 if (mFBO) 160 if (mFBO)
147 { 161 {
@@ -160,13 +174,34 @@ void LLRenderTarget::bindTexture()
160 glBindTexture(mUsage, mTex); 174 glBindTexture(mUsage, mTex);
161} 175}
162 176
163void LLRenderTarget::flush() 177void LLRenderTarget::bindDepth()
178{
179 glBindTexture(mUsage, mDepth);
180}
181
182
183void LLRenderTarget::flush(BOOL fetch_depth)
164{ 184{
165 gGL.flush(); 185 gGL.flush();
166 if (!mFBO) 186 if (!mFBO)
167 { 187 {
168 bindTexture(); 188 bindTexture();
169 glCopyTexSubImage2D(mUsage, 0, 0, 0, 0, 0, mResX, mResY); 189 glCopyTexSubImage2D(mUsage, 0, 0, 0, 0, 0, mResX, mResY);
190
191 if (fetch_depth)
192 {
193 if (!mDepth)
194 {
195 allocateDepth();
196 }
197
198 bindDepth();
199 glCopyTexImage2D(mUsage, 0, GL_DEPTH24_STENCIL8_EXT, 0, 0, mResX, mResY, 0);
200 }
201 }
202 else
203 {
204 glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0);
170 } 205 }
171} 206}
172 207
diff --git a/linden/indra/llrender/llrendertarget.h b/linden/indra/llrender/llrendertarget.h
index cc36146..918a604 100644
--- a/linden/indra/llrender/llrendertarget.h
+++ b/linden/indra/llrender/llrendertarget.h
@@ -37,7 +37,7 @@
37/* 37/*
38 SAMPLE USAGE: 38 SAMPLE USAGE:
39 39
40 LLFBOTarget target; 40 LLRenderTarget target;
41 41
42 ... 42 ...
43 43
@@ -46,7 +46,7 @@
46 46
47 //render to contents of offscreen buffer 47 //render to contents of offscreen buffer
48 target.bindTarget(); 48 target.bindTarget();
49 glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); 49 target.clear();
50 ... <issue drawing commands> ... 50 ... <issue drawing commands> ...
51 target.flush(); 51 target.flush();
52 52
@@ -71,7 +71,10 @@ public:
71 //allocate resources for rendering 71 //allocate resources for rendering
72 //must be called before use 72 //must be called before use
73 //multiple calls will release previously allocated resources 73 //multiple calls will release previously allocated resources
74 void allocate(U32 resx, U32 resy, U32 color_fmt, BOOL depth, U32 usage = GL_TEXTURE_2D, BOOL force_fbo = FALSE); 74 void allocate(U32 resx, U32 resy, U32 color_fmt, BOOL depth, U32 usage = GL_TEXTURE_2D, BOOL use_fbo = TRUE);
75
76 //allocate a depth texture
77 void allocateDepth();
75 78
76 //free any allocated resources 79 //free any allocated resources
77 //safe to call redundantly 80 //safe to call redundantly
@@ -80,7 +83,7 @@ public:
80 //bind target for rendering 83 //bind target for rendering
81 //applies appropriate viewport 84 //applies appropriate viewport
82 void bindTarget(); 85 void bindTarget();
83 86
84 //clear render targer, clears depth buffer if present, 87 //clear render targer, clears depth buffer if present,
85 //uses scissor rect if in copy-to-texture mode 88 //uses scissor rect if in copy-to-texture mode
86 void clear(); 89 void clear();
@@ -88,14 +91,25 @@ public:
88 //get applied viewport 91 //get applied viewport
89 void getViewport(S32* viewport); 92 void getViewport(S32* viewport);
90 93
94 //get X resolution
95 U32 getWidth() const { return mResX; }
96
97 //get Y resolution
98 U32 getHeight() const { return mResY; }
99
91 //bind results of render for sampling 100 //bind results of render for sampling
92 void bindTexture(); 101 void bindTexture();
93 102
103 //bind results of render for sampling depth buffer
104 void bindDepth();
105
94 //flush rendering operations 106 //flush rendering operations
95 //must be called when rendering is complete 107 //must be called when rendering is complete
96 //should be used 1:1 with bindTarget 108 //should be used 1:1 with bindTarget
97 // call bindTarget once, do all your rendering, call flush once 109 // call bindTarget once, do all your rendering, call flush once
98 void flush(); 110 // if fetch_depth is TRUE, every effort will be made to copy the depth buffer into
111 // the current depth texture. A depth texture will be allocated if needed.
112 void flush(BOOL fetch_depth = FALSE);
99 113
100 //Returns TRUE if target is ready to be rendered into. 114 //Returns TRUE if target is ready to be rendered into.
101 //That is, if the target has been allocated with at least 115 //That is, if the target has been allocated with at least
@@ -108,8 +122,11 @@ private:
108 U32 mTex; 122 U32 mTex;
109 U32 mFBO; 123 U32 mFBO;
110 U32 mDepth; 124 U32 mDepth;
125 U32 mStencil;
111 BOOL mUseDepth; 126 BOOL mUseDepth;
127 BOOL mRenderDepth;
112 U32 mUsage; 128 U32 mUsage;
129
113}; 130};
114 131
115#endif 132#endif