diff options
| author | Kristian Høgsberg <krh@redhat.com> | 2008-11-03 06:35:46 -0500 |
|---|---|---|
| committer | Kristian Høgsberg <krh@redhat.com> | 2008-11-06 10:53:02 -0500 |
| commit | 3f59e82c20e2bcbf663701fb1abfb6132e6d04ea (patch) | |
| tree | 832bd5e750607eb055c447d149074302b62019a6 | |
| parent | 61017b190a5c46e052f02a49c094e42316f2e511 (diff) | |
| download | wayland-3f59e82c20e2bcbf663701fb1abfb6132e6d04ea.tar.gz wayland-3f59e82c20e2bcbf663701fb1abfb6132e6d04ea.tar.xz wayland-3f59e82c20e2bcbf663701fb1abfb6132e6d04ea.zip | |
Use GL_ONE for the source in glBendFunc instead of pre-unmultiplying.
Eventually we need to allow both pre-multiplied alpha and not, but for now default to premultiplied.
| -rw-r--r-- | egl-compositor.c | 4 | ||||
| -rw-r--r-- | flower.c | 30 | ||||
| -rw-r--r-- | pointer.c | 30 | ||||
| -rw-r--r-- | window.c | 30 |
4 files changed, 3 insertions, 91 deletions
diff --git a/egl-compositor.c b/egl-compositor.c index 049af98..4129e99 100644 --- a/egl-compositor.c +++ b/egl-compositor.c @@ -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); @@ -18,34 +18,6 @@ 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; @@ -16,34 +16,6 @@ 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; @@ -16,34 +16,6 @@ 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; |
