|
@@ -49,11 +49,34 @@ void tnsGet2DTextureSubImage(tnsTexture* t, int xoffset, int yoffset, uint32_t w
|
|
}
|
|
}
|
|
glBindFramebuffer(GL_FRAMEBUFFER, offscreen_framebuffer);
|
|
glBindFramebuffer(GL_FRAMEBUFFER, offscreen_framebuffer);
|
|
glViewport(0, 0, t->Width, t->Height);
|
|
glViewport(0, 0, t->Width, t->Height);
|
|
- glReadPixels(0, 0, width, height, format, type, pixels);
|
|
|
|
|
|
+ glReadPixels(xoffset, yoffset, width, height, format, type, pixels);
|
|
|
|
+ glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
|
|
|
+ glDeleteFramebuffers(1, &offscreen_framebuffer);
|
|
#else
|
|
#else
|
|
glGetTextureSubImage(texture,0,xoffset,yoffset,0,width,height,1,format,type,bufSize,pixels);
|
|
glGetTextureSubImage(texture,0,xoffset,yoffset,0,width,height,1,format,type,bufSize,pixels);
|
|
#endif
|
|
#endif
|
|
}
|
|
}
|
|
|
|
+void tnsClearTextureImage(tnsTexture* t, int tex_format, int tex_bits_type){
|
|
|
|
+ int texture=t->GLTexHandle;
|
|
|
|
+#ifdef LA_USE_GLES
|
|
|
|
+ int offscreen_framebuffer;
|
|
|
|
+ glGenFramebuffers(1, &offscreen_framebuffer);
|
|
|
|
+ glBindFramebuffer(GL_FRAMEBUFFER, offscreen_framebuffer);
|
|
|
|
+ glBindTexture(GL_TEXTURE_2D, texture);
|
|
|
|
+ glFramebufferTexture2D(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_2D, texture, 0);
|
|
|
|
+ GLenum status = glCheckFramebufferStatus(GL_FRAMEBUFFER);
|
|
|
|
+ if(status != GL_FRAMEBUFFER_COMPLETE) {
|
|
|
|
+ logPrint("Failed to make complete framebuffer object in la_glGetTextureSubImage()", status);
|
|
|
|
+ }
|
|
|
|
+ glBindFramebuffer(GL_FRAMEBUFFER, offscreen_framebuffer);
|
|
|
|
+ glViewport(0, 0, t->Width, t->Height);
|
|
|
|
+ glClearColor(0,0,0,0); glClear(GL_COLOR_BUFFER_BIT);
|
|
|
|
+ glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
|
|
|
+ glDeleteFramebuffers(1, &offscreen_framebuffer);
|
|
|
|
+#else
|
|
|
|
+ glClearTexImage(t->GLTexHandle,0,tex_format,tex_bits_type,0);
|
|
|
|
+#endif
|
|
|
|
+}
|
|
|
|
|
|
|
|
|
|
// 1 2
|
|
// 1 2
|
|
@@ -388,7 +411,13 @@ char* tnsEnsureShaderCommoms(char* Content, char* Library, char* Material){
|
|
c=strSub(c1,"#with LA_SHADER_LIB_FXAA",LA_SHADER_LIB_FXAA); free(c1);
|
|
c=strSub(c1,"#with LA_SHADER_LIB_FXAA",LA_SHADER_LIB_FXAA); free(c1);
|
|
c1=strSub(c,"#with TNS_SHADER_MATERIAL",Material?Material:""); free(c);
|
|
c1=strSub(c,"#with TNS_SHADER_MATERIAL",Material?Material:""); free(c);
|
|
c=strSub(c1,"#with TNS_SHADER_LIBRARY",Library?Library:""); free(c1);
|
|
c=strSub(c1,"#with TNS_SHADER_LIBRARY",Library?Library:""); free(c1);
|
|
- return c;
|
|
|
|
|
|
+#ifdef LA_USE_GLES
|
|
|
|
+ const char uint_texture_selection[] = "#define GLES_UINT_TEXTURE";
|
|
|
|
+#else
|
|
|
|
+ const char uint_texture_selection[] = "";
|
|
|
|
+#endif
|
|
|
|
+ c1=strSub(c,"#with TNS_GLES_UINT_TEXTURE",uint_texture_selection); free(c);
|
|
|
|
+ return c1;
|
|
}
|
|
}
|
|
int tnsNewVertexShader(char *Content){
|
|
int tnsNewVertexShader(char *Content){
|
|
int status = 0;
|
|
int status = 0;
|