|
|
@ -448,25 +448,26 @@ static bool output_cursor_to_picture(struct wlr_x11_output *output,
|
|
|
|
return true;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int depth = 32;
|
|
|
|
struct wlr_texture *texture = wlr_texture_from_buffer(renderer, buffer);
|
|
|
|
int stride = buffer->width * 4;
|
|
|
|
if (!texture) {
|
|
|
|
|
|
|
|
|
|
|
|
uint8_t *data = malloc(buffer->height * stride);
|
|
|
|
|
|
|
|
if (data == NULL) {
|
|
|
|
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (!wlr_renderer_begin_with_buffer(renderer, buffer)) {
|
|
|
|
int depth = 32;
|
|
|
|
free(data);
|
|
|
|
int stride = texture->width * 4;
|
|
|
|
|
|
|
|
uint8_t *data = malloc(texture->height * stride);
|
|
|
|
|
|
|
|
if (data == NULL) {
|
|
|
|
|
|
|
|
wlr_texture_destroy(texture);
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool result = wlr_renderer_read_pixels(
|
|
|
|
bool result = wlr_texture_read_pixels(texture, &(struct wlr_texture_read_pixels_options) {
|
|
|
|
renderer, DRM_FORMAT_ARGB8888,
|
|
|
|
.format = DRM_FORMAT_ARGB8888,
|
|
|
|
stride, buffer->width, buffer->height, 0, 0, 0, 0,
|
|
|
|
.stride = stride,
|
|
|
|
data);
|
|
|
|
.data = data,
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
wlr_renderer_end(renderer);
|
|
|
|
wlr_texture_destroy(texture);
|
|
|
|
|
|
|
|
|
|
|
|
if (!result) {
|
|
|
|
if (!result) {
|
|
|
|
free(data);
|
|
|
|
free(data);
|
|
|
|