diff options
author | Drew DeVault <sir@cmpwn.com> | 2017-08-09 11:32:02 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-08-09 11:32:02 -0400 |
commit | df378d32740495d33dc46e799a547adc9b9620e1 (patch) | |
tree | 969d1e4d3d557cdeaa6544ebf3ffd7b4579d5fbd /examples | |
parent | 6345d6deeda014b8a95ef4a40eef938b552ff153 (diff) | |
parent | fb58307a5006366e791c96491f855777a11fdf2c (diff) |
Merge pull request #50 from nyorain/wl_surface
Add first wlr_surface example implementation
Diffstat (limited to 'examples')
-rw-r--r-- | examples/compositor/main.c | 9 | ||||
-rw-r--r-- | examples/compositor/wl_compositor.c | 91 | ||||
-rw-r--r-- | examples/meson.build | 2 |
3 files changed, 11 insertions, 91 deletions
diff --git a/examples/compositor/main.c b/examples/compositor/main.c index 6afdb391..8e5fcc34 100644 --- a/examples/compositor/main.c +++ b/examples/compositor/main.c @@ -10,6 +10,7 @@ #include <wlr/render.h> #include <wlr/render/gles2.h> #include <wlr/types/wlr_output.h> +#include <wlr/types/wlr_surface.h> #include <xkbcommon/xkbcommon.h> #include <wlr/util/log.h> #include "shared.h" @@ -32,11 +33,11 @@ void handle_output_frame(struct output_state *output, struct timespec *ts) { struct wl_resource *_res; float matrix[16]; wl_list_for_each(_res, &sample->compositor.surfaces, link) { - struct wlr_texture *texture = wl_resource_get_user_data(_res); - if (texture->valid) { - wlr_texture_get_matrix(texture, &matrix, + struct wlr_surface *surface = wl_resource_get_user_data(_res); + if (surface->texture->valid) { + wlr_texture_get_matrix(surface->texture, &matrix, &wlr_output->transform_matrix, 200, 200); - wlr_render_with_matrix(sample->renderer, texture, &matrix); + wlr_render_with_matrix(sample->renderer, surface->texture, &matrix); } } diff --git a/examples/compositor/wl_compositor.c b/examples/compositor/wl_compositor.c index 03a1aa7e..89d23d6a 100644 --- a/examples/compositor/wl_compositor.c +++ b/examples/compositor/wl_compositor.c @@ -1,90 +1,13 @@ #include <assert.h> +#include <stdlib.h> #include <wayland-server.h> #include <wlr/util/log.h> +#include <wlr/types/wlr_surface.h> #include "compositor.h" -static void surface_destroy(struct wl_client *client, struct wl_resource *resource) { - wl_resource_destroy(resource); -} - -static void surface_attach(struct wl_client *client, - struct wl_resource *resource, - struct wl_resource *buffer_resource, int32_t sx, int32_t sy) { - struct wlr_texture *texture = wl_resource_get_user_data(resource); - struct wl_shm_buffer *buffer = wl_shm_buffer_get(buffer_resource); - uint32_t format = wl_shm_buffer_get_format(buffer); - wlr_texture_upload_shm(texture, format, buffer); -} - -static void surface_damage(struct wl_client *client, - struct wl_resource *resource, - int32_t x, int32_t y, int32_t width, int32_t height) { - wlr_log(L_DEBUG, "TODO: surface damage"); -} - -static void surface_frame(struct wl_client *client, - struct wl_resource *resource, uint32_t callback) { - wlr_log(L_DEBUG, "TODO: surface frame"); -} - -static void surface_set_opaque_region(struct wl_client *client, - struct wl_resource *resource, - struct wl_resource *region_resource) { - wlr_log(L_DEBUG, "TODO: surface opaque region"); -} - -static void surface_set_input_region(struct wl_client *client, - struct wl_resource *resource, - struct wl_resource *region_resource) { - - wlr_log(L_DEBUG, "TODO: surface input region"); -} - -static void surface_commit(struct wl_client *client, - struct wl_resource *resource) { - wlr_log(L_DEBUG, "TODO: surface surface commit"); -} - -static void surface_set_buffer_transform(struct wl_client *client, - struct wl_resource *resource, int transform) { - wlr_log(L_DEBUG, "TODO: surface surface buffer transform"); -} - -static void surface_set_buffer_scale(struct wl_client *client, - struct wl_resource *resource, - int32_t scale) { - wlr_log(L_DEBUG, "TODO: surface set buffer scale"); -} - - -static void surface_damage_buffer(struct wl_client *client, - struct wl_resource *resource, - int32_t x, int32_t y, int32_t width, - int32_t height) { - wlr_log(L_DEBUG, "TODO: surface damage buffer"); -} - -struct wl_surface_interface surface_interface = { - surface_destroy, - surface_attach, - surface_damage, - surface_frame, - surface_set_opaque_region, - surface_set_input_region, - surface_commit, - surface_set_buffer_transform, - surface_set_buffer_scale, - surface_damage_buffer -}; - -static void destroy_surface(struct wl_resource *resource) { - struct wlr_texture *surface = wl_resource_get_user_data(resource); - wlr_texture_destroy(surface); -} - static void destroy_surface_listener(struct wl_listener *listener, void *data) { struct wl_compositor_state *state; - struct wlr_texture *surface = data; + struct wlr_surface *surface = data; state = wl_container_of(listener, state, destroy_surface_listener); struct wl_resource *res = NULL; @@ -101,13 +24,9 @@ static void wl_compositor_create_surface(struct wl_client *client, struct wl_compositor_state *state = wl_resource_get_user_data(resource); struct wl_resource *surface_resource = wl_resource_create(client, &wl_surface_interface, wl_resource_get_version(resource), id); - struct wlr_texture *texture = wlr_render_texture_init(state->renderer); - texture->resource = surface_resource; - wl_resource_set_implementation(surface_resource, &surface_interface, - texture, destroy_surface); - wl_resource_set_user_data(surface_resource, texture); + struct wlr_surface *surface = wlr_surface_create(surface_resource, state->renderer); wl_list_insert(&state->surfaces, wl_resource_get_link(surface_resource)); - wl_signal_add(&texture->destroy_signal, &state->destroy_surface_listener); + wl_signal_add(&surface->signals.destroy, &state->destroy_surface_listener); } static void wl_compositor_create_region(struct wl_client *client, diff --git a/examples/meson.build b/examples/meson.build index ed49444f..a44a4946 100644 --- a/examples/meson.build +++ b/examples/meson.build @@ -11,7 +11,7 @@ executable('tablet', 'tablet.c', dependencies: dep_wlr, link_with: lib_shared) compositor_src = [ 'compositor/main.c', 'compositor/wl_compositor.c', - 'compositor/wl_shell.c', + 'compositor/wl_shell.c' ] executable('compositor', compositor_src, dependencies: dep_wlr, link_with: lib_shared) |