X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=HomeScreen%2Fsrc%2Flayouthandler.cpp;h=5f52cd5a4f32d3d8b91bf84a276b5f01bc6f309f;hb=bf0f33bec5ad705666dff6c821334524c1b81583;hp=cb210186dff4a7f7fb950ece47170ff9dbda355d;hpb=ef00508748d82b3703951cc8eb46b289af8111b0;p=staging%2FHomeScreen.git diff --git a/HomeScreen/src/layouthandler.cpp b/HomeScreen/src/layouthandler.cpp index cb21018..5f52cd5 100644 --- a/HomeScreen/src/layouthandler.cpp +++ b/HomeScreen/src/layouthandler.cpp @@ -4,14 +4,16 @@ LayoutHandler::LayoutHandler(QObject *parent) : QObject(parent), mp_dBusWindowManagerProxy(0), mp_dBusPopupProxy(0), - m_visibleApps(), - m_invisibleApps(), - m_requestsToBeVisibleApps() + m_visibleSurfaces(), + m_invisibleSurfaces(), + m_requestsToBeVisibleSurfaces() { qDBusRegisterMetaType(); qDBusRegisterMetaType >(); - qDBusRegisterMetaType(); - qDBusRegisterMetaType >(); + qDBusRegisterMetaType(); + qDBusRegisterMetaType >(); + qDBusRegisterMetaType(); + qDBusRegisterMetaType >(); qDebug("D-Bus: connect to org.agl.windowmanager /windowmanager"); mp_dBusWindowManagerProxy = new org::agl::windowmanager("org.agl.windowmanager", @@ -34,8 +36,8 @@ LayoutHandler::~LayoutHandler() void LayoutHandler::setUpLayouts() { qDebug("setUpLayouts"); - QList surfaceAreas; - SimpleRect surfaceArea; + QList surfaceAreas; + LayoutArea surfaceArea; const int SCREEN_WIDTH = 1080; const int SCREEN_HEIGHT = 1920; @@ -108,76 +110,91 @@ void LayoutHandler::setUpLayouts() surfaceAreas.append(surfaceArea); mp_dBusWindowManagerProxy->addLayout(3, "side by side", surfaceAreas); - } void LayoutHandler::makeMeVisible(int pid) { qDebug("makeMeVisible %d", pid); - m_requestsToBeVisibleApps.append(pid); - qDebug("m_visibleApps %d", m_visibleApps.size()); - qDebug("m_invisibleApps %d", m_invisibleApps.size()); - qDebug("m_requestsToBeVisibleApps %d", m_requestsToBeVisibleApps.size()); + QList allSurfaces = mp_dBusWindowManagerProxy->getAllSurfacesOfProcess(pid); + qSort(allSurfaces); - QList availableLayouts = mp_dBusWindowManagerProxy->getAvailableLayouts(m_visibleApps.size() + m_requestsToBeVisibleApps.size()); - if (0 == availableLayouts.size()) + if (0 != allSurfaces.size()) { - // no layout fits the need! - // replace the last app - qDebug("no layout fits the need!"); - qDebug("replace the last app"); - - m_invisibleApps.append(m_visibleApps.last()); - m_visibleApps.removeLast(); + m_requestsToBeVisibleSurfaces.append(allSurfaces.at(0)); - m_visibleApps.append(m_requestsToBeVisibleApps); - m_requestsToBeVisibleApps.clear(); + qDebug("m_visibleSurfaces %d", m_visibleSurfaces.size()); + qDebug("m_invisibleSurfaces %d", m_invisibleSurfaces.size()); + qDebug("m_requestsToBeVisibleSurfaces %d", m_requestsToBeVisibleSurfaces.size()); - for (int i = 0; i < m_visibleApps.size(); ++i) + QList availableLayouts = mp_dBusWindowManagerProxy->getAvailableLayouts(m_visibleSurfaces.size() + m_requestsToBeVisibleSurfaces.size()); + if (0 == availableLayouts.size()) { - mp_dBusWindowManagerProxy->setPidToLayoutArea(i, i); - } - } - if (1 == availableLayouts.size()) - { - // switch to new layout - qDebug("switch to new layout %d", availableLayouts.at(0)); - m_visibleApps.append(m_requestsToBeVisibleApps); - m_requestsToBeVisibleApps.clear(); + // no layout fits the need! + // replace the last app + qDebug("no layout fits the need!"); + qDebug("replace the last surface"); - mp_dBusWindowManagerProxy->setLayoutById(availableLayouts.at(0)); - for (int i = 0; i < m_visibleApps.size(); ++i) - { - mp_dBusWindowManagerProxy->setPidToLayoutArea(i, i); - } - } - if (1 < availableLayouts.size()) - { - // more than one layout possible! Ask user. - qDebug("more than one layout possible! Ask user."); + m_invisibleSurfaces.append(m_visibleSurfaces.last()); + m_visibleSurfaces.removeLast(); + + m_visibleSurfaces.append(m_requestsToBeVisibleSurfaces); + m_requestsToBeVisibleSurfaces.clear(); - QStringList choices; - for (int i = 0; i < availableLayouts.size(); ++i) + for (int i = 0; i < m_visibleSurfaces.size(); ++i) + { + mp_dBusWindowManagerProxy->setSurfaceToLayoutArea(m_visibleSurfaces.at(i), i); + } + } + if (1 == availableLayouts.size()) { - choices.append(mp_dBusWindowManagerProxy->getLayoutName(availableLayouts.at(i))); + // switch to new layout + qDebug("switch to new layout %d", availableLayouts.at(0)); + m_visibleSurfaces.append(m_requestsToBeVisibleSurfaces); + m_requestsToBeVisibleSurfaces.clear(); + + mp_dBusWindowManagerProxy->setLayoutById(availableLayouts.at(0)); + for (int i = 0; i < m_visibleSurfaces.size(); ++i) + { + mp_dBusWindowManagerProxy->setSurfaceToLayoutArea(m_visibleSurfaces.at(i), i); + } } + if (1 < availableLayouts.size()) + { + // more than one layout possible! Ask user. + qDebug("more than one layout possible! Ask user."); - mp_dBusPopupProxy->showPopupComboBox("Select Layout", choices); + QStringList choices; + for (int i = 0; i < availableLayouts.size(); ++i) + { + choices.append(mp_dBusWindowManagerProxy->getLayoutName(availableLayouts.at(i))); + } + mp_dBusPopupProxy->showPopupComboBox("Select Layout", choices); + } } } +void LayoutHandler::requestRenderSurfaceToArea(int surfaceId, const QRect &renderArea) +{ + qDebug("requestRenderSurfaceToArea %d %d,%d,%d,%d", surfaceId, renderArea.x(), renderArea.y(), renderArea.width(), renderArea.height()); +} + +void LayoutHandler::requestSurfaceIdToFullScreen(int surfaceId) +{ + qDebug("requestSurfaceIdToFullScreen %d", surfaceId); +} + void LayoutHandler::setLayoutByName(QString layoutName) { // switch to new layout qDebug("setLayout: switch to new layout %s", layoutName.toStdString().c_str()); - m_visibleApps.append(m_requestsToBeVisibleApps); - m_requestsToBeVisibleApps.clear(); + m_visibleSurfaces.append(m_requestsToBeVisibleSurfaces); + m_requestsToBeVisibleSurfaces.clear(); mp_dBusWindowManagerProxy->setLayoutByName(layoutName); - for (int i = 0; i < m_visibleApps.size(); ++i) + for (int i = 0; i < m_visibleSurfaces.size(); ++i) { - mp_dBusWindowManagerProxy->setPidToLayoutArea(i, i); + mp_dBusWindowManagerProxy->setSurfaceToLayoutArea(i, i); } }