diff options
Diffstat (limited to 'video/out/opengl/video.c')
-rw-r--r-- | video/out/opengl/video.c | 14 |
1 files changed, 4 insertions, 10 deletions
diff --git a/video/out/opengl/video.c b/video/out/opengl/video.c index fb339992cc..baa660de51 100644 --- a/video/out/opengl/video.c +++ b/video/out/opengl/video.c @@ -2278,13 +2278,16 @@ static bool init_format(int fmt, struct gl_video *init) init->has_alpha = false; // YUV/planar formats - if (desc.flags & MP_IMGFLAG_YUV_P) { + if (desc.flags & (MP_IMGFLAG_YUV_P | MP_IMGFLAG_RGB_P)) { int bits = desc.component_bits; if ((desc.flags & MP_IMGFLAG_NE) && bits >= 8 && bits <= 16) { init->has_alpha = desc.num_planes > 3; plane_format[0] = find_tex_format(gl, (bits + 7) / 8, 1); for (int p = 1; p < desc.num_planes; p++) plane_format[p] = plane_format[0]; + // RGB/planar + if (desc.flags & MP_IMGFLAG_RGB_P) + snprintf(init->color_swizzle, sizeof(init->color_swizzle), "brga"); goto supported; } } @@ -2300,15 +2303,6 @@ static bool init_format(int fmt, struct gl_video *init) goto supported; } - // RGB/planar - if (fmt == IMGFMT_GBRP) { - snprintf(init->color_swizzle, sizeof(init->color_swizzle), "brga"); - plane_format[0] = find_tex_format(gl, 1, 1); - for (int p = 1; p < desc.num_planes; p++) - plane_format[p] = plane_format[0]; - goto supported; - } - // XYZ (same organization as RGB packed, but requires conversion matrix) if (fmt == IMGFMT_XYZ12) { plane_format[0] = find_tex_format(gl, 2, 3); |