aboutsummaryrefslogtreecommitdiffstats
path: root/flower.c
diff options
context:
space:
mode:
authorKristian Høgsberg <krh@redhat.com>2008-11-03 06:35:46 -0500
committerKristian Høgsberg <krh@redhat.com>2008-11-06 10:53:02 -0500
commit3f59e82c20e2bcbf663701fb1abfb6132e6d04ea (patch)
tree832bd5e750607eb055c447d149074302b62019a6 /flower.c
parentAdd a window client, first implementation of surface resizing. (diff)
downloadwayland-3f59e82c20e2bcbf663701fb1abfb6132e6d04ea.tar
wayland-3f59e82c20e2bcbf663701fb1abfb6132e6d04ea.tar.gz
wayland-3f59e82c20e2bcbf663701fb1abfb6132e6d04ea.tar.bz2
wayland-3f59e82c20e2bcbf663701fb1abfb6132e6d04ea.tar.lz
wayland-3f59e82c20e2bcbf663701fb1abfb6132e6d04ea.tar.xz
wayland-3f59e82c20e2bcbf663701fb1abfb6132e6d04ea.tar.zst
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.
Diffstat (limited to 'flower.c')
-rw-r--r--flower.c30
1 files changed, 0 insertions, 30 deletions
diff --git a/flower.c b/flower.c
index cc8d985..e6c1c1f 100644
--- a/flower.c
+++ b/flower.c
@@ -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;