diff options
author | Scott Murray <scott.murray@konsulko.com> | 2017-11-14 22:34:03 +0900 |
---|---|---|
committer | Scott Murray <scott.murray@konsulko.com> | 2017-11-14 22:34:45 +0900 |
commit | 2162c566e4c427ebc7c93ef3bb273cce4ee6b5ca (patch) | |
tree | 5e1bca314bb3b0ece6824c3894dcf53b9421fe20 | |
parent | b79d2e9c18ffcaaa73df03ff908a62fc7603bba5 (diff) |
Porting to new HMI Frameworkeel_4.99.3eel/4.99.34.99.3
Changes following guidelines given in "Kickstart: New HMI Framework"
document at:
https://wiki.automotivelinux.org/_media/kickstart_apps_migration_guide.pdf
Change-Id: Ia0736b44b19f0375f216d280ac2be8b3857a8802
Signed-off-by: Scott Murray <scott.murray@konsulko.com>
-rw-r--r-- | app/app.pro | 2 | ||||
-rw-r--r-- | app/main.cpp | 54 | ||||
-rw-r--r-- | package/config.xml | 2 |
3 files changed, 44 insertions, 14 deletions
diff --git a/app/app.pro b/app/app.pro index bc1ab2f..3bb385a 100644 --- a/app/app.pro +++ b/app/app.pro @@ -7,7 +7,7 @@ HEADERS = phone.h SUBDIRS = telephony-binding CONFIG += link_pkgconfig -PKGCONFIG += qtappfw +PKGCONFIG += libhomescreen qlibwindowmanager qtappfw RESOURCES += \ phone.qrc \ diff --git a/app/main.cpp b/app/main.cpp index 09e501f..7e56138 100644 --- a/app/main.cpp +++ b/app/main.cpp @@ -22,24 +22,16 @@ #include <QtQml/QQmlApplicationEngine> #include <QtQml/QQmlContext> #include <QtQuickControls2/QQuickStyle> - -#ifdef HAVE_LIBHOMESCREEN +#include <QQuickWindow> #include <libhomescreen.hpp> -#endif +#include <qlibwindowmanager.h> #include <telephony.h> #include "phone.h" int main(int argc, char *argv[]) { -#ifdef HAVE_LIBHOMESCREEN - LibHomeScreen libHomeScreen; - - if (!libHomeScreen.renderAppToAreaAllowed(0, 1)) { - qWarning() << "renderAppToAreaAllowed is denied"; - return -1; - } -#endif + QString myname = QString("Phone"); QGuiApplication app(argc, argv); @@ -72,10 +64,46 @@ int main(int argc, char *argv[]) Phone *phone = new Phone(telephony); context->setContextProperty("phone", phone); QObject::connect(telephony, &Telephony::callStateChanged, phone, &Phone::onCallStateChanged); - } + std::string token = secret.toStdString(); + LibHomeScreen* hs = new LibHomeScreen(); + QLibWindowmanager* qwm = new QLibWindowmanager(); + + // WindowManager + if(qwm->init(port,secret) != 0){ + exit(EXIT_FAILURE); + } + // Request a surface as described in layers.json windowmanager’s file + if (qwm->requestSurface(myname) != 0) { + exit(EXIT_FAILURE); + } + // Create an event callback against an event type. Here a lambda is called when SyncDraw event occurs + qwm->set_event_handler(QLibWindowmanager::Event_SyncDraw, [qwm, myname](json_object *object) { + fprintf(stderr, "Surface got syncDraw!\n"); + qwm->endDraw(myname); + }); - engine.load(QUrl(QStringLiteral("qrc:/Phone.qml"))); + // HomeScreen + hs->init(port, token.c_str()); + // Set the event handler for Event_TapShortcut which will activate the surface for windowmanager + hs->set_event_handler(LibHomeScreen::Event_TapShortcut, [qwm, myname](json_object *object){ + json_object *appnameJ = nullptr; + if(json_object_object_get_ex(object, "application_name", &appnameJ)) + { + const char *appname = json_object_get_string(appnameJ); + if(myname == appname) + { + qDebug("Surface %s got tapShortcut\n", appname); + qwm->activateSurface(myname); + } + } + }); + engine.load(QUrl(QStringLiteral("qrc:/Phone.qml"))); + QObject *root = engine.rootObjects().first(); + QQuickWindow *window = qobject_cast<QQuickWindow *>(root); + QObject::connect(window, SIGNAL(frameSwapped()), qwm, SLOT(slotActivateSurface() + )); + } return app.exec(); } diff --git a/package/config.xml b/package/config.xml index 6cff9d8..e716936 100644 --- a/package/config.xml +++ b/package/config.xml @@ -7,6 +7,8 @@ <author>Qt</author> <license>APL 2.0</license> <feature name="urn:AGL:widget:required-api"> + <param name="windowmanager" value="ws" /> + <param name="homescreen" value="ws" /> <param name="lib/libtelephony-binding.so" value="local" /> </feature> <feature name="urn:AGL:widget:required-permission"> |