X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=homescreen%2Fsrc%2Fhomescreenhandler.cpp;h=9fd439d3cc48d66bb1333ea5f34e49684aa4508a;hb=45fe29549378629ef5952a62e12887f007ce89f5;hp=e7d6a393a6109479f72d8d1c762d00e27b1bdd3d;hpb=4c7852e6ff7fde510f4f11c21bec817583397951;p=apps%2Fhomescreen.git diff --git a/homescreen/src/homescreenhandler.cpp b/homescreen/src/homescreenhandler.cpp index e7d6a39..9fd439d 100644 --- a/homescreen/src/homescreenhandler.cpp +++ b/homescreen/src/homescreenhandler.cpp @@ -5,12 +5,15 @@ */ #include +#include #include #include #include "homescreenhandler.h" #include "hmi-debug.h" +QScreen *find_screen(const char *output); + // defined by meson build file #include QT_QPA_HEADER @@ -18,16 +21,13 @@ // a user session by systemd #define LAUNCHER_APP_ID "launcher" -static struct wl_output * -getWlOutput(QPlatformNativeInterface *native, QScreen *screen); -HomescreenHandler::HomescreenHandler(Shell *_aglShell, ApplicationLauncher *launcher, QObject *parent) : - QObject(parent), - aglShell(_aglShell) +HomescreenHandler::HomescreenHandler(ApplicationLauncher *launcher, GrpcClient *_client, QObject *parent) : + QObject(parent) + , m_grpc_client(_client) { mp_launcher = launcher; mp_applauncher_client = new AppLauncherClient(); - QPlatformNativeInterface *native = qApp->platformNativeInterface(); // // The "started" event is received any time a start request is made to applaunchd, @@ -42,16 +42,10 @@ HomescreenHandler::HomescreenHandler(Shell *_aglShell, ApplicationLauncher *laun HomescreenHandler::~HomescreenHandler() { + delete m_grpc_client; delete mp_applauncher_client; } -static struct wl_output * -getWlOutput(QPlatformNativeInterface *native, QScreen *screen) -{ - void *output = native->nativeResourceForScreen("output", screen); - return static_cast(output); -} - void HomescreenHandler::tapShortcut(QString app_id) { HMI_DEBUG("HomeScreen","tapShortcut %s", app_id.toStdString().c_str()); @@ -91,17 +85,87 @@ void HomescreenHandler::addAppToStack(const QString& app_id) void HomescreenHandler::activateApp(const QString& app_id) { - struct agl_shell *agl_shell = aglShell->shell.get(); - QPlatformNativeInterface *native = qApp->platformNativeInterface(); - struct wl_output *mm_output = getWlOutput(native, qApp->screens().first()); + QScreen *default_screen = qApp->screens().first(); + std::string default_output_name; + + if (!default_screen) { + HMI_DEBUG("HomeScreen", "No default output found to activate on!\n"); + } else { + default_output_name = default_screen->name().toStdString(); + HMI_DEBUG("HomeScreen", "Activating app_id %s by default on output %s\n", + app_id.toStdString().c_str(), default_output_name.c_str()); + } if (mp_launcher) { mp_launcher->setCurrent(app_id); } - HMI_DEBUG("HomeScreen", "Activating application %s", app_id.toStdString().c_str()); + // search for a pending application which might have a different output + auto iter = pending_app_list.begin(); + bool found_pending_app = false; + while (iter != pending_app_list.end()) { + const QString &app_to_search = iter->first; + + if (app_to_search == app_id) { + found_pending_app = true; + HMI_DEBUG("HomeScreen", "Found app_id %s in pending list of applications", + app_id.toStdString().c_str()); + break; + } + + iter++; + } + + if (found_pending_app) { + const QString &output_name = iter->second; + QScreen *screen = + ::find_screen(output_name.toStdString().c_str()); + + if (!screen) { + HMI_DEBUG("HomeScreen", "Can't activate application %s on another " + "output, because output %s could not be found. " + "Trying with remoting ones.", + app_id.toStdString().c_str(), + output_name.toStdString().c_str()); + + // try with remoting-remote-X which is the streaming + // one + std::string new_remote_output = + "remoting-" + output_name.toStdString(); + + screen = ::find_screen(new_remote_output.c_str()); + if (!screen) { + HMI_DEBUG("HomeScreen", "Can't activate application %s on another " + "output, because output remoting-%s could not be found", + app_id.toStdString().c_str(), + output_name.toStdString().c_str()); + return; + } + + HMI_DEBUG("HomeScreen", "Found a stream remoting output %s to activate application %s on", + new_remote_output.c_str(), + app_id.toStdString().c_str()); + default_output_name = new_remote_output; + } else { + default_output_name = output_name.toStdString(); + } + + pending_app_list.erase(iter); + HMI_DEBUG("HomeScreen", "For application %s found another " + "output to activate %s\n", + app_id.toStdString().c_str(), + default_output_name.c_str()); + } + + if (default_output_name.empty()) { + HMI_DEBUG("HomeScreen", "No suitable output found for activating %s", + app_id.toStdString().c_str()); + return; + } - agl_shell_activate_app(agl_shell, app_id.toStdString().c_str(), mm_output); + HMI_DEBUG("HomeScreen", "Activating application %s on output %s", + app_id.toStdString().c_str(), default_output_name.c_str()); + m_grpc_client->ActivateApp(app_id.toStdString(), default_output_name); } void HomescreenHandler::deactivateApp(const QString& app_id) @@ -123,5 +187,7 @@ void HomescreenHandler::processAppStatusEvent(const QString &app_id, const QStri } else if (status == "terminated") { HMI_DEBUG("HomeScreen", "Application %s terminated, activating last app", app_id.toStdString().c_str()); deactivateApp(app_id); + } else if (status == "deactivated") { + HMI_DEBUG("HomeScreen", "Application %s deactivated, activating last app", app_id.toStdString().c_str()); } }