Use GL_ONE for the source in glBendFunc instead of pre-unmultiplying.
authorKristian Høgsberg <krh@redhat.com>
Mon, 3 Nov 2008 11:35:46 +0000 (06:35 -0500)
committerKristian Høgsberg <krh@redhat.com>
Thu, 6 Nov 2008 15:53:02 +0000 (10:53 -0500)
Eventually we need to allow both pre-multiplied alpha and not, but for now default to premultiplied.

egl-compositor.c
flower.c
pointer.c
window.c

index 049af98..4129e99 100644 (file)
@@ -68,7 +68,9 @@ repaint(void *data)
                glBindTexture(GL_TEXTURE_2D, sd->texture);
                glEnable(GL_TEXTURE_2D);
                glEnable(GL_BLEND);
-               glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
+               /* Assume pre-multiplied alpha for now, this probably
+                * needs to be a wayland visual type of thing. */
+               glBlendFunc(GL_ONE, GL_ONE_MINUS_SRC_ALPHA);
 
                glEnableClientState(GL_VERTEX_ARRAY);
                glEnableClientState(GL_TEXTURE_COORD_ARRAY);
index cc8d985..e6c1c1f 100644 (file)
--- a/flower.c
+++ b/flower.c
 static const char gem_device[] = "/dev/dri/card0";
 static const char socket_name[] = "\0wayland";
 
-static void
-unpremultiply_data(uint8_t *data, int width, int height, int stride)
-{
-       unsigned int i, j;
-       uint8_t *row;
-
-       for (j = 0; j < height; j++) {
-               row = data + j * stride;
-
-               for (i = 0; i < width; i++) {
-                       uint8_t *b = &row[i * 4];
-                       uint32_t pixel;
-                       uint8_t  alpha;
-
-                       memcpy (&pixel, b, sizeof (uint32_t));
-                       alpha = (pixel & 0xff000000) >> 24;
-                       if (alpha == 0) {
-                               b[0] = b[1] = b[2] = b[3] = 0;
-                       } else {
-                               b[0] = (((pixel & 0xff0000) >> 16) * 255 + alpha / 2) / alpha;
-                               b[1] = (((pixel & 0x00ff00) >>  8) * 255 + alpha / 2) / alpha;
-                               b[2] = (((pixel & 0x0000ff) >>  0) * 255 + alpha / 2) / alpha;
-                               b[3] = alpha;
-                       }
-               }
-       }
-}
-
 static uint32_t name_cairo_surface(int fd, cairo_surface_t *surface)
 {
        struct drm_i915_gem_create create;
@@ -59,8 +31,6 @@ static uint32_t name_cairo_surface(int fd, cairo_surface_t *surface)
        stride = cairo_image_surface_get_stride(surface);
        data = cairo_image_surface_get_data(surface);
 
-       unpremultiply_data(data, width, height, stride);
-
        memset(&create, 0, sizeof(create));
        create.size = height * stride;
 
index d534a56..cd2cb0b 100644 (file)
--- a/pointer.c
+++ b/pointer.c
 static const char gem_device[] = "/dev/dri/card0";
 static const char socket_name[] = "\0wayland";
 
-static void
-unpremultiply_data(uint8_t *data, int width, int height, int stride)
-{
-       unsigned int i, j;
-       uint8_t *row;
-
-       for (j = 0; j < height; j++) {
-               row = data + j * stride;
-
-               for (i = 0; i < width; i++) {
-                       uint8_t *b = &row[i * 4];
-                       uint32_t pixel;
-                       uint8_t  alpha;
-
-                       memcpy (&pixel, b, sizeof (uint32_t));
-                       alpha = (pixel & 0xff000000) >> 24;
-                       if (alpha == 0) {
-                               b[0] = b[1] = b[2] = b[3] = 0;
-                       } else {
-                               b[0] = (((pixel & 0xff0000) >> 16) * 255 + alpha / 2) / alpha;
-                               b[1] = (((pixel & 0x00ff00) >>  8) * 255 + alpha / 2) / alpha;
-                               b[2] = (((pixel & 0x0000ff) >>  0) * 255 + alpha / 2) / alpha;
-                               b[3] = alpha;
-                       }
-               }
-       }
-}
-
 static uint32_t name_cairo_surface(int fd, cairo_surface_t *surface)
 {
        struct drm_i915_gem_create create;
@@ -57,8 +29,6 @@ static uint32_t name_cairo_surface(int fd, cairo_surface_t *surface)
        stride = cairo_image_surface_get_stride(surface);
        data = cairo_image_surface_get_data(surface);
 
-       unpremultiply_data(data, width, height, stride);
-
        memset(&create, 0, sizeof(create));
        create.size = height * stride;
 
index ee9de1e..41428ef 100644 (file)
--- a/window.c
+++ b/window.c
 static const char gem_device[] = "/dev/dri/card0";
 static const char socket_name[] = "\0wayland";
 
-static void
-unpremultiply_data(uint8_t *data, int width, int height, int stride)
-{
-       unsigned int i, j;
-       uint8_t *row;
-
-       for (j = 0; j < height; j++) {
-               row = data + j * stride;
-
-               for (i = 0; i < width; i++) {
-                       uint8_t *b = &row[i * 4];
-                       uint32_t pixel;
-                       uint8_t  alpha;
-
-                       memcpy (&pixel, b, sizeof (uint32_t));
-                       alpha = (pixel & 0xff000000) >> 24;
-                       if (alpha == 0) {
-                               b[0] = b[1] = b[2] = b[3] = 0;
-                       } else {
-                               b[0] = (((pixel & 0xff0000) >> 16) * 255 + alpha / 2) / alpha;
-                               b[1] = (((pixel & 0x00ff00) >>  8) * 255 + alpha / 2) / alpha;
-                               b[2] = (((pixel & 0x0000ff) >>  0) * 255 + alpha / 2) / alpha;
-                               b[3] = alpha;
-                       }
-               }
-       }
-}
-
 static uint32_t name_cairo_surface(int fd, cairo_surface_t *surface)
 {
        struct drm_i915_gem_create create;
@@ -57,8 +29,6 @@ static uint32_t name_cairo_surface(int fd, cairo_surface_t *surface)
        stride = cairo_image_surface_get_stride(surface);
        data = cairo_image_surface_get_data(surface);
 
-       unpremultiply_data(data, width, height, stride);
-
        memset(&create, 0, sizeof(create));
        create.size = height * stride;