summaryrefslogtreecommitdiffstats
path: root/README.md
AgeCommit message (Expand)AuthorFilesLines
2020-07-24Update README.md and meta-agl.mdJan-Simon Möller1-135/+1
2020-07-13Point to new mailinglist at groups.ioJan-Simon Moeller1-1/+1
2019-05-13Fix the headline of meta-agl document.Li Xiaoming1-2/+2
2018-08-01Remove porter reference from meta-aglRonan Le Martret1-54/+33
2018-01-23bblayers.conf: Remove meta-ruby and meta-efl layerChanghyeok Bae1-1/+0
2017-03-03Add dependency to imagesRonan1-4/+2
2016-12-05Merge meta-agl-security into meta-aglStephane Desneux1-4/+0
2016-08-05Rewrite and restructure readme filesJan-Simon Moeller1-272/+97
2015-10-02Reworking packagegroups of AGL DistributionTadao Tanikawa1-24/+24
2015-09-22Update layer dependencies and build instructionsTadao Tanikawa1-22/+108
2015-08-19Add new Yocto layer for common packages to IVI systemsTadao Tanikawa1-6/+14
2015-08-14Update commit id for meta-renesas in README.md0.2015.33Tadao Tanikawa1-2/+2
2015-08-08Appended more detailed build procedure for R-Car M2 porter boardTadao Tanikawa1-27/+103
2015-08-07Support R-Car M2 porter boardTadao Tanikawa1-2/+83
2015-07-23Fix typo in README.mdTadao Tanikawa1-1/+1
2015-07-22Fix line feed code README.mdTadao Tanikawa1-87/+87
2015-07-22Mini-manual of `meta-agl`Tadao Tanikawa1-0/+87
id='n261' href='#n261'>261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279
/*
 * Copyright (C) 2016, 2017 Mentor Graphics Development (Deutschland) GmbH
 *
 * 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 "layouthandler.h"
#include <QTimerEvent>

LayoutHandler::LayoutHandler(QObject *parent) :
    QObject(parent),
    m_secondsTimerId(-1),
    mp_dBusWindowManagerProxy(0),
    mp_dBusPopupProxy(0),
    m_visibleSurfaces(),
    m_invisibleSurfaces(),
    m_requestsToBeVisibleSurfaces()
{
    qDBusRegisterMetaType<SimplePoint>();
    qDBusRegisterMetaType<QList<SimplePoint> >();
    qDBusRegisterMetaType<LayoutArea>();
    qDBusRegisterMetaType<QList<LayoutArea> >();
    qDBusRegisterMetaType<Layout>();
    qDBusRegisterMetaType<QList<Layout> >();

    qDebug("D-Bus: connect to org.agl.windowmanager /windowmanager");
    mp_dBusWindowManagerProxy = new org::agl::windowmanager("org.agl.windowmanager",
                                              "/windowmanager",
                                              QDBusConnection::sessionBus(),
                                              0);
    qDebug("D-Bus: connect to org.agl.homescreen /Popup");
    mp_dBusPopupProxy = new org::agl::popup("org.agl.homescreen",
                                              "/Popup",
                                              QDBusConnection::sessionBus(),
                                              0);

    QDBusConnection::sessionBus().connect("org.agl.windowmanager",
                                       "/windowmanager",
                                       "org.agl.windowmanager",
                                       "surfaceVisibilityChanged",
                                       this,
                                       SIGNAL(surfaceVisibilityChanged(int,bool)));

    QList<LayoutArea> surfaceAreas;
    LayoutArea surfaceArea;

    const int SCREEN_WIDTH = 1080;
    const int SCREEN_HEIGHT = 1920;

    const int TOPAREA_HEIGHT = 218;
    const int TOPAREA_WIDTH = SCREEN_WIDTH;
    const int TOPAREA_X = 0;
    const int TOPAREA_Y = 0;
    const int MEDIAAREA_HEIGHT = 215;
    const int MEDIAAREA_WIDTH = SCREEN_WIDTH;
    const int MEDIAAREA_X = 0;
    const int MEDIAAREA_Y = SCREEN_HEIGHT - MEDIAAREA_HEIGHT;


    // only one Layout for CES2017 needed
    // layout 1:
    // one app surface, statusbar, control bar
    surfaceArea.x = 0;
    surfaceArea.y = TOPAREA_HEIGHT;
    surfaceArea.width = SCREEN_WIDTH;
    surfaceArea.height = SCREEN_HEIGHT - TOPAREA_HEIGHT - MEDIAAREA_HEIGHT;

    surfaceAreas.append(surfaceArea);

    mp_dBusWindowManagerProxy->addLayout(1, "one app", surfaceAreas);
}

LayoutHandler::~LayoutHandler()
{
    delete mp_dBusPopupProxy;
    delete mp_dBusWindowManagerProxy;
}

void LayoutHandler::showAppLayer(const QString &app_id, int pid)
{
    mp_dBusWindowManagerProxy->showAppLayer(app_id, pid);
}

void LayoutHandler::hideAppLayer()
{
    // POPUP=0, HOMESCREEN_OVERLAY=1, APPS=2, HOMESCREEN=3
    mp_dBusWindowManagerProxy->hideLayer(2); // TODO: enum
}

void LayoutHandler::makeMeVisible(int pid)
{
    qDebug("makeMeVisible %d", pid);

#if 0
    // if app does not request to be visible
    if (-1 == m_requestsToBeVisiblePids.indexOf(pid))
    {
        m_requestsToBeVisiblePids.append(pid);

        // callback every second
        if (-1 != m_secondsTimerId)
        {
            killTimer(m_secondsTimerId);
            m_secondsTimerId = -1;
        }
        m_secondsTimerId = startTimer(1000);
    }
    else
    {
        checkToDoQueue();
    }
#endif
}

void LayoutHandler::checkToDoQueue()
{
#if 0
    if ((-1 != m_secondsTimerId) && (0 == m_requestsToBeVisiblePids.size()))
    {
        killTimer(m_secondsTimerId);
        m_secondsTimerId = -1;
    }

    if (0 != m_requestsToBeVisiblePids.size())
    {
        int pid = m_requestsToBeVisiblePids.at(0);
        qDebug("pid %d wants to be visible", pid);

        QList<int> allSurfaces;
        allSurfaces = mp_dBusWindowManagerProxy->getAllSurfacesOfProcess(pid);
        if (0 == allSurfaces.size())
        {
            qDebug("no surfaces for pid %d. retrying!", pid);
        }
        else
        {
            m_requestsToBeVisiblePids.removeAt(0);
            qSort(allSurfaces);

            if (0 != allSurfaces.size())
            {
                int firstSurface = allSurfaces.at(0);

                if (-1 != m_visibleSurfaces.indexOf(firstSurface))
                {
                    qDebug("already visible");
                }
                else
                {
                    if (-1 != m_invisibleSurfaces.indexOf(firstSurface))
                    {
                        m_invisibleSurfaces.removeAt(m_invisibleSurfaces.indexOf(firstSurface));
                    }
                    if (-1 == m_requestsToBeVisibleSurfaces.indexOf(firstSurface))
                    {
                        m_requestsToBeVisibleSurfaces.append(firstSurface);
                    }

                    qDebug("before");
                    qDebug(" m_visibleSurfaces %d", m_visibleSurfaces.size());
                    qDebug(" m_invisibleSurfaces %d", m_invisibleSurfaces.size());
                    qDebug(" m_requestsToBeVisibleSurfaces %d", m_requestsToBeVisibleSurfaces.size());

                    QList<int> availableLayouts = mp_dBusWindowManagerProxy->getAvailableLayouts(1); // one app only for CES2017
                    if (1 == availableLayouts.size())
                    {
                        qDebug("active layout: %d", availableLayouts.at(0));
                        m_invisibleSurfaces.append(m_visibleSurfaces);
                        m_visibleSurfaces.clear();
                        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);
                        }

                        qDebug("after");
                        qDebug(" m_visibleSurfaces %d", m_visibleSurfaces.size());
                        qDebug(" m_invisibleSurfaces %d", m_invisibleSurfaces.size());
                        qDebug(" m_requestsToBeVisibleSurfaces %d", m_requestsToBeVisibleSurfaces.size());
                    }
                    else
                    {
                        qDebug("this should not happen!?");
                    }
                }
            }
        }
    }
#endif
}

#if 0
QList<int> LayoutHandler::requestGetAllSurfacesOfProcess(int pid)
{
    qDebug("requestGetAllSurfacesOfProcess %d", pid);

    return mp_dBusWindowManagerProxy->getAllSurfacesOfProcess(pid);
}
#endif

int LayoutHandler::requestGetSurfaceStatus(int surfaceId)
{
    int result = -1;

    if (-1 != m_visibleSurfaces.indexOf(surfaceId))
    {
        result = 0;
    }
    if (-1 != m_invisibleSurfaces.indexOf(surfaceId))
    {
        result = 1;
    }
    if (-1 != m_requestsToBeVisibleSurfaces.indexOf(surfaceId))
    {
        result = 1;
    }

    return result;
}

void LayoutHandler::requestRenderSurfaceToArea(int surfaceId, int layoutArea)
{
    qDebug("requestRenderSurfaceToArea %d %d", surfaceId, layoutArea);
    mp_dBusWindowManagerProxy->setSurfaceToLayoutArea(surfaceId, layoutArea);
}

bool LayoutHandler::requestRenderSurfaceToAreaAllowed(int surfaceId, int layoutArea)
{
    qDebug("requestRenderSurfaceToAreaAllowed %d %d", surfaceId, layoutArea);
    bool result = true;
    return result;
}

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_visibleSurfaces.append(m_requestsToBeVisibleSurfaces);
    m_requestsToBeVisibleSurfaces.clear();

    mp_dBusWindowManagerProxy->setLayoutByName(layoutName);
    for (int i = 0; i < m_visibleSurfaces.size(); ++i)
    {
        mp_dBusWindowManagerProxy->setSurfaceToLayoutArea(i, i);
    }
}

void LayoutHandler::requestSurfaceVisibilityChanged(int surfaceId, bool visible)
{
    qDebug("requestSurfaceVisibilityChanged %d %s", surfaceId, visible ? "true" : "false");
    emit surfaceVisibilityChanged(surfaceId, visible);
}

void LayoutHandler::timerEvent(QTimerEvent *e)
{
    if (e->timerId() == m_secondsTimerId)
    {
        checkToDoQueue();
    }
}