X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fwayland.hpp;h=da3cc29647bdee8ad0f4e3b537e43791ef5da37b;hb=1e4ce4dfbb457caa9452d16d76f112cff228ff69;hp=58c63b18895dc6d42e00dc230ca327f876f0611c;hpb=342cead0ff9a95479270de381c3cd14ea7a95c0b;p=staging%2Fwindowmanager.git diff --git a/src/wayland.hpp b/src/wayland.hpp index 58c63b1..da3cc29 100644 --- a/src/wayland.hpp +++ b/src/wayland.hpp @@ -201,6 +201,13 @@ struct surface : public wayland_proxy, // |___/ struct layer : public wayland_proxy, controlled_entity { + struct rect dst_rect; + struct rect src_rect; + struct size size; + int32_t orientation; + int32_t visibility; + float opacity; + layer(uint32_t i, struct controller *c); layer(uint32_t i, int32_t w, int32_t h, struct controller *c); ~layer() override; @@ -250,8 +257,13 @@ struct layer : public wayland_proxy, ivi_controller_layer_remove_surface(this->proxy, surface->proxy); } - inline void set_render_order(struct wl_array *surfaces) { - ivi_controller_layer_set_render_order(this->proxy, surfaces); + void set_render_order(std::vector const &ro) { + struct wl_array wlro{ + .size = ro.size() * sizeof(ro[0]), + .alloc = ro.capacity() * sizeof(ro[0]), + .data = const_cast(static_cast(ro.data())) + }; + ivi_controller_layer_set_render_order(this->proxy, &wlro); } }; @@ -264,6 +276,19 @@ struct layer : public wayland_proxy, struct screen : public wayland_proxy, controlled_entity { screen(uint32_t i, struct controller *c, struct ivi_controller_screen *p); + + void clear() { ivi_controller_screen_clear(this->proxy); } + void add_layer(layer *l) { + ivi_controller_screen_add_layer(this->proxy, l->proxy); + } + void set_render_order(std::vector const &ro) { + struct wl_array wlro{ + .size = ro.size() * sizeof(ro[0]), + .alloc = ro.capacity() * sizeof(ro[0]), + .data = const_cast(static_cast(ro.data())) + }; + ivi_controller_screen_set_render_order(this->proxy, &wlro); + } }; // _ _ _ @@ -281,6 +306,8 @@ struct controller : public wayland_proxy { name_task_pair; std::vector pending; + size output_size; + void add_task(char const *name, std::function &&f) { this->pending.emplace_back(std::make_pair(name, f)); @@ -294,6 +321,7 @@ struct controller : public wayland_proxy { } this->pending.clear(); ivi_controller_commit_changes(this->proxy); + // XXX: No flush here... } }