emailuis/uicomponents/inc/fstexture.h
author Simon Howkins <simonh@symbian.org>
Thu, 25 Nov 2010 12:13:04 +0000
branchRCL_3
changeset 83 31a5fbf5db1d
parent 0 8466d47a6819
permissions -rw-r--r--
Adjusted to avoid exports, etc, from a top-level bld.inf

/*
* Copyright (c) 2007-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: This file defines class CFsTexture.
*
*/


#ifndef __FSTEXTURE_H__
#define __FSTEXTURE_H__

// INCLUDES
#include <e32std.h>
#include <e32base.h>
//<cmail> SF
#include <alf/alftexture.h>
//</cmail>
#include "fstextureloader.h"
#include "fstextureobserver.h"

// FORWARD DECLARATIONS
class CFbsBitmap;
class CAlfPicture;
class CAlfTexture;
class CFsBitmapProvider;

// CONSTANTS
#define KFsUndefined (-1)

// CLASS DECLARATION

/**
*  CFsTexture
*  -
*/
class CFsTexture
    : public CBase
    {
    public:
        // Flags
        enum
            {
            EFlagNoneDefined,
            EFlagStatic = 1 << 1,
            EFlagPreserveProvider = 1 << 2
            };
    public: // Constructor, destructor

        /**
         * 2-phased constructor
         * @param aTexture
         * @param aObserver Observer reference
         * @param aProvider (Optional) Bitmap provider
         * @param aId Unique id
         * @return Instance of texture
         */
        static CFsTexture* NewL( CAlfTexture& aTexture,
                                 MFsTextureLoaderObserver& aObserver,
                                 CFsBitmapProvider* aProvider,
                                 const TInt aId
                               );


        /**
         * C++ Destructor
         */
        ~CFsTexture();
    public:
        /**
         * Return reference of Alf/Hitchock texture
         * @return Reference
         */

        CAlfTexture& Texture();


        /**
         * Return address of provider
         * @return null, or address of bitmap provider
         */
        CFsBitmapProvider* Provider();

        /**
         * Return position of texture
         * @return Position, -1 stands for undefined position
         */
        TInt Pos() const;

        /**
         * Set position
         * @param aPos New position
         */
        void SetPos( const TInt& aPos );

        /**
         * Unload bitmap, or cancel unload
         * @param aCancel, ETrue cancels possible unload procedure
         */
        void UnloadL( const TBool& aCancel );

        /**
         * Return internal size of texture
         * @return texture size, or overwritten internal size
         */
        TSize TextSize() const;

        /**
         * Overwrite default size
         * @param aSize New size
         */
        void SetTextSize( const TSize& aSize );

        /**
         * Return current flag status
         * @return Flag status
         */
        TInt TextFlags() const;

        /**
         * Set flag status
         * @aparam New staus
         */
        void SetTextFlags( const TInt& aFlags );

        /**
         * Return unique id of texture
         * @return Id
         */
        TInt Id() const;

    public: // for Timer callback access
        /**
         * Timer callback
         */
        void TimerExpiredL();
        
    private: // New methods
        /**
         * Stop timer
         */
        void StopTimer();

    private: // Constructor

        /**
         * C++ constructor
         * @param aTexture
         * @param aObserver Observer reference
         * @param aProvider (Optional) Bitmap provider
         * @param aId Unique id
         */
        CFsTexture( CAlfTexture& aTexture,
                    MFsTextureLoaderObserver& aObserver,
                    CFsBitmapProvider* aProvider,
                    const TInt aId
                  );


       /**
         * 2nd phase constructor
         */
        void ConstructL();

    private: // data
        /** Texture position */
        TInt iPos;
        
        /** Owns:*/
        CPeriodic* iUnloadTimer;        

        /** Texture reference */

        CAlfTexture& iTexture;

        
        /** Observer reference */
        MFsTextureLoaderObserver& iObserver;
        
        /** Internal text size, not related to texture size */
        TSize iTextSize;
        
        /** Internal flags */
        TInt iTextFlags;
        
        /** Owns: */
        CFsBitmapProvider* iProvider;
        
        /** Texture id */
        const TInt iId;
    };

/**
* Timer callback
* @aModel Address of instance, which will handle callback
* @return Response
*/
TInt TimerCallbackL( TAny* aModel );

#endif // __FSTEXTURE_H__

// End of File