mirror of https://github.com/encounter/SDL.git
Only advertise the SDL_PIXELFORMAT_EXTERNAL_OES format if we can build the shader for it
This commit is contained in:
parent
6de15ffcd6
commit
5bc85d6788
|
@ -578,7 +578,7 @@ static int GLES2_CacheShaders(GLES2_RenderData * data)
|
|||
|
||||
data->texcoord_precision_hint = GLES2_GetTexCoordPrecisionEnumFromHint();
|
||||
|
||||
for (shader = 0; shader < GLES2_SHADER_COUNT; ++shader) {
|
||||
for (shader = 0; shader < GLES2_SHADER_FRAGMENT_TEXTURE_EXTERNAL_OES; ++shader) {
|
||||
GLenum shader_type;
|
||||
|
||||
if (shader == GLES2_SHADER_VERTEX_DEFAULT) {
|
||||
|
@ -2209,7 +2209,9 @@ GLES2_CreateRenderer(SDL_Window *window, Uint32 flags)
|
|||
renderer->info.texture_formats[renderer->info.num_texture_formats++] = SDL_PIXELFORMAT_NV21;
|
||||
#endif
|
||||
#ifdef GL_TEXTURE_EXTERNAL_OES
|
||||
renderer->info.texture_formats[renderer->info.num_texture_formats++] = SDL_PIXELFORMAT_EXTERNAL_OES;
|
||||
if (GLES2_CacheShader(data, GLES2_SHADER_FRAGMENT_TEXTURE_EXTERNAL_OES, GL_FRAGMENT_SHADER)) {
|
||||
renderer->info.texture_formats[renderer->info.num_texture_formats++] = SDL_PIXELFORMAT_EXTERNAL_OES;
|
||||
}
|
||||
#endif
|
||||
|
||||
/* Set up parameters for rendering */
|
||||
|
|
|
@ -56,6 +56,7 @@ typedef enum
|
|||
GLES2_SHADER_FRAGMENT_TEXTURE_NV21_BT601,
|
||||
GLES2_SHADER_FRAGMENT_TEXTURE_NV21_BT709,
|
||||
#endif
|
||||
/* Shaders beyond this point are optional and not cached at render creation */
|
||||
GLES2_SHADER_FRAGMENT_TEXTURE_EXTERNAL_OES,
|
||||
GLES2_SHADER_COUNT
|
||||
} GLES2_ShaderType;
|
||||
|
|
Loading…
Reference in New Issue