aboutsummaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
authortiansen <tian_sen@dl.cn.nexty-ele.com>2018-11-02 20:16:20 +0800
committertiansen <tian_sen@dl.cn.nexty-ele.com>2018-11-02 20:16:20 +0800
commitde4e4f75c59b1da4de91a75b3ab7b94d0ab8335f (patch)
tree16e4181f175748a5aff3f91b48449c37ec361e7a /app
parentec044f44133cad1d12311345437b13b1a953226e (diff)
Diffstat (limited to 'app')
-rw-r--r--app/app.pri13
-rw-r--r--app/app.pro17
-rw-r--r--app/images/black_normal.pngbin0 -> 9809 bytes
-rw-r--r--app/images/black_split.pngbin0 -> 5011 bytes
-rw-r--r--app/main.cpp107
-rw-r--r--app/main.qml67
-rw-r--r--app/main.qrc7
-rw-r--r--app/pkg-config_wrapper.sh6
8 files changed, 217 insertions, 0 deletions
diff --git a/app/app.pri b/app/app.pri
new file mode 100644
index 0000000..c3b1fd1
--- /dev/null
+++ b/app/app.pri
@@ -0,0 +1,13 @@
+TEMPLATE = app
+QMAKE_LFLAGS += "-Wl,--hash-style=gnu -Wl,--as-needed"
+
+load(configure)
+qtCompileTest(libhomescreen)
+
+config_libhomescreen {
+ CONFIG += link_pkgconfig
+ PKGCONFIG += homescreen
+ DEFINES += HAVE_LIBHOMESCREEN
+}
+
+DESTDIR = $${OUT_PWD}/../package/root/bin
diff --git a/app/app.pro b/app/app.pro
new file mode 100644
index 0000000..22c9b00
--- /dev/null
+++ b/app/app.pro
@@ -0,0 +1,17 @@
+######################################################################
+# Automatically generated by qmake (3.1) Tue Apr 24 05:31:07 2018
+######################################################################
+
+TARGET = restriction
+INCLUDEPATH += .
+
+QT = quickcontrols2
+
+CONFIG += link_pkgconfig
+PKGCONFIG += libhomescreen qlibwindowmanager
+
+# Input
+SOURCES += main.cpp
+RESOURCES += main.qrc
+
+include(app.pri) \ No newline at end of file
diff --git a/app/images/black_normal.png b/app/images/black_normal.png
new file mode 100644
index 0000000..378798a
--- /dev/null
+++ b/app/images/black_normal.png
Binary files differ
diff --git a/app/images/black_split.png b/app/images/black_split.png
new file mode 100644
index 0000000..9ce95ed
--- /dev/null
+++ b/app/images/black_split.png
Binary files differ
diff --git a/app/main.cpp b/app/main.cpp
new file mode 100644
index 0000000..92f1c5f
--- /dev/null
+++ b/app/main.cpp
@@ -0,0 +1,107 @@
+
+#include <QtQml/qqml.h>
+#include <qlibwindowmanager.h>
+#include <QQuickWindow>
+#include <QtCore/QCommandLineParser>
+#include <QtCore/QDebug>
+#include <QtCore/QDir>
+#include <QtCore/QStandardPaths>
+#include <QtCore/QUrlQuery>
+#include <QtGui/QGuiApplication>
+#include <QtQml/QQmlApplicationEngine>
+#include <QtQml/QQmlContext>
+#include <QtQuickControls2/QQuickStyle>
+#include <libhomescreen.hpp>
+
+int main(int argc, char* argv[]) {
+ QString role = QString("Restriction");
+
+ QGuiApplication app(argc, argv);
+
+ QQuickStyle::setStyle("AGL");
+
+ QQmlApplicationEngine engine;
+
+ QCommandLineParser parser;
+ parser.addPositionalArgument("port",
+ app.translate("main", "port for binding"));
+ parser.addPositionalArgument("secret",
+ app.translate("main", "secret for binding"));
+ parser.addHelpOption();
+ parser.addVersionOption();
+ parser.process(app);
+ QStringList positionalArguments = parser.positionalArguments();
+
+ if (positionalArguments.length() == 2) {
+ int port = positionalArguments.takeFirst().toInt();
+ QString secret = positionalArguments.takeFirst();
+ QUrl bindingAddress;
+ bindingAddress.setScheme(QStringLiteral("ws"));
+ bindingAddress.setHost(QStringLiteral("localhost"));
+ bindingAddress.setPort(port);
+ bindingAddress.setPath(QStringLiteral("/api"));
+ QUrlQuery query;
+ query.addQueryItem(QStringLiteral("token"), secret);
+ bindingAddress.setQuery(query);
+
+ std::string token = secret.toStdString();
+ LibHomeScreen* hs = new LibHomeScreen();
+ QLibWindowmanager* qwm = new QLibWindowmanager();
+
+ if (qwm->init(port, secret) != 0) {
+ exit(EXIT_FAILURE);
+ }
+ // Request a surface as described in layers.json windowmanager’s file
+ if (qwm->requestSurface(role) != 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, role](json_object* object) {
+ fprintf(stderr, "Surface got syncDraw!\n");
+ qwm->endDraw(role);
+ });
+
+ engine.load(QUrl(QStringLiteral("qrc:/main.qml")));
+ QObject* root = engine.rootObjects().first();
+
+ // HomeScreen
+ hs->init(port, token.c_str());
+
+ // release restriction
+ hs->set_event_handler(
+ LibHomeScreen::Event_ReleaseRestriction,
+ [qwm, role, root](json_object* object) {
+ json_object* areaJ = nullptr;
+ if (json_object_object_get_ex(object, "area", &areaJ)) {
+ QString area(QLatin1String(json_object_get_string(areaJ)));
+
+ QMetaObject::invokeMethod(root, "hideImage");
+
+ // qwm->releaseWR(role, area);
+ qwm->deactivateSurface(role);
+ }
+ });
+
+ // allocate restriction
+ hs->set_event_handler(
+ LibHomeScreen::Event_AllocateRestriction,
+ [qwm, role, root](json_object* object) {
+ json_object* areaJ = nullptr;
+ if (json_object_object_get_ex(object, "area", &areaJ)) {
+ QString area(QLatin1String(json_object_get_string(areaJ)));
+ qDebug()
+ << "Surface got Event_AllocateRestriction " << area;
+
+ QMetaObject::invokeMethod(root, "showImage",
+ Q_ARG(QVariant, area));
+
+ // qwm->allocateWR(role, area);
+ qwm->activateSurface(role, area.prepend("restriction."));
+ }
+ });
+ }
+
+ return app.exec();
+} \ No newline at end of file
diff --git a/app/main.qml b/app/main.qml
new file mode 100644
index 0000000..15369cf
--- /dev/null
+++ b/app/main.qml
@@ -0,0 +1,67 @@
+import QtQuick 2.6
+import QtQuick.Controls 2.0
+
+ApplicationWindow {
+ id: root
+
+ color: "#00000000"
+
+ Label {
+ id: message
+ anchors.top: parent.top
+ anchors.left: parent.left
+ anchors.right: parent.right
+ anchors.bottom: parent.bottom
+ anchors.margins: 20
+ font.pixelSize: 75
+ wrapMode: Text.WordWrap
+ horizontalAlignment: Text.AlignHCenter
+ verticalAlignment: Text.AlignVCenter
+ color: "white"
+ text: "Only the video’s sound will be available while driving."
+ }
+
+ background : Image {
+ id: backgroundImg
+ anchors.fill: parent
+ anchors.topMargin: 0
+ anchors.bottomMargin: 0
+
+ visible: true
+ fillMode: Image.Stretch
+ source: 'images/black_normal.png'
+
+ state: "begin"
+ states: [
+ State {
+ name: "begin"
+ PropertyChanges { target: backgroundImg; opacity: 0.25 }
+ },
+ State {
+ name: "end"
+ PropertyChanges { target: backgroundImg; opacity: 0.75 }
+ }
+ ]
+
+ transitions: [
+ Transition {
+ from: "begin"; to: "end"
+ PropertyAnimation {target: backgroundImg; properties: "opacity"; duration: 2000}
+ }
+ ]
+ }
+
+ function showImage(area) {
+ if (area === 'normal') {
+ backgroundImg.source = 'images/black_normal.png'
+ } else {
+ backgroundImg.source = 'images/black_split.png'
+ }
+ backgroundImg.state = "end"
+ }
+
+
+ function hideImage() {
+ backgroundImg.state = "begin"
+ }
+}
diff --git a/app/main.qrc b/app/main.qrc
new file mode 100644
index 0000000..c9f6449
--- /dev/null
+++ b/app/main.qrc
@@ -0,0 +1,7 @@
+<RCC>
+ <qresource prefix="/">
+ <file>main.qml</file>
+ <file>images/black_normal.png</file>
+ <file>images/black_split.png</file>
+ </qresource>
+</RCC>
diff --git a/app/pkg-config_wrapper.sh b/app/pkg-config_wrapper.sh
new file mode 100644
index 0000000..02ed39b
--- /dev/null
+++ b/app/pkg-config_wrapper.sh
@@ -0,0 +1,6 @@
+#!/bin/sh
+PKG_CONFIG_SYSROOT_DIR=/opt/sdk/sysroots/aarch64-agl-linux
+export PKG_CONFIG_SYSROOT_DIR
+PKG_CONFIG_LIBDIR=/opt/sdk/sysroots/aarch64-agl-linux/usr/lib/pkgconfig:/opt/sdk/sysroots/aarch64-agl-linux/usr/share/pkgconfig
+export PKG_CONFIG_LIBDIR
+exec pkg-config "$@"