diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/libwindowmanager.cpp | 244 | ||||
-rw-r--r-- | src/libwindowmanager.h | 62 |
2 files changed, 305 insertions, 1 deletions
diff --git a/src/libwindowmanager.cpp b/src/libwindowmanager.cpp index e4614ac..f5e6100 100644 --- a/src/libwindowmanager.cpp +++ b/src/libwindowmanager.cpp @@ -29,6 +29,7 @@ #include <mutex> #include <set> #include <queue> +#include <memory> #include <unistd.h> @@ -79,6 +80,14 @@ class LibWindowmanager::Impl { void set_event_handler(enum EventType et, handler_fun func); + void setVisibleHandler(visible_handler f); + void setInvisibleHandler(invisible_handler f); + void setActiveHandler(active_handler f); + void setInactiveHandler(inactive_handler f); + void setSyncDrawHandler(sync_draw_handler f); + void setFlushDrawHandler(flush_draw_handler f); + void setScreenUpdatedHandler(screen_update_handler f); + Impl(); ~Impl(); @@ -96,11 +105,17 @@ public: void event(char const *et, json_object *object); private: int runEventLoop(); + visible_handler _on_visible = nullptr; + invisible_handler _on_invisible = nullptr; + active_handler _on_active = nullptr; + inactive_handler _on_inactive = nullptr; + sync_draw_handler _on_sync_draw = nullptr; + flush_draw_handler _on_flush_draw = nullptr; + screen_update_handler _on_screen_updated = nullptr; }; namespace { -constexpr const int token_maxlen = 20; constexpr const char *const wmAPI = "windowmanager"; #define CONCAT_(X, Y) X##Y @@ -584,6 +599,89 @@ void LibWindowmanager::Impl::set_event_handler(enum EventType et, handler_fun fu } } +void LibWindowmanager::Impl::setActiveHandler(active_handler f) { + struct json_object* j = json_object_new_object(); + json_object_object_add(j, "event", json_object_new_int(Event_Active)); + + int ret = afb_wsj1_call_j(this->wsj1, wmAPI, "wm_subscribe", j, _on_reply_static, this); + if (0 > ret) { + HMI_ERROR("libwm", "Failed to subscribe event"); + return; + } + this->_on_active = f; +} + +void LibWindowmanager::Impl::setInactiveHandler(inactive_handler f) { + struct json_object* j = json_object_new_object(); + json_object_object_add(j, "event", json_object_new_int(Event_Inactive)); + + int ret = afb_wsj1_call_j(this->wsj1, wmAPI, "wm_subscribe", j, _on_reply_static, this); + if (0 > ret) { + HMI_ERROR("libwm", "Failed to subscribe event"); + return; + } + this->_on_inactive = f; +} + +void LibWindowmanager::Impl::setVisibleHandler(visible_handler f) { + struct json_object* j = json_object_new_object(); + json_object_object_add(j, "event", json_object_new_int(Event_Visible)); + + int ret = afb_wsj1_call_j(this->wsj1, wmAPI, "wm_subscribe", j, _on_reply_static, this); + if (0 > ret) { + HMI_ERROR("libwm", "Failed to subscribe event"); + return; + } + this->_on_visible = f; +} + +void LibWindowmanager::Impl::setInvisibleHandler(invisible_handler f) { + struct json_object* j = json_object_new_object(); + json_object_object_add(j, "event", json_object_new_int(Event_Invisible)); + + int ret = afb_wsj1_call_j(this->wsj1, wmAPI, "wm_subscribe", j, _on_reply_static, this); + if (0 > ret) { + HMI_ERROR("libwm", "Failed to subscribe event"); + return; + } + this->_on_invisible = f; +} + +void LibWindowmanager::Impl::setSyncDrawHandler(sync_draw_handler f) { + struct json_object* j = json_object_new_object(); + json_object_object_add(j, "event", json_object_new_int(Event_SyncDraw)); + + int ret = afb_wsj1_call_j(this->wsj1, wmAPI, "wm_subscribe", j, _on_reply_static, this); + if (0 > ret) { + HMI_ERROR("libwm", "Failed to subscribe event"); + return; + } + this->_on_sync_draw = f; +} + +void LibWindowmanager::Impl::setFlushDrawHandler(flush_draw_handler f) { + struct json_object* j = json_object_new_object(); + json_object_object_add(j, "event", json_object_new_int(Event_FlushDraw)); + + int ret = afb_wsj1_call_j(this->wsj1, wmAPI, "wm_subscribe", j, _on_reply_static, this); + if (0 > ret) { + HMI_ERROR("libwm", "Failed to subscribe event"); + return; + } + this->_on_flush_draw = f; +} +void LibWindowmanager::Impl::setScreenUpdatedHandler(screen_update_handler f) { + struct json_object* j = json_object_new_object(); + json_object_object_add(j, "event", json_object_new_int(Event_ScreenUpdated)); + + int ret = afb_wsj1_call_j(this->wsj1, wmAPI, "wm_subscribe", j, _on_reply_static, this); + if (0 > ret) { + HMI_ERROR("libwm", "Failed to subscribe event"); + return; + } + this->_on_screen_updated = f; +} + namespace { std::pair<bool, LibWindowmanager::EventType> make_event_type(char const *et) { // Event have the form "$API/$EVENT", just try to find the first / and @@ -690,6 +788,74 @@ void LibWindowmanager::Impl::event(char const *et, json_object *object) { return; } + json_object *j_val; + const char* role; + bool emit = false; + if(json_object_object_get_ex(object, kKeyDrawingName, &j_val)) { + role = json_object_get_string(j_val); + } + if (this->labels.find(role) != this->labels.end()){ + emit = true; + } + + switch(oet.second) { + case Event_Active : + if(_on_active && emit) { + return _on_active(role); + } + break; + case Event_Inactive : + if(_on_inactive && emit) { + return _on_inactive(role); + } + break; + case Event_Visible : + if(_on_visible && emit) { + return _on_visible(role); + } + break; + case Event_Invisible : + if(_on_invisible && emit) { + return _on_invisible(role); + } + break; + case Event_SyncDraw : + if(_on_sync_draw && emit) { + json_object_object_get_ex(object, kKeyDrawingArea, &j_val); + const char* area = json_object_get_string(j_val); + json_object_object_get_ex(object, "x", &j_val); + unsigned x = json_object_get_int(j_val); + json_object_object_get_ex(object, "y", &j_val); + unsigned y = json_object_get_int(j_val); + json_object_object_get_ex(object, "width", &j_val); + unsigned w = json_object_get_int(j_val); + json_object_object_get_ex(object, "height", &j_val); + unsigned h = json_object_get_int(j_val); + Rect rect(x, y, w, h); + return _on_sync_draw(role, area, rect); + } + break; + case Event_FlushDraw : + if(_on_flush_draw && emit) { + return _on_flush_draw(role); + } + break; + case Event_ScreenUpdated : + if(_on_screen_updated) { + // emit this case + json_object_object_get_ex(object, "ids", &j_val); + int len = json_object_array_length(j_val); + std::vector<std::string> id_list; + for(int i = 0; i < len; i++) + { + id_list.emplace_back( + json_object_get_string(json_object_array_get_idx(j_val, i))); + } + return _on_screen_updated(id_list); + } + break; + } + auto i = this->handlers.find(oet.second); if (i != this->handlers.end()) { json_object *val; @@ -807,10 +973,58 @@ int LibWindowmanager::getDisplayInfo(json_object *object) { return this->d->getDisplayInfo(object); } +int LibWindowmanager::getDisplayInfo(AGLScreenInfo *out_info) { + json_object* object = json_object_new_object(); + int ret = this->d->getDisplayInfo(object); + if (!ret) { + json_object *j_val; + if (json_object_object_get_ex(object, "width_pixel", &j_val)) { + out_info->set_width_dp(json_object_get_double(j_val)); + } + if (json_object_object_get_ex(object, "height_pixel", &j_val)) { + out_info->set_height_dp(json_object_get_double(j_val)); + } + if (json_object_object_get_ex(object, "width_mm", &j_val)) { + out_info->set_width_mm(json_object_get_double(j_val)); + } + if (json_object_object_get_ex(object, "height_mm", &j_val)) { + out_info->set_height_mm(json_object_get_double(j_val)); + } + if (json_object_object_get_ex(object, "scale", &j_val)) { + out_info->set_scale_factor(json_object_get_double(j_val)); + } + } + json_object_put(object); + return ret; +} + int LibWindowmanager::getAreaInfo(json_object *in_obj, json_object *out_obj) { return this->d->getAreaInfo(in_obj, out_obj); } +int LibWindowmanager::getAreaInfo(const char *role, Rect *out_rect) { + json_object *object = json_object_new_object(); + json_object *out = json_object_new_object(); + json_object_object_add(object, this->kKeyDrawingName, json_object_new_string(role)); + int ret = this->d->getAreaInfo(object, out); + if(!ret) { + json_object *j_val; + if (json_object_object_get_ex(object, "x", &j_val)) { + out_rect->set_left(json_object_get_int(j_val)); + } + if (json_object_object_get_ex(object, "y", &j_val)) { + out_rect->set_top(json_object_get_int(j_val)); + } + if (json_object_object_get_ex(object, "width", &j_val)) { + out_rect->set_width(json_object_get_int(j_val)); + } + if (json_object_object_get_ex(object, "height", &j_val)) { + out_rect->set_height(json_object_get_int(j_val)); + } + } + return ret; +} + int LibWindowmanager::getAreaInfo(const char *label, json_object *out_obj) { json_object *object = json_object_new_object(); json_object_object_add(object, this->kKeyDrawingName, json_object_new_string(label)); @@ -821,6 +1035,34 @@ void LibWindowmanager::set_event_handler(enum EventType et, handler_fun f) { return this->d->set_event_handler(et, std::move(f)); } +void LibWindowmanager::setVisibleHandler(invisible_handler f) { + return this->d->setVisibleHandler(f); +} + +void LibWindowmanager::setInvisibleHandler(visible_handler f) { + return this->d->setInvisibleHandler(f); +} + +void LibWindowmanager::setActiveHandler(active_handler f) { + return this->d->setActiveHandler(f); +} + +void LibWindowmanager::setInactiveHandler(inactive_handler f) { + return this->d->setInactiveHandler(f); +} + +void LibWindowmanager::setSyncDrawHandler(sync_draw_handler f) { + return this->d->setSyncDrawHandler(f); +} + +void LibWindowmanager::setFlushDrawHandler(flush_draw_handler f) { + return this->d->setFlushDrawHandler(f); +} + +void LibWindowmanager::setScreenUpdatedHandler(screen_update_handler f) { + return this->d->setScreenUpdatedHandler(f); +} + LibWindowmanager::LibWindowmanager() : d(new Impl) {} LibWindowmanager::~LibWindowmanager() { delete d; } diff --git a/src/libwindowmanager.h b/src/libwindowmanager.h index 697191c..a241131 100644 --- a/src/libwindowmanager.h +++ b/src/libwindowmanager.h @@ -18,8 +18,53 @@ #define LIBWINDOWMANAGER_H #include <functional> +#include <vector> #include <json-c/json.h> +class Rect { + public: + Rect() : _x(0), _y(0),_w(0), _h(0) {} + Rect(unsigned x, unsigned y, unsigned w, unsigned h) + : _x(x), _y(y),_w(w), _h(h) {} + ~Rect() = default; + unsigned left() const {return _x;} + unsigned top() const {return _y;} + unsigned width() const {return _w;} + unsigned height() const {return _h;} + void set_left(unsigned int x){_x = x;} + void set_top(unsigned int y){_y = y;} + void set_width(unsigned int w){_w = w;} + void set_height(unsigned int h){_h = h;} + private: + unsigned _x; + unsigned _y; + unsigned _w; + unsigned _h; +}; + +class AGLScreenInfo +{ + public: + unsigned long width_dp(void) const { return _width_dp; }; + unsigned long height_dp(void) const { return _height_dp; }; + unsigned long width_mm(void) const { return _width_mm; }; + unsigned long height_mm(void) const { return _height_mm; }; + double scale_factor(void) const { return _scale; }; + + void set_width_dp(unsigned long w) { _width_dp = w; }; + void set_height_dp(unsigned long h) { _height_dp = h; }; + void set_width_mm(unsigned long w) { _width_mm = w; }; + void set_height_mm(unsigned long h) { _height_mm = h; }; + void set_scale_factor(double scale) { _scale = scale; }; + + private: + unsigned long _width_dp; + unsigned long _height_dp; + unsigned long _width_mm; + unsigned long _height_mm; + double _scale = 1.0; +}; + class LibWindowmanager { public: LibWindowmanager(); @@ -29,6 +74,13 @@ public: LibWindowmanager &operator=(const LibWindowmanager &) = delete; using handler_fun = std::function<void(json_object *)>; + using visible_handler = std::function<void(const char*)>; + using invisible_handler = std::function<void(const char*)>; + using active_handler = std::function<void(const char*)>; + using inactive_handler = std::function<void(const char*)>; + using sync_draw_handler = std::function<void(const char*, const char*, const Rect&)>; + using flush_draw_handler= std::function<void(const char*)>; + using screen_update_handler = std::function<void(const std::vector<std::string>&)>; /* DrawingArea name (usage: {layout}.{area}) */ const std::string kStrLayoutNormal = "normal"; @@ -68,6 +120,16 @@ public: int activateWindow(const char* role, const char* area); int deactivateWindow(const char* role); int endDraw(const char* role); + int getDisplayInfo(AGLScreenInfo *out_info); + int getAreaInfo(const char* role, Rect *out_rect); + + void setVisibleHandler(visible_handler f); + void setInvisibleHandler(invisible_handler f); + void setActiveHandler(active_handler f); + void setInactiveHandler(inactive_handler f); + void setSyncDrawHandler(sync_draw_handler f); + void setFlushDrawHandler(flush_draw_handler f); + void setScreenUpdatedHandler(screen_update_handler f); // Backward Compatible API int requestSurface(json_object *object); |