X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fapp.hpp;h=13bc42178a3f65029e0c723017d7a963c9d46482;hb=5b404b92f28630649d1a4063339a3d2663072a55;hp=d1393c0c4dd262c820268b9f6582d8559d4673d0;hpb=c83642c69ede418f4c4d89daa0dae4b8698e0765;p=apps%2Fagl-service-windowmanager.git diff --git a/src/app.hpp b/src/app.hpp index d1393c0..13bc421 100644 --- a/src/app.hpp +++ b/src/app.hpp @@ -31,6 +31,7 @@ #include "policy.hpp" #include "result.hpp" #include "wayland_ivi_wm.hpp" +#include "policy_manager.hpp" #include "hmi-debug.h" namespace wl { @@ -127,6 +128,14 @@ struct id_allocator { } }; +typedef struct CarInfo { + bool parking_brake_stt; + bool accel_pedal_stt; + double accel_pedal_pos; + const char *car_stt; + bool headlamp_stt; +} CarInfo; + struct App { typedef std::unordered_map rect_map; @@ -144,7 +153,16 @@ struct App { Event_SyncDraw, Event_FlushDraw, - Event_Val_Max = Event_FlushDraw, + Event_HeadlampOff, + Event_HeadlampOn, + + Event_ParkingBrakeOff, + Event_ParkingBrakeOn, + + Event_CarStop, + Event_CarRun, + + Event_Val_Max = Event_CarRun, }; const std::vector kListEventName{ @@ -153,7 +171,13 @@ struct App { "visible", "invisible", "syncdraw", - "flushdraw" + "flushdraw", + "headlamp_off", + "headlamp_on", + "parking_brake_off", + "parking_brake_on", + "car_stop", + "car_run", }; struct controller_hooks chooks; @@ -203,12 +227,14 @@ struct App { result api_request_surface(char const *drawing_name); char const *api_request_surface(char const *drawing_name, char const *ivi_id); - void api_activate_surface(char const *drawing_name, char const *drawing_area, const reply_func &reply); - void api_deactivate_surface(char const *drawing_name, const reply_func &reply); + void allocateWindowResource(char const *event, char const *drawing_name, + char const *role, char const *drawing_area, + const reply_func &reply); void api_enddraw(char const *drawing_name); result api_get_display_info(); result api_get_area_info(char const *drawing_name); void api_ping(); + void send_event(char const *evname); void send_event(char const *evname, char const *label); void send_event(char const *evname, char const *label, char const *area, int x, int y, int w, int h); @@ -216,7 +242,26 @@ struct App { void surface_created(uint32_t surface_id); void surface_removed(uint32_t surface_id); + void setAccelPedalPos(double val); + private: + PolicyManager pm_; + LayoutManager lm_; + std::unordered_map role2surfaceid_; + std::unordered_map app2role_; + std::unordered_map role2app_; + std::unordered_map appid2role_; + CarInfo crr_car_info_; + + int allocateSurface(); + void setSurfaceSize(const char* role, const char* area); + int loadAppDb(); + +#if 0 + struct id_allocator app_id_alloc_; + std::unordered_map appname2appid_; +#endif + optional lookup_id(char const *name); optional lookup_name(int id); @@ -227,7 +272,6 @@ private: int init_layers(); - void surface_set_layout(int surface_id, optional sub_surface_id = nullopt); void layout_commit(); // TMC WM Events to clients @@ -238,15 +282,18 @@ private: void emit_visible(char const *label, bool is_visible); void emit_invisible(char const *label); void emit_visible(char const *label); + void emitHeadlampOff(); + void emitHeadlampOn(); + void emitParkingBrakeOff(); + void emitParkingBrakeOn(); + void emitCarStop(); + void emitCarRun(); void activate(int id); void deactivate(int id); + void deactivate(std::string role); void deactivate_main_surface(); - bool can_split(struct LayoutState const &state, int new_id); - void try_layout(struct LayoutState &state, - struct LayoutState const &new_layout, - std::function apply); }; } // namespace wm