diff options
author | Scott Murray <scott.murray@konsulko.com> | 2017-11-14 22:36:10 +0900 |
---|---|---|
committer | Scott Murray <scott.murray@konsulko.com> | 2017-11-14 22:37:39 +0900 |
commit | e27d7e58afda96a0079c7d7b4c86e3fc74e3559d (patch) | |
tree | 68010a2afd37bb355f18d4fdb1d43d1d201c682a | |
parent | fad0af3fd59883c58224d1ffd1a6aa9668f75851 (diff) |
Porting to new HMI Framework
Changes following guidelines given in "Kickstart: New HMI Framework"
document at:
https://wiki.automotivelinux.org/_media/kickstart_apps_migration_guide.pdf
Change-Id: I4d6883bd60951af97be2d834667ab38622040735
Signed-off-by: Scott Murray <scott.murray@konsulko.com>
-rw-r--r-- | app/app.pro | 3 | ||||
-rw-r--r-- | app/main.cpp | 63 | ||||
-rw-r--r-- | package/config.xml | 2 |
3 files changed, 51 insertions, 17 deletions
diff --git a/app/app.pro b/app/app.pro index d05b9ca..36a71f0 100644 --- a/app/app.pro +++ b/app/app.pro @@ -3,6 +3,9 @@ QT = quickcontrols2 dbus SOURCES = main.cpp +CONFIG += link_pkgconfig +PKGCONFIG += libhomescreen qlibwindowmanager + RESOURCES += \ settings.qrc \ images/images.qrc \ diff --git a/app/main.cpp b/app/main.cpp index 381b936..d496ef6 100644 --- a/app/main.cpp +++ b/app/main.cpp @@ -1,5 +1,6 @@ /* * Copyright (C) 2016 The Qt Company Ltd. + * Copyright (C) 2017 Konsulko Group * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -24,10 +25,9 @@ #include <QtQml/QQmlApplicationEngine> #include <QtQml/QQmlContext> #include <QtQuickControls2/QQuickStyle> - -#ifdef HAVE_LIBHOMESCREEN +#include <QQuickWindow> #include <libhomescreen.hpp> -#endif +#include <qlibwindowmanager.h> class DBus : public QObject { @@ -48,17 +48,10 @@ private: 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("Settings"); QGuiApplication app(argc, argv); - app.setApplicationName(QStringLiteral("HVAC")); + app.setApplicationName(myname); app.setApplicationVersion(QStringLiteral("0.1.0")); app.setOrganizationDomain(QStringLiteral("automotivelinux.org")); app.setOrganizationName(QStringLiteral("AutomotiveGradeLinux")); @@ -67,18 +60,17 @@ int main(int argc, char *argv[]) QCommandLineParser parser; parser.addPositionalArgument("port", app.translate("main", "port for binding")); -// parser.addPositionalArgument("secret", app.translate("main", "secret for binding")); + parser.addPositionalArgument("secret", app.translate("main", "secret for binding")); parser.addHelpOption(); parser.addVersionOption(); parser.process(app); QStringList positionalArguments = parser.positionalArguments(); - QQmlApplicationEngine engine; - int port = 0; - if (!positionalArguments.isEmpty()) { - port = positionalArguments.takeFirst().toInt(); + if (positionalArguments.length() != 2) { + exit(EXIT_FAILURE); } + int port = positionalArguments.takeFirst().toInt(); QString secret = positionalArguments.takeFirst(); QUrl bindingAddress; bindingAddress.setScheme(QStringLiteral("http")); @@ -99,6 +91,40 @@ int main(int argc, char *argv[]) context->setContextProperty(QStringLiteral("bindingAddress"), bindingAddress); context->setContextProperty(QStringLiteral("bindingAddressWS"), bindingAddressWS); + 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); + }); + + // 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); + } + } + }); + QFile version("/proc/version"); if (version.open(QFile::ReadOnly)) { QStringList data = QString::fromLocal8Bit(version.readAll()).split(QLatin1Char(' ')); @@ -110,6 +136,9 @@ int main(int argc, char *argv[]) DBus dbus; engine.rootContext()->setContextProperty("dbus", &dbus); engine.load(QUrl(QStringLiteral("qrc:/Settings.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 dcb76f2..2e40034 100644 --- a/package/config.xml +++ b/package/config.xml @@ -7,6 +7,8 @@ <author>Tasuku Suzuki <tasuku.suzuki@qt.io></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="wifi-manager" value="ws" /> <param name="Bluetooth-Manager" value="ws" /> </feature> |