dependencies/AknsSrvChunkLookup.h
author MattD <mattd@symbian.org>
Thu, 01 Apr 2010 12:18:40 +0100
branchv5backport
changeset 45 fd868a928992
parent 39 4e8bbb15b77a
permissions -rw-r--r--
Merging in kashif's additional head into fdim's

/*
* Copyright (c) 2003-2007 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:  Chunk Lookup.
*
*/


#ifndef AKNSSRVCHUNKLOOKUP_H
#define AKNSSRVCHUNKLOOKUP_H

// INCLUDES

#include <e32std.h>
#include <e32base.h>
#include <AknsItemDef.h>

// FORWARD DECLARATIONS
struct TAknsSrvItemDef;

/**
* A class for looking up and creating item definitions stored in the
* shared memory chunk.
*
* @since 2.0
*/
NONSHARABLE_CLASS(CAknsSrvChunkLookup) : public CBase
    {
    public: // Construction and destruction

        /**
        * SymbianOS two-phased constructor.
        *
        * @since 2.0
        *
        * @return A new instance of CAknsSrvChunkLookup.
        *
        * @par Exceptions:
        *   If the construction fails, the leaves with one of the system wide
        *   error codes.
        */
        static CAknsSrvChunkLookup* NewL();

        /**
        * Default C++ destructor.
        */
        virtual ~CAknsSrvChunkLookup();

    public: // New methods

        /**
        * Returns item definition object matching the given item ID.
        * Performs lookup for the given item ID and returns an instance of one
        * of the subclasses of CAknsItemDef matching the given ID. If the call
        * is successfull, ownership of the item definition object is transferred
        * to the caller.
        *
        * @since 2.0
        *
        * @param aID Item ID to be searched.
        *
        * @return Pointer to the item definition object now owned by the caller,
        *   or @c NULL if there was no match for the given IID.
        *
        * @par Exceptions:
        *   If construction of the item definition object failed, method leaves
        *   with an error code.
        */
        IMPORT_C CAknsItemDef* LookupAndCreateDefL( const TAknsItemID& aID );

        /**
        * Returns stored scalable bitmaps and optionally its mask if it
        * was stored. The ownership of the returned bitmap (and mask, if any)
        * is transferred to the caller.
        *
        * Optionally, the caller can give the current copy of the bitmap and
        * mask as aBitmap and aMask parameters. If the currently stored
        * scalable bitmaps have the same handles, they are not re-duplicated.
        * The ownership of the given bitmaps is transferred to chunk lookup.
        *
        * @since 2.8
        *
        * @param aID Item ID to be searched.
        *
        * @param aLayout The layout id type for the searhed item.
        *
        * @param aBitmap Current bitmap or @c NULL. Ownership is transferred.
        *   After return, contains the newly duplicated bitmap, or @c NULL if
        *   not found. Ownership is transferred.
        *
        * @param aMask Current mask or @c NULL. Ownership is transferred.
        *   After return, contains the newly duplicated mask, or @c NULL if
        *   not found. Ownership is transferred.
        */
        IMPORT_C void LookupAndCreateScalableItemL( const TAknsItemID& aID,
            const TInt aLayout, const TSize& aLayoutSize, CFbsBitmap*& aBitmap,
            CFbsBitmap*& aMask, TInt& aMorphing);

        /**
        * Blocks write access to the shared memory chunk.
        *
        * @since 2.0
        */
        void BeginRead();

        /**
        * Allows write access to the shared memory chunk.
        *
        * @since 2.0
        */
        void EndRead();

        /**
        * Blocks all rendering.
        *
        * @since 2.8
        */
        IMPORT_C void BeginRender();

        /**
        * Allows rendering.
        *
        * @since 2.8
        */
        IMPORT_C void EndRender();

    private: // Reserved exports

        /**
        * Reserved for future use.
        *
        * @since 2.0
        *
        * @return Always returns zero.
        */
        IMPORT_C TInt Reserved();

    protected: // New methods

        /**
        * Creates an item definition object (or leaves) based on the given
        * item definition structure.
        *
        * Note that this method does not use the semaphore, and is therefore
        * unprotected.
        *
        * @param aID Item ID of the item.
        *
        * @param aType Type of the definition.
        *
        * @param aDef Pointer to the definition.
        *
        * @param aBasePtr Chunk base pointer.
        *
        * @return Newly construction item definition object, or @c NULL if
        *   aDef was @c NULL.
        *
        * @since 2.0
        */
        CAknsItemDef* CreateUnprotectedL( const TAknsItemID& aID,
            const TAny* aDef, const TAknsItemType aType,
            const TAny* aBasePtr );

        /**
        * Returns stored scalable bitmaps and optionally its mask if it
        * was stored.
        *
        * Note that this method does not use the semaphore, and is therefore
        * unprotected.
        *
        * @since 2.8
        */
        void LookupAndCreateScalableItemUnprotectedL( const TAknsItemID& aID,
            const TInt aLayout, const TSize& aLayoutSize, CFbsBitmap*& aBitmap,
            CFbsBitmap*& aMask, TInt& aMorphing);

        /**
        *
        * @since 3.0
        */
        CAknsEffectQueueItemDef* CreateEffectQueueL( const TAknsItemID& aID,
            const TAny* aDefPtr, const TAny* aBasePtr );

        /**
        *
        * @since 3.0
        */
        CAknsAnimationItemDef* CreateAnimationL( const TAknsItemID& aID,
            const TAny* aDefPtr, const TAny* aBasePtr );

        /**
        * @since 3.0
        */
        CAknsEffectItemDef* CreateEffectL( const TUint8* aData,
            const TBool aIsAnimationCommand, const TAny* aBasePtr );

        /**
        * @since 3.0
        */
        CAknsEffectParamDef* CreateParameterL( const TUint8* aData, const TAny* aBasePtr );

        /**
        * @since 3.0
        */
        TUint32 CreateParameterL( CAknsEffectParamDef*& aDef,
                                  const TUint32 aOffset,
                                  const TAny* aDefPtr,
                                  const TAny* aBasePtr );

        /**
        * @since 3.0
        */
        TUint32 CreateEffectL( CAknsEffectItemDef*& aDef,
                               const TUint32 aOffset,
                               const TAny* aDefPtr,
                               const TAny* aBasePtr,
                               const TBool aIsAnimationCommand );

    protected: // Protected constructors

        /**
        * Default C++ constructor
        */
        CAknsSrvChunkLookup();

        /**
        * Second-phase constructor.
        */
        void ConstructL();

    private: // Data

        RChunk iSharedChunk;
        RSemaphore iWaitSema;
        RMutex iRenderMutex;

    };

#endif // AKNSSRVCHUNKLOOKUP_H

// End of file.