X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=app%2Fmain.cpp;h=4c406e61fc78bd0a25eedade5a2f386aa891dfb4;hb=61a5af3ee61d017dd3c9dd2c23a41fbfde37fb6b;hp=4b966d50b430a414a9f57f4fca676909c2d79598;hpb=b4f138383f10562b7cdd5585a8e0cc12265dff2c;p=apps%2Fmediaplayer.git diff --git a/app/main.cpp b/app/main.cpp index 4b966d5..4c406e6 100644 --- a/app/main.cpp +++ b/app/main.cpp @@ -28,8 +28,12 @@ #include #include "qlibwindowmanager.h" +#include "qlibsoundmanager.h" +#include +static LibHomeScreen* hs; static QLibWindowmanager* qwm; +static QLibSoundmanager* smw; static std::string myname = std::string("MediaPlayer"); int main(int argc, char *argv[]) @@ -61,7 +65,13 @@ int main(int argc, char *argv[]) query.addQueryItem(QStringLiteral("token"), secret); bindingAddress.setQuery(query); context->setContextProperty(QStringLiteral("bindingAddress"), bindingAddress); - qwm = new QLibWindowmanager(); + + std::string token = secret.toStdString(); + + hs = new LibHomeScreen(); + qwm = new QLibWindowmanager(); + smw = new QLibSoundmanager(); + // WindowManager if(qwm->init(port,secret) != 0){ exit(EXIT_FAILURE); @@ -73,9 +83,30 @@ int main(int argc, char *argv[]) fprintf(stderr, "Surface got syncDraw!\n"); qwm->endDraw(myname.c_str()); }); - qwm->set_event_handler(QLibWindowmanager::Event_FlushDraw, [](json_object *object) { - fprintf(stderr, "Surface got flushDraw!\n");; + qwm->set_event_handler(QLibWindowmanager::Event_FlushDraw, [&engine, smw](json_object *object) { + fprintf(stderr, "Surface got flushDraw!\n"); + QObject *root = engine.rootObjects().first(); + int sourceID = root->property("sourceID").toInt(); + smw->connect(sourceID, "default"); }); + + // HomeScreen + hs->init(port, token.c_str()); + hs->set_event_handler(LibHomeScreen::Event_TapShortcut, [qwm](json_object *object){ + const char *appname = json_object_get_string( + json_object_object_get(object, "application_name")); + if(myname == appname) + { + qDebug("Surface %s got tapShortcut\n", appname); + qwm->activateSurface(myname.c_str()); + } + }); + + // SoundManager, event handler is set inside smw + smw->init(port, secret); + + engine.rootContext()->setContextProperty("smw",smw); + } engine.load(QUrl(QStringLiteral("qrc:/MediaPlayer.qml"))); @@ -83,6 +114,10 @@ int main(int argc, char *argv[]) QQuickWindow *window = qobject_cast(root); QObject::connect(window, SIGNAL(frameSwapped()), qwm, SLOT(slotActivateSurface())); // This should be disconnected, but when... + QObject::connect(smw, SIGNAL(reply(QVariant)), + root, SLOT(slotReply(QVariant))); + QObject::connect(smw, SIGNAL(event(QVariant, QVariant)), + root, SLOT(slotEvent(QVariant, QVariant))); return app.exec(); }