epoc32/include/mw/animationframe.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
parent 3 e1b950c65cb4
permissions -rw-r--r--
Current Symbian^3 public API header files (from PDK 3.0.h)
This is the epoc32/include tree with the "platform" subtrees removed, and
all but a selected few mbg and rsg files removed.
     1 // Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies).
     2 // All rights reserved.
     3 // This component and the accompanying materials are made available
     4 // under the terms of "Eclipse Public License v1.0"
     5 // which accompanies this distribution, and is available
     6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
     7 //
     8 // Initial Contributors:
     9 // Nokia Corporation - initial contribution.
    10 //
    11 // Contributors:
    12 //
    13 // Description:
    14 //
    15 
    16 #ifndef __ANIMATIONFRAME_H__
    17 #define __ANIMATIONFRAME_H__
    18 
    19 #include <icl/imagedata.h>
    20 
    21 class CFbsBitmap;
    22 
    23 /**
    24 Data format for individual bitmap format animation frames.
    25 
    26 Animators and data providers which use the "bitmap" data type use objects
    27 of this type to transfer data.
    28 
    29 You do not need to instantiate an object of this type unless you are writing
    30 a new data provider.
    31 
    32 @see CBitmapAnimator
    33 @see CICLAnimationDataProvider
    34 @publishedAll
    35 @released
    36 */
    37 class CAnimationFrame : public CBase
    38 	{
    39 public:
    40 	/** Structure used for passing a CAnimationFrame safely over a
    41 	client/server connection.*/
    42 	struct THandles
    43 		{
    44 		/** A handle to the bitmap into which the decoded frame(s) are put */
    45 		TInt iBitmapHandle;
    46 		/**	The bitmap mask for the changed area for this frame */
    47 		TInt iMaskHandle;
    48 		/** General frame info provided by all plugins */
    49 		TFrameInfo iFrameInfo;
    50 		};
    51 public:
    52 	virtual ~CAnimationFrame();
    53 	IMPORT_C static CAnimationFrame* NewL();
    54 	IMPORT_C static CAnimationFrame* NewL(const THandles& aHandles);
    55 	IMPORT_C void GetHandles(THandles & aHandles) const;
    56 	IMPORT_C void SetHandlesL(const THandles & aHandles);
    57 	IMPORT_C void CreateL(const TFrameInfo& aFrameInfo);
    58 	/** Returns the bitmap image for the changed area for this frame
    59 	@return A pointer to a CFbsBitmap */
    60 	CFbsBitmap* Bitmap()				{ return iBitmap; }
    61 	/** Returns the bitmap image for the changed area for this frame
    62 	@return A pointer to a const CFbsBitmap */
    63 	const CFbsBitmap* Bitmap() const	{ return iBitmap; }
    64 	/** Returns the bitmap mask for the changed area for this frame
    65 	@return A pointer to a CFbsBitmap */
    66 	CFbsBitmap* Mask()					{ return iMask; }
    67 	/** Returns the bitmap mask for the changed area for this frame
    68 	@return A pointer to a const CFbsBitmap */
    69 	const CFbsBitmap* Mask() const		{ return iMask; }
    70 	/** Returns information about the frame.
    71   	@return A TFrameInfo */
    72   	TFrameInfo& FrameInfo() 			{ return iFrameInfo; }
    73   	/** Returns information about the frame.	
    74 	@return A const TFrameInfo */
    75 	const TFrameInfo& FrameInfo() const	{ return iFrameInfo; }
    76 protected:
    77 	IMPORT_C virtual void CAnimationFrame_Reserved1();
    78 	IMPORT_C virtual void CAnimationFrame_Reserved2();
    79 private:
    80 	TInt iCAnimationFrame_Reserved;
    81 private:
    82 	CAnimationFrame() {};
    83 	CAnimationFrame(const CAnimationFrame&); // no implementation
    84 	CAnimationFrame& operator=(const CAnimationFrame&); // no implementation
    85 	void ConstructL();
    86 private:
    87 	CFbsBitmap* iBitmap;
    88 	CFbsBitmap* iMask;
    89 	TFrameInfo iFrameInfo;
    90 	};
    91 
    92 #endif //__ANIMATIONFRAME_H__