diff options
author | Yuta Doi <yuta-d@witz-inc.co.jp> | 2017-12-22 21:00:10 +0900 |
---|---|---|
committer | Yuta Doi <yuta-d@witz-inc.co.jp> | 2018-03-08 11:46:58 +0900 |
commit | a0a00ddd1a5d01566ffd145765a813814e20ae20 (patch) | |
tree | e361d94cdbcd98e7cb54cd5bc477b50dae4df352 /src/app.hpp | |
parent | a40753a48f09c8ffcce43f324f5f91029a351a48 (diff) |
Add APIs which can get information about the display and the surface area
getDisplayInfo() can get the display information as follows:
- width[pixel]
- height[pixel]
- width[mm]
- height[mm]
NOTE:
It uses wl_output::geometry() for getting physical width[mm] and height[mm] of the display,
but the value is different with measured value.
value from wl_output::geometry(): width:320 height:520
measured value : width:193 height:343
getAreaInfo() can get the information of area drawn by the application as follows:
- x-coordinate
- y-coordinate
- width
- height
The details are described in doc/ApplicationGuide.md.
Bug-AGL: SPEC-1087
Change-Id: I97c71b1618f9c8a799b14d9a0a53acfb27e1822d
Signed-off-by: Yuta Doi <yuta-d@witz-inc.co.jp>
Diffstat (limited to 'src/app.hpp')
-rw-r--r-- | src/app.hpp | 36 |
1 files changed, 27 insertions, 9 deletions
diff --git a/src/app.hpp b/src/app.hpp index 5ec19ae..f20f8b9 100644 --- a/src/app.hpp +++ b/src/app.hpp @@ -46,15 +46,25 @@ namespace wm { using std::experimental::optional; /* DrawingArea name used by "{layout}.{area}" */ -static const char *kNameLayoutNormal = "normal"; -static const char *kNameLayoutSplit = "split"; -static const char *kNameAreaFull = "full"; -static const char *kNameAreaMain = "main"; -static const char *kNameAreaSub = "sub"; +extern const char kNameLayoutNormal[]; +extern const char kNameLayoutSplit[]; +extern const char kNameAreaFull[]; +extern const char kNameAreaMain[]; +extern const char kNameAreaSub[]; /* Key for json obejct */ -static const char *kKeyDrawingName = "drawing_name"; -static const char *kKeyDrawingArea = "drawing_area"; +extern const char kKeyDrawingName[]; +extern const char kKeyDrawingArea[]; +extern const char kKeyDrawingRect[]; +extern const char kKeyX[]; +extern const char kKeyY[]; +extern const char kKeyWidth[]; +extern const char kKeyHeigh[]; +extern const char kKeyWidthPixel[]; +extern const char kKeyHeightPixel[]; +extern const char kKeyWidthMm[]; +extern const char kKeyHeightMm[]; + struct id_allocator { unsigned next = 1; @@ -118,6 +128,9 @@ struct id_allocator { }; struct App { + + typedef std::unordered_map<uint32_t, struct compositor::rect> rect_map; + enum EventType { Event_Val_Min = 0, @@ -167,6 +180,9 @@ struct App { std::map<const char *, struct afb_event> map_afb_event; + // Surface are info (x, y, w, h) + rect_map area_info; + // FOR CES DEMO std::vector<int> surface_bg; @@ -190,10 +206,12 @@ struct App { 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<json_object *> api_get_display_info(); + result<json_object *> 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); + void send_event(char const *evname, char const *label, char const *area, int x, int y, int w, int h); // Events from the compositor we are interested in void surface_created(uint32_t surface_id); @@ -216,7 +234,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); + void emit_syncdraw(char const *label, char const *area, int x, int y, int w, int h); void emit_flushdraw(char const *label); void emit_visible(char const *label, bool is_visible); void emit_invisible(char const *label); |