mirror of https://github.com/encounter/SDL.git
wayland: Wayland cursors should use premultiplied alpha
It turns out that Wayland's WL_SHM_FORMAT_ARGB8888 format (and, indeed, all wayland RGBA formats) should be treated as premultiplied. SDL surfaces tend not to be premultiplied, and this is assumed by other backends when dealing with cursors. This change premultiplies the cursor surface in Wayland_CreateCursor() using the new SDL_PremultiplySurfaceAlphaToARGB8888(). In so doing, it also adds support for a wider range of input surfaces, including those with non-ARGB8888 pixel formats, and those which don't have pitch==width. This should fix #4856
This commit is contained in:
parent
84808ea4bb
commit
b528d48446
|
@ -34,6 +34,7 @@
|
||||||
#include "SDL_mouse.h"
|
#include "SDL_mouse.h"
|
||||||
#include "../../events/SDL_mouse_c.h"
|
#include "../../events/SDL_mouse_c.h"
|
||||||
#include "SDL_waylandvideo.h"
|
#include "SDL_waylandvideo.h"
|
||||||
|
#include "../SDL_pixels_c.h"
|
||||||
#include "SDL_waylandevents_c.h"
|
#include "SDL_waylandevents_c.h"
|
||||||
|
|
||||||
#include "wayland-cursor.h"
|
#include "wayland-cursor.h"
|
||||||
|
@ -267,10 +268,6 @@ Wayland_CreateCursor(SDL_Surface *surface, int hot_x, int hot_y)
|
||||||
}
|
}
|
||||||
cursor->driverdata = (void *) data;
|
cursor->driverdata = (void *) data;
|
||||||
|
|
||||||
/* Assume ARGB8888 */
|
|
||||||
SDL_assert(surface->format->format == SDL_PIXELFORMAT_ARGB8888);
|
|
||||||
SDL_assert(surface->pitch == surface->w * 4);
|
|
||||||
|
|
||||||
/* Allocate shared memory buffer for this cursor */
|
/* Allocate shared memory buffer for this cursor */
|
||||||
if (create_buffer_from_shm (data,
|
if (create_buffer_from_shm (data,
|
||||||
surface->w,
|
surface->w,
|
||||||
|
@ -282,9 +279,8 @@ Wayland_CreateCursor(SDL_Surface *surface, int hot_x, int hot_y)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_memcpy(data->shm_data,
|
/* Wayland requires premultiplied alpha for its surfaces. */
|
||||||
surface->pixels,
|
SDL_PremultiplySurfaceAlphaToARGB8888(surface, data->shm_data);
|
||||||
surface->h * surface->pitch);
|
|
||||||
|
|
||||||
data->surface = wl_compositor_create_surface(wd->compositor);
|
data->surface = wl_compositor_create_surface(wd->compositor);
|
||||||
wl_surface_set_user_data(data->surface, NULL);
|
wl_surface_set_user_data(data->surface, NULL);
|
||||||
|
|
Loading…
Reference in New Issue