screensaver/screensavermodel/src/screensaver.cpp
branchRCL_3
changeset 33 5f0182e07bfb
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/screensaver/screensavermodel/src/screensaver.cpp	Tue Aug 31 15:06:34 2010 +0300
@@ -0,0 +1,324 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+* 
+* Description:  Base class for all screensavers.
+*
+*/
+
+#include "screensaver.h"
+#include "screensaver_p.h"
+
+/*!
+    \enum ScreensaverState
+    Lists states that the Screensaver can be in.
+*/
+
+/*
+    \var ScreensaverState ScreensaverStateConstructed
+    Screensaver is in this state right after construction.
+*/
+
+/*
+    \var ScreensaverState ScreensaverStateInitialized
+
+    All Screensaver resources are initialized.
+    Screensaver is set to Initialized state after a call to initialize 
+    (if previously Constructed or Closed) method.
+*/
+
+/*
+    \var Screensaver ScreensaverStateBackground
+    Screensaver is in background, its operations are suspended.
+    Screensaver is set to Background after a call to background method.
+*/
+
+/*
+    \var Screensaver ScreensaverStateForeground 
+    Screensaver is in foreground and fully operational, showing the main visualization.
+    Screensaver is set to Foreground after a call to foreground method.
+*/
+
+/*
+    \var Screensaver ScreensaverStatePartialForeground 
+    Screensaver has limited foreground (in OLED display cases).
+    Screensaver is set to PartialForeground after a call to partialForeground method.
+*/
+
+/*
+    \var Screensaver ScreensaverStatePowerSave 
+    Device is in power save mode. Screensaver should limit all processing.
+    Screensaver is set to PowerSave after a call to powerSave method.
+*/
+
+/*
+    \var Screensaver ScreensaverStateClosed 
+    Screensaver is closed. All resources should be frees.
+    Screensaver is set to Closed after a call to close method.
+*/
+
+/*!
+    \class Screensaver
+    \brief Base class for all screensavers.
+
+    Screensaver plug-ins provide the visualizations for different screensaver application states.
+    A Screensaver is notified about state changes and in consequence it should emit a signal
+    viewChanged() carrying a QGraphicsWidget which will be set as the current view.
+    The application takse care about tracing device status so the Screensaver should be only
+    concerned about the GUI.
+ */
+
+/*!
+    Constructs a new Screensaver with \a parent.
+ */
+Screensaver::Screensaver(QObject *parent) :
+    QObject(parent), m_d(new ScreensaverPrivate(this))
+{
+}
+
+/*!
+    Destructs the class.
+ */
+Screensaver::~Screensaver()
+{
+    delete m_d;
+}
+
+/*!
+    \fn void Screensaver::faulted()
+
+    This signal is emitted if a fault occurs when changing Screensaver's state.
+ */
+
+/*!
+    \fn void Screensaver::viewChanged(QGraphicsWidget *widget)
+
+    This signal should be emitted when the Screensaver needs to change its visualization
+    after a state change.
+    \param widget The graphics widget container holding the current visualization.
+ */
+
+/*!
+    \fn void Screensaver::unlockRequested()
+
+    This signal is emitted if screensaver wants the device to be unlocked.
+ */
+
+/*!
+    \fn void Screensaver::screenPowerModeRequested(ScreenPowerMode mode)
+
+    This signal is emitted when screensaver wants to switch the power
+    mode of the screen, or update the visible area in power save mode.
+ */
+
+/*!
+    Returns the state that the Screensaver is currently in.
+    \return The current state.
+ */
+ScreensaverState Screensaver::currentState()
+{
+    return m_d->currentState();
+}
+
+/*!
+    \fn virtual void getActiveScreenRows(int *firstActiveRow, int *lastActiveRow) = 0
+
+    Inherited screensavers must implement this function to return the rows where 
+    the screensaver wants to draw graphics. This is called when screen is set to the
+    power save mode. The values returned do not matter in case the screensaver doesn't
+    ask for power save mode.
+    Note that the returned rows should reflect the rows in the natural orientation
+    of the screen device. That is, if default orientation of the screen is portrait,
+    then the return value in landscape mode must reflect the columns between which
+    the graphics are drawn.
+ */
+
+/*!
+    \fn virtual void updateLayout() = 0
+
+    Inherited screensavers must implement this function to reload the screen layout
+    for the current screen orientation.
+ */
+
+/*!
+    Initializes the Screensaver
+ */
+void Screensaver::initialize()
+{
+    m_d->initialize();
+}
+
+/*!
+    Called when the application is in foreground.
+ */
+void Screensaver::foreground()
+{
+    m_d->foreground();
+}
+
+/*!
+    Called when the application gains limited foreground as with OLED display cases.
+ */
+void Screensaver::partialForeground()
+{
+    m_d->partialForeground();
+}
+
+/*!
+    Called when the application goes to background.
+ */
+void Screensaver::background()
+{
+    m_d->background();
+}
+
+/*!
+    Called when device enters power save mode.
+ */
+void Screensaver::powerSave()
+{
+    m_d->powerSave();
+}
+
+/*!
+    Stops Screensaver's processing.
+ */
+void Screensaver::close()
+{
+    m_d->close();
+}
+
+/*!
+    If there is any active universal indicator when screensaver
+    is launched, then this method is called.
+    Note that indicators are implemented only for Symbian/S60 OS.
+    \param activeIndicators List of currently active indicators in 
+    the chronological order according to their arrival time.
+ */
+void Screensaver::handleActiveIndicators(
+    const QList<HbIndicatorInterface*> &activeIndicators)
+{
+    // TODO: need to go through private class?
+    m_d->handleActiveIndicators(activeIndicators);
+}
+
+/*!
+    Called when some universal indicator is activated.
+    \param activatedIndicator Activated indicator. Ownership is not transferred.
+ */
+void Screensaver::handleActivatedIndicator(
+    HbIndicatorInterface* activatedIndicator)
+{
+    m_d->handleActivatedIndicator(activatedIndicator);
+}
+
+/*!
+    Called when some universal indicator is deactivated.
+    \param activatedIndicator Deactivated indicator. Ownership is not transferred.
+ */
+void Screensaver::handleDeactivatedIndicator(
+    HbIndicatorInterface* deactivatedIndicator)
+{
+    m_d->handleDeactivatedIndicator(deactivatedIndicator);
+}
+
+
+/*!
+    \fn virtual bool Screensaver::onForeground() = 0
+
+    After a call the Screensaver should emit the foreground state visualization.
+    Returns true if the operation secceeded, otherwise false - in this case 
+    the faulted() signal will be emitted by the base class.
+    \return Indicates if the operation succeeded.
+ */
+
+/*!
+    \fn virtual bool Screensaver::onPartialForeground() = 0
+
+    After a call the Screensaver should emit the partial foreground state visualization.
+    This is valid for OLED display cases when the screensaver is displayed at all times
+    with limited functionality.
+    Returns true if the operation secceeded, otherwise false - in this case 
+    the faulted() signal will be emitted by the base class.
+    \return Indicates if the operation succeeded.
+ */
+
+/*!
+    \fn virtual bool Screensaver::onBackground() = 0
+
+    After a call the Screensaver should limit its processing.
+    Returns true if the operation secceeded, otherwise false - in this case 
+    the faulted() signal will be emitted by the base class.
+    \return Indicates if the operation succeeded.
+ */
+
+/*!
+    \fn virtual bool Screensaver::onPowerSave() = 0
+
+    After a call the Screensaver should limit its processing as much as possible.
+    Returns true if the operation secceeded, otherwise false - in this case 
+    the faulted() signal will be emitted by the base class.
+    \return Indicates if the operation succeeded.
+ */
+
+/*!
+    After a call it should initialize the Screensaver.
+    Returns true if the operation secceeded, otherwise false - in this case 
+    the faulted() signal will be emitted by the base class.
+    The default implementation does nothing and always returns true.
+    \return Indicates if the operation succeeded.
+ */
+bool Screensaver::onInitialize()
+{
+    return true;
+}
+
+/*!
+    After a call it should close the Screensaver.
+    The Screensaver should also free all resources.
+    Returns true if the operation secceeded, otherwise false - in this case 
+    the faulted() signal will be emitted by the base class.
+    The default implementation does nothing and always returns true.
+    \return Indicates if the operation succeeded.
+ */
+bool Screensaver::onClose()
+{
+    return true;
+}
+
+/*!
+    The default implementation is empty.
+ */
+void Screensaver::onHandleActiveIndicators(
+        const QList<HbIndicatorInterface*> &activeIndicators)
+{
+    Q_UNUSED(activeIndicators);
+}
+
+/*!
+    The default implementation is empty.
+ */
+void Screensaver::onHandleActivatedIndicator(
+        HbIndicatorInterface *activatedIndicator)
+{
+    Q_UNUSED(activatedIndicator);
+}
+
+/*!
+    The default implementation is empty.
+ */
+void Screensaver::onHandleDeactivatedIndicator(
+        HbIndicatorInterface *deactivatedIndicator)
+{
+    Q_UNUSED(deactivatedIndicator);
+}
+