src/hbcore/utils/hboogmwatcher.cpp
author hgs
Tue, 13 Jul 2010 22:03:02 +0300
changeset 13 5168dbe2168a
parent 5 627c4a0fd0e7
permissions -rw-r--r--
201027_1

/****************************************************************************
**
** Copyright (C) 2008-2010 Nokia Corporation and/or its subsidiary(-ies).
** All rights reserved.
** Contact: Nokia Corporation (developer.feedback@nokia.com)
**
** This file is part of the HbCore module of the UI Extensions for Mobile.
**
** GNU Lesser General Public License Usage
** This file may be used under the terms of the GNU Lesser General Public
** License version 2.1 as published by the Free Software Foundation and
** appearing in the file LICENSE.LGPL included in the packaging of this file.
** Please review the following information to ensure the GNU Lesser General
** Public License version 2.1 requirements will be met:
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, Nokia gives you certain additional
** rights.  These rights are described in the Nokia Qt LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
** If you have questions regarding the use of this file, please contact
** Nokia at developer.feedback@nokia.com.
**
****************************************************************************/

#include "hboogmwatcher_p.h"
#ifdef Q_OS_SYMBIAN
#include "hboogmwatcher_sym_p.h"
#else
#include "hboogmwatcher_dummy_p.h"
#endif
#include <hbiconitem.h>
#include <hbiconitem_p.h>
#ifdef HB_EFFECTS_OPENVG
#include <hbvgeffect_p.h>
#endif
#include <QApplication>
#include "hbiconloader_p.h"

/*!
  \class HbOogmWatcher

  \brief Listens for out-of-graphics memory notifications and distributes them
  via a signal. Also tries to reduce the resource usage of the pixmap cache and
  non-visible HbIconItem instances, whenever the low-graphics-memory event is
  received.

  \internal
*/

/*!
  \fn void HbOogmWatcher::graphicsMemoryNeeded()

  This signal is emitted when the amount of free graphics memory goes below some
  critical limit. Note that this has nothing to do with the amount of free
  system memory (RAM). When this signal is emitted, all entities, that have
  anything to do with graphics memory, are expected to perform as much cleanup
  as possible in order to increase the amount of free graphics memory.
*/

static bool oogmWatcherDeleted = false;

/*!
    Returns the global HbOogmWatcher instance.
 */
HbOogmWatcher *HbOogmWatcher::instance()
{
    if (oogmWatcherDeleted) {
        return 0;
    }
    static HbOogmWatcher *watcher = new HbOogmWatcher(qApp);
    return watcher;
}

HbOogmWatcher::HbOogmWatcher(QObject *parent)
    : QObject(parent), d_ptr(new HbOogmWatcherPrivate)
{
    Q_D(HbOogmWatcher);
    d->q_ptr = this;
    d->mRenderMode = EHWRendering;
}

HbOogmWatcher::~HbOogmWatcher()
{
    delete d_ptr;
    oogmWatcherDeleted = true;
}

/*!
  Forces the graphics-memory-low notifications to be sent.
  Useful for forcing icons to perform some cleanup, for example.
 */
void HbOogmWatcher::notifyGraphicsMemoryLow()
{
    Q_D(HbOogmWatcher);
    d->graphicsMemoryLow();
}

/*!
  \internal
*/
void HbOogmWatcherPrivate::graphicsMemoryLow()
{
    qWarning("HbOogmWatcher::graphicsMemoryLow()");
    if (mRenderMode == EHWRendering) {
        mRenderMode = ESWRendering;
        HbIconLoader::global()->switchRenderingMode(mRenderMode);
    }
#ifdef HB_EFFECTS_OPENVG
    // Destroy the cached pixmaps of effects. This is also necessary
    // to make the OpenVG filter effect caching working properly. (if
    // Qt would free the pixmaps' underlying VGImage when graphics
    // memory is low then that would render the filter effects' cached
    // pixmaps invalid so we just drop them here)
    HbVgEffect::releaseCachedResources();
#endif
    // Drop the underlying pixmap data (if possible) for all HbIconItems that
    // are not currently visible.
    int n = 0;
    foreach(HbIconItem * iconItem, mIconItems) {
        if (!iconItem->isVisible()) {
            HbIconItemPrivate::d_ptr(iconItem)->clearStoredIconContent();
            ++n;
        }
    }
    emit q_ptr->iconCleanupDone(n);
    emit q_ptr->graphicsMemoryLow();
}

/*!
  \internal
*/
void HbOogmWatcherPrivate::graphicsMemoryGood()
{
    qWarning("HbOogmWatcher::graphicsMemoryGood()");
    if (mRenderMode == ESWRendering) {
        mRenderMode = EHWRendering;
        HbIconLoader::global()->switchRenderingMode(mRenderMode);
    }
    emit q_ptr->graphicsMemoryGood();
}

/*!  Registers an HbIconItem instance. Whenever graphics memory is
  low, the registered iconitems will be examined and the ones that are
  not visible will be asked to drop the underlying data of their
  HbIcons.
 */
void HbOogmWatcher::registerIconItem(HbIconItem *item)
{
    Q_D(HbOogmWatcher);
    if (!d->mIconItems.contains(item)) {
        d->mIconItems.append(item);
    }
}

/*!
  Unregisters an HbIconItem. This must be done when the item is deleted, for example.
 */
void HbOogmWatcher::unregisterIconItem(HbIconItem *item)
{
    Q_D(HbOogmWatcher);
    d->mIconItems.removeOne(item);
}