gl: use correct blend functions for unpremultiplied alpha
authorMatthew Waters <matthew@centricular.com>
Thu, 4 Oct 2018 13:43:19 +0000 (23:43 +1000)
committerMatthew Waters <matthew@centricular.com>
Thu, 4 Oct 2018 13:43:19 +0000 (23:43 +1000)
Fallback to the closest but incorrect values we had before if we can't
do this correctly.

ext/gl/gstglimagesink.c
ext/gl/gstgloverlay.c

index c70cd5510d2fc2986e7ade942512a17dfbb65023..14e1c950a883cbd573524a86e0f2331cb41fdd7c 100644 (file)
@@ -2237,7 +2237,14 @@ gst_glimage_sink_on_draw (GstGLImageSink * gl_sink)
 
     if (gl_sink->ignore_alpha) {
       gl->BlendColor (0.0, 0.0, 0.0, alpha);
-      gl->BlendFunc (GL_SRC_ALPHA, GL_CONSTANT_COLOR);
+      if (gl->BlendFuncSeparate) {
+        gl->BlendFuncSeparate (GL_SRC_ALPHA, GL_CONSTANT_COLOR, GL_ONE,
+            GL_ONE_MINUS_SRC_ALPHA);
+      } else {
+        /* we don't have separate blend modes, perform something close to
+         * correct instead */
+        gl->BlendFunc (GL_SRC_ALPHA, GL_CONSTANT_COLOR);
+      }
       gl->BlendEquation (GL_FUNC_ADD);
       gl->Enable (GL_BLEND);
     }
index 864ea64da214344c685cdf7ecb36a3564fbe1a4d..59096cb3205f6c97dbe9c628c40466b1e279306f 100644 (file)
@@ -530,7 +530,11 @@ gst_gl_overlay_callback (GstGLFilter * filter, GstGLMemory * in_tex,
   gst_gl_shader_set_uniform_1f (overlay->shader, "alpha", overlay->alpha);
 
   gl->Enable (GL_BLEND);
-  gl->BlendFunc (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
+  if (gl->BlendFuncSeparate)
+    gl->BlendFuncSeparate (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA, GL_ONE,
+        GL_ONE_MINUS_SRC_ALPHA);
+  else
+    gl->BlendFunc (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
   gl->BlendEquation (GL_FUNC_ADD);
 
   gl->DrawElements (GL_TRIANGLES, 6, GL_UNSIGNED_SHORT, 0);