X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fapp.hpp;h=5ec19ae471d55507f5934b5ffe2bf9810b7c8a30;hb=a5872e5c14a97d738fd9a0daaf0764b655baeebd;hp=11ae8a77d4f81eff5b9d332820200e44c4b54c73;hpb=6aaba1066fe89f324d4bae67497f4035fe997d5f;p=apps%2Fagl-service-windowmanager-2017.git diff --git a/src/app.hpp b/src/app.hpp index 11ae8a7..5ec19ae 100644 --- a/src/app.hpp +++ b/src/app.hpp @@ -24,8 +24,6 @@ #include #include #include - -#include "afb_binding_api.hpp" #include "config.hpp" #include "controller_hooks.hpp" #include "layers.hpp" @@ -57,17 +55,6 @@ static const char *kNameAreaSub = "sub"; /* Key for json obejct */ static const char *kKeyDrawingName = "drawing_name"; static const char *kKeyDrawingArea = "drawing_area"; -static const char *kKeyDrawingRect = "drawing_rect"; -static const char *kKeyX = "x"; -static const char *kKeyY = "y"; -static const char *kKeyWidth = "width"; -static const char *kKeyHeight = "height"; -static const char *kKeyWidthPixel = "width_pixel"; -static const char *kKeyHeightPixel = "height_pixel"; -static const char *kKeyWidthMm = "width_mm"; -static const char *kKeyHeightMm = "height_mm"; - - struct id_allocator { unsigned next = 1; @@ -92,6 +79,14 @@ struct id_allocator { return sid; } + // Insert a new ID which defined outside + void register_name_id(std::string const &name, unsigned sid) { + this->id2name[sid] = name; + this->name2id[name] = sid; + HMI_DEBUG("wm", "register id %u with name %s", sid, name.c_str()); + return; + } + // Lookup by ID or by name optional lookup(std::string const &name) const { auto i = this->name2id.find(name); @@ -123,9 +118,6 @@ struct id_allocator { }; struct App { - - typedef std::unordered_map rect_map; - enum EventType { Event_Val_Min = 0, @@ -150,7 +142,6 @@ struct App { "flushdraw" }; - struct binding_api api; struct controller_hooks chooks; // This is the one thing, we do not own. @@ -176,7 +167,8 @@ struct App { std::map map_afb_event; - rect_map area_info; + // FOR CES DEMO + std::vector surface_bg; explicit App(wl::display *d); ~App() = default; @@ -194,13 +186,14 @@ struct App { void set_pending_events(); result api_request_surface(char const *drawing_name); + char const *api_request_surface(char const *drawing_name, char const *ivi_id); char const *api_activate_surface(char const *drawing_name, char const *drawing_area); char const *api_deactivate_surface(char const *drawing_name); char const *api_enddraw(char const *drawing_name); - result api_get_display_info(); - result api_get_area_info(char const *drawing_name); char const *api_subscribe(afb_req *req, char const *event_name); void api_ping(); + void send_event(char const *evname, char const *label); + void send_event(char const *evname, char const *label, char const *area); // Events from the compositor we are interested in void surface_created(uint32_t surface_id); @@ -223,7 +216,7 @@ private: // TMC WM Events to clients void emit_activated(char const *label); void emit_deactivated(char const *label); - void emit_syncdraw(char const *label, char const *area, int x, int y, int w, int h); + void emit_syncdraw(char const *label, char const *area); void emit_flushdraw(char const *label); void emit_visible(char const *label, bool is_visible); void emit_invisible(char const *label);