graphicscomposition/surfaceupdate/inc/compositionsurfaceupdate.h
author MattD <ext-matt.4.davies@nokia.com>
Fri, 24 Sep 2010 16:48:05 +0100
branchEGL_MERGE
changeset 190 19ce5231ffe4
parent 0 5d03bc08d59c
permissions -rw-r--r--
merged back another dead head. No changes.

// 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:
// CompositionSurfaceUpdate.h
// Interface to be implemented and registered with SUS by listener for surface content update messages.  
//
#ifndef __COMPOSITIONSURFACEUPDATE_H__
#define __COMPOSITIONSURFACEUPDATE_H__

/**
 * \brief Interface to implement and register with SUS to receive ContentUpdated() notifications. 
 * 
 * 
 **/
NONSHARABLE_CLASS(MCompositionSurfaceUpdate)
    {
public:
    enum    
        {
        KUidCompositionSurfaceUpdate =  0x10286498,
        ETypeId=     KUidCompositionSurfaceUpdate 
        };
    /*-------------------------------------------------------------------*//*!
     * \brief   Gets the API version number of the
     *          implementation.
     *
     * @return  1 for Oghma conformant implementation,
     *          2 for Sphinx (Maybe).
     *          3 for Native Stream first version.
     *//*-------------------------------------------------------------------*/

        virtual TInt        ApiVersion          (void) = 0;

    /*-------------------------------------------------------------------*//*!
     * \brief   Gets the internal version number of the
     *          implementation.
     *
     * @return  The version number of the 
     *          instance.
     *//*-------------------------------------------------------------------*/

        virtual TVersion    InternalVersion     (void) = 0;

        /*-------------------------------------------------------------------*//*!
         * \brief   A function that responds to surface content notifications.
         *
         * When the contents of a surface change, this function gets called
         * by a mechanism that is an implementation detail of the graphics
         * driver together with the Native Stream and Compositor implementations. 
         * The call can originate from different processes and the
         * Native Stream together with the Compositor implementation
         * relays the information content of it, through implementation
         * specific means, to trigger the actual composition soon after this
         * call - this composition call should be synchronized with the
         * refresh rate of the screen.
         *
         * @param   aSurface            The surface that has been updated.
         * @param   aBuffer             The buffer of the surface to be used in
         *                              composition. Integer starting from 0.
         * @param   aRegion             The sub-area that has the updates. If NULL, the
         *                              whole surface is considered changed.
         * @param   aStatusConsumed     A request status object or NULL. If not NULL, then the
         *                              request status is completed once the receiver
         *                              does not anymore need the contents of the
         *                              surface to render the update. This may happen
         *                              before actually displaying the finished frame.
         * @param   aStatusDisplayed    This is signaled after the composited frame
         *                              is posted the to display for the first time after
         *                              the update. After this the value in
         *                              aTimeStamp is valid, if the value in the
         *                              status object is KErrNone. Can be NULL, if
         *                              no signal is desired.
         * @param   aTimeStamp          Value of the User::FastCounter() right after the
         *                              display refresh that signaled aStatusDisplayed.
         * @param   aStatusDispXTimes   This is signaled when the surface has been on
         *                              the screen for aDisplayedXTimes refreshes,
         *                              including the update that signaled aStatusDisplayed.
         *                              Can be NULL, if no signal is wanted.
         * @param   aDisplayedXTimes    The number of refreshes after which aStatusDispXTimes
         *                              is signaled or NULL. If values is provided, it must be
         *                              >= 1.
         *
         * @pre     The MCompositionSurfaceUpdate implementation is waiting for content
         *          update notifications.
         * @pre     aSurface.IsNull() returns EFalse.
         * @pre     The surface aSurface is registered with the receiver or all status
         *          requests are completed with KErrArgument.
         * @pre     Either both aStatusDisplayed and aTimeStamp are NULL or neither
         *          of them are.
         * @pre     Either both aStatusDispXTimes and aDisplayedXTimes are NULL or
         *          neither of them are.
         * @post    The MCompositionSurfaceUpdate implementation is waiting for vsync 
         *          or another synchronisation method to trigger composition,
         *          depending on cached visibility information.
         * @note    The updated region is used only as an optimisation hint.
         *          the current contents of the surface are always used for
         *          composition independent of the aRegion.
         * @see     Surface Update API Specification for further details
         *          about the semantics of the parameters and return values
         *          of the TRequestStatus objects.
         *//*-------------------------------------------------------------------*/

            virtual void        ContentUpdated      (const TSurfaceId&  aSurface,
                                                     TInt               aBuffer,
                                                     const TRegion*     aRegion,
                                                     TRequestStatus*    aStatusConsumed,
                                                     TRequestStatus*    aStatusDisplayed,
                                                     TUint32*           aTimeStamp,
                                                     TRequestStatus*    aStatusDispXTimes,
                                                     TInt*              aDisplayedXTimes) = 0;
public:
    /** Get Extension Interface.
     *  Implemented using the CBase::Extension_() mechanism 
     *  Note that the pointer returned is only good for the lifetime of the called CBase derived object.
     *  @param  aExtensionId    The GUID/ Well-known ID of the interface
     *  @return pointer to the interface or NULL if not available
     **/
        inline TAny* GetInterface(TUint aExtensionId);
    /** Get Extension Interface - templated helper.
     *  Resolves the ID and returned pointer based on the class name.
     *  Note that the pointer returned is only good for the lifetime of the called CBase derived object.
     *  Class name should support ETypeId intergral value, else use non-template version. 
     *  @param  MClass  The class of the interface with embedded GUID / Well known ID 
     *  @return pointer to the interface or NULL if not available
     **/
        template <class MClass> MClass* GetInterface()
        {
            return static_cast<MClass*>(GetInterface(MClass::ETypeId));
        }

protected:  //From CBase
    virtual TInt Extension_(TUint aExtensionId, TAny*& a0, TAny* a1)=0;
    
    };

inline TAny* MCompositionSurfaceUpdate::GetInterface(TUint aExtensionId)
    {
    TAny*   retVal=NULL;
    //Note that extension is intentionally not overloaded in MCompositionSurfaceUpdate
    if (this->Extension_(aExtensionId,retVal,NULL)<KErrNone)
        {
        return NULL;
        }
    else
        {
        return retVal;
        }
    }

#endif  //__COMPOSITIONSURFACEUPDATE_H__