1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
|
**OnScreen Application Guide**
====
<div align="right">Revision: 0.1</div>
<div align="right">TOYOTA MOTOR CORPORATION</div>
<div align="right">Advanced Driver Information Technology</div>
<div align="right">12th/Dec/2017</div>
* * *
<div id="Table of content"></div>
## Table of content
- [Target reader of this document](#Target reader of this document)
- [Overview](#Overview)
- [Getting Start](#Getting Start)
- [Supported environment](#Supported environment)
- [Build](#Build)
- [Configuring](#Configuring)
- [How to call HomeScreen APIs from your Application?](#How to call HomeScreen APIs from your Application?)
- [Supported usecase](#Supported usecase)
- [Operation check](#Operation check)
* * *
<div id="Target reader of this document"></div>
## Target reader of this document
Application developer who wants to realize on-screen display on HomeScreen using OnScreenApp.
* * *
<div id="Overview"></div>
## Overview
OnScreenApp realizes on-screen display on the HomeScreen receiving the on_screen_message event of HomeScreenBinding.
OnScreenApp is implemented with Qt. In order to receive the on_screen_message event, HomeScreenBinder needs to be started as part of afb - daemon 's service.
OnScreenApp analyzes the command (JSON) acquired by on_screen_message, reads QML and displays it.
You can find these projects in AGL gerrit.
homescreen-2017(HomeScreenGUI):
https://gerrit.automotivelinux.org/gerrit/#/admin/projects/staging/homescreen-2017
agl-service-homescreen-2017(HomeScreenBinder's binding library):
https://gerrit.automotivelinux.org/gerrit/#/admin/projects/apps/agl-service-homescreen-2017
libhomescreen(library for application to communication with HomeScreenBinder):
https://gerrit.automotivelinux.org/gerrit/#/admin/projects/src/libhomescreen
Also OnScreenApp is using qlibwindowmanager.
<div id="Getting Start"></div>
## Getting Start
<div id="Supported environment"></div>
### Supported environment
| Item | Description |
|:------------|:----------------------------------|
| AGL version | Electric Eel |
| Hardware | Renesas R-Car Starter Kit Pro(M3) |
<div id="Build"></div>
### Build
**Download recipe**
```
$ mkdir WORK
$ cd WORK
$ repo init -u https://gerrit.automotivelinux.org/gerrit/AGL/AGL-repo
$ repo sync
```
Then you can find the following recipes.
* `meta-agl-devel/meta-hmi-framework/homescreen-2017`
* `meta-agl-devel/meta-hmi-framework/agl-service-homescreen-2017`
* `meta-agl-demo/recipes-demo-hmi/libhomescreen`
**Bitbake**
```
$ source meta-agl/scripts/aglsetup.sh -m m3ulcb agl-demo agl-devel agl-appfw-smack agl-hmi-framework
$ bitbake agl-demo-platform
$ bitbake agl-demo-platform-crosssdk
```
**Export SDK**
```
$ cd WORK
$ cd ./build/tmp/deploy/sdk/
$ ./poky-agl-glibc-x86_64-agl-demo-platform-crosssdk-aarch64-toolchain-4.99.2.sh
```
* * *
<div id="Configuring"></div>
### Configuring
OnScreenApp uses HomeScreenBinding and WindowManager API.
In order to use these APIs, you need to paste the following configuration definition into "config.xml" of your application.
```
<feature name="urn:AGL:widget:required-api">
<param name="homescreen" value="ws" />
<param name="windowmanager" value="ws" />
</feature>
```
* * *
<div id="How to call HomeScreen and WindowManager APIs from your Application?"></div>
## How to perform on-screen display on OnScreenApp
### Send message to perform on-screen display
In order to perform on-screen display on OnScreenApp, it is necessary to use the on_screen_message () API provided by HomeScreenBinding.
In the argument of on_screen_message (), pass the character string of JSON format below.
```
{
"app": "<Application name>",
"message": "<Message string>",
"file": "<QML file path>",
"mask": "<Display mask image file>"
}
```
Since the application name is used as a key for specifying an application displayed on OnScreenApp, it needs to be unique.
The message string is a character string for default display when a specific command or external QML is not read.
For the QML file path and the display mask image file, the full path on the AGL system is described respectively.
### Display QML file and mask image
OnScreenApp has the function of reading and displaying QML file from outside.
Even when there is no QML file, you can display a character string on the default User Interface.
The size of the displayable QML file is width 1079 height 400. Mask image is also similar size and image file with alpha channel (Recommended is png format).
### Retrieve events from QML
It is possible to execute "on_screen_reply()" of libhomescreen using the object called eventHandler in prepared QML.
For example, by registering the event "Evnet_OnScreenReply" of libhomescreen on the application side,
It is possible to implement processing by clicking buttons prepared on the QML.
Example) Execution of on_screen_reply event by QML Button click
```
ImageButton {
width: 300
height: 60
offImage: 'images/button.svg'
onClicked: {
eventHandler.onScreenReply("{ \"<Application name>\": \"<Message string>\" }");
}
}
```
<br />
* * *
<div id="Supported usecase"></div>
## Supported usecase
1. Display OnScreen messages
- Applications sending OnScreen messages to homescreen-service, and OnScreenApp
will get these message and display.
2. Get OnSreen Reply event
- When OnScreen messages is displaying, OnScreenApp will send a reply event to applications.
* * *
<div id="Operation check"></div>
## Operation check
The operation on OnScreenApp can be confirmed by afb-client-demo.
OnScreenApp includes QML files for Phone and System as operation confirmation samples.
You can confirm the operation by executing the following command on the AGL on which OnScreenApp is installed.
```
$ afm-util start onscreenapp@0.1
$ afb-client-demo ws://localhost:1024/api?token=HELLO
homescreen subscribe { "event" : "on_screen_reply" }
homescreen on_screen_message { "display_message" : "{\"app\":\"Phone\", \"message\":\"incoming call\", \"file\":\"qrc:/phone.qml\", \"mask\":\":/images/star_1079x400.png\"}" }
homescreen on_screen_message { "display_message" : "{\"app\":\"System\", \"message\":\"error\", \"file\":\"qrc:/system.qml\", \"mask\":\":/images/oval_1079x400.png\"}" }
homescreen on_screen_message { "display_message" : "{\"app\":\"System\", \"message\":\"rejected\", \"file\":\"qrc:/system.qml\", \"mask\":\":/images/oval_1079x400.png\"}" }
homescreen on_screen_message { "display_message" : "{\"app\":\"Phone\", \"message\":\"call rejected\", \"file\":\"qrc:/phone.qml\", \"mask\":\":/images/star_1079x400.png\"}" }
```
|