summaryrefslogtreecommitdiffstats
path: root/meta-speech-framework/recipes-apis/agl-service-voice-high/default-voice-high-config/voice-high.json
blob: 1b72b8c85342ce9e6cebcfbc5f0a9c835bceedda (plain)
1
{ "default": "" }
00; background-color: #fff0f0 } /* Literal.String.Affix */ .highlight .sb { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Backtick */ .highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */ .highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */ .highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */ .highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */ .highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */ .highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */ .highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */ .highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */ .highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */ .highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */ .highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */ .highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */ .highlight .vc { color: #336699 } /* Name.Variable.Class */ .highlight .vg { color: #dd7700 } /* Name.Variable.Global */ .highlight .vi { color: #3333bb } /* Name.Variable.Instance */ .highlight .vm { color: #336699 } /* Name.Variable.Magic */ .highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */ }
/*
 * Copyright (C) 2016 The Qt Company Ltd.
 * Copyright (C) 2016,2017 Konsulko Group
 * Copyright (C) 2018 IoT.bzh
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#include <QtCore/QDebug>
#include <QtCore/QCommandLineParser>
#include <QtCore/QUrlQuery>
#include <QtCore/QDir>
#include <QtCore/QStandardPaths>
#include <QtCore/QThread>
#include <QtGui/QGuiApplication>
#include <QtQml/QQmlApplicationEngine>
#include <QtQml/QQmlContext>
#include <QtQuickControls2/QQuickStyle>
#include <QtQml/qqml.h>
#include <QtQuick/qquickitem.h>
#include <QtQuick/qquickview.h>
#include <QQuickWindow>
#ifndef NATIVE_BUILD
#include <libhomescreen.hpp>
#include <qlibwindowmanager.h>
#else
#include <QScreen>
#endif
#include "mixer.h"

int main(int argc, char *argv[])
{
	QString myname = QString("Mixer");

	QGuiApplication app(argc, argv);

	QQuickStyle::setStyle("AGL");

	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();

        qmlRegisterType<Mixer>("Mixer", 1, 0, "Mixer");

	QQmlApplicationEngine engine;
	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);
		QQmlContext *context = engine.rootContext();
		context->setContextProperty(QStringLiteral("bindingAddress"), bindingAddress);
		qDebug() << "Connect to: " << bindingAddress;


#ifndef NATIVE_BUILD
		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 callbnewack against an event type. Here a lambda is called when SyncDraw event occurs
            qwm->set_event_handler(QLibWindowmanager::Event_SyncDraw, [qwm, myname](json_object*) {
				fprintf(stderr, "Surface got syncDraw!\n");
				qwm->endDraw(myname);
			});

		// HomeScreen
		std::string token = secret.toStdString();
		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);
				}
			}
		});
#endif
		engine.load(QUrl(QStringLiteral("qrc:/Mixer.qml")));

		// Find the instantiated model QObject and connect the signals/slots
		QList<QObject*> mobjs = engine.rootObjects();
                if (mobjs.empty())
                {
                    qDebug() << "[ERROR] Failed to load QML!";
                    return -1;
                }

                QQuickWindow *window = qobject_cast<QQuickWindow *>(mobjs.first());
#ifdef NATIVE_BUILD
                window->setFlags(window->flags() & ~Qt::FramelessWindowHint); // Remove the borderless flag
                window->setHeight(QGuiApplication::primaryScreen()->geometry().height());
#else
                QObject::connect(window, SIGNAL(frameSwapped()), qwm, SLOT(slotActivateSurface()));
#endif
	}
        else
        {
            qDebug() << "[ERROR] No port and token specified!";
            return -1;
        }

	return app.exec();
}