svgtopt/SVG/SVGImpl/inc/SVGMediaAnimationElementImpl.h
author hgs
Wed, 03 Nov 2010 18:56:10 +0200
changeset 46 88edb906c587
permissions -rw-r--r--
201044
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
46
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2005-2006 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  This class provides the functionality for the animation 
hgs
parents:
diff changeset
    15
                  element as specified in the SVG 1.2 specification
hgs
parents:
diff changeset
    16
 *
hgs
parents:
diff changeset
    17
*/
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#if !defined(__E32BASE_H__)
hgs
parents:
diff changeset
    20
#include <e32base.h>
hgs
parents:
diff changeset
    21
#endif
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
#ifndef C_SVGMediaAnimationElementImpl_H
hgs
parents:
diff changeset
    24
#define C_SVGMediaAnimationElementImpl_H
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
#include "SVGMediaElementBase.h"
hgs
parents:
diff changeset
    27
#include "SVGTimeContainer.h"
hgs
parents:
diff changeset
    28
#include "SVGListener.h"
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
class CSvgDocumentImpl;
hgs
parents:
diff changeset
    31
class MXmlDocument;
hgs
parents:
diff changeset
    32
class CSvgFitToViewBoxImpl;
hgs
parents:
diff changeset
    33
class CSvgErrorImpl;
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
NONSHARABLE_CLASS( CSvgMediaAnimationElementImpl ): 
hgs
parents:
diff changeset
    36
        public CSvgMediaElementBase, 
hgs
parents:
diff changeset
    37
        public MSvgMouseListener,
hgs
parents:
diff changeset
    38
        public MSvgTimeContainerObserver
hgs
parents:
diff changeset
    39
    {
hgs
parents:
diff changeset
    40
    
hgs
parents:
diff changeset
    41
     public:
hgs
parents:
diff changeset
    42
        /**
hgs
parents:
diff changeset
    43
         * Two Phase Constructor
hgs
parents:
diff changeset
    44
         *
hgs
parents:
diff changeset
    45
         * since S60 3.2
hgs
parents:
diff changeset
    46
         * @param  animation element id and document pointer
hgs
parents:
diff changeset
    47
         * @return Animation element object
hgs
parents:
diff changeset
    48
         */
hgs
parents:
diff changeset
    49
        static CSvgMediaAnimationElementImpl* NewL(  const TUint8 aElemID,
hgs
parents:
diff changeset
    50
                                      CSvgDocumentImpl* aDoc );
hgs
parents:
diff changeset
    51
        /**
hgs
parents:
diff changeset
    52
         * Two Phase Constructor
hgs
parents:
diff changeset
    53
         *
hgs
parents:
diff changeset
    54
         * since S60 3.2
hgs
parents:
diff changeset
    55
         * @param  animation element id and document pointer
hgs
parents:
diff changeset
    56
         * @return Animation element object
hgs
parents:
diff changeset
    57
         */
hgs
parents:
diff changeset
    58
         
hgs
parents:
diff changeset
    59
        static CSvgMediaAnimationElementImpl* NewLC(  const TUint8 aElemID,
hgs
parents:
diff changeset
    60
                                       CSvgDocumentImpl* aDoc );
hgs
parents:
diff changeset
    61
        /**
hgs
parents:
diff changeset
    62
        * Set the Synchronised behaviour for the animation element
hgs
parents:
diff changeset
    63
        * @since S60 3.2
hgs
parents:
diff changeset
    64
        * @param aValue "canSlip" | "locked" | "independent" | "default"
hgs
parents:
diff changeset
    65
        * @return none.
hgs
parents:
diff changeset
    66
        */
hgs
parents:
diff changeset
    67
        virtual void SetSyncBehavior( const TDesC& aValue );
hgs
parents:
diff changeset
    68
        
hgs
parents:
diff changeset
    69
        /**
hgs
parents:
diff changeset
    70
        * Set the Synchronised Tolerance for the animation element
hgs
parents:
diff changeset
    71
        * @since S60 3.2
hgs
parents:
diff changeset
    72
        * @param aValue Clock-value | "default"
hgs
parents:
diff changeset
    73
        * @return none.
hgs
parents:
diff changeset
    74
        */        
hgs
parents:
diff changeset
    75
        virtual void SetSyncTolerance( const TDesC& aValue );
hgs
parents:
diff changeset
    76
        
hgs
parents:
diff changeset
    77
        /**
hgs
parents:
diff changeset
    78
        * Set the animation element as Synchronised Master
hgs
parents:
diff changeset
    79
        * @since S60 3.2
hgs
parents:
diff changeset
    80
        * @param aValue "true" | "false"
hgs
parents:
diff changeset
    81
        * @return none.
hgs
parents:
diff changeset
    82
        */        
hgs
parents:
diff changeset
    83
        virtual void SetSyncMaster( const TDesC& aValue );
hgs
parents:
diff changeset
    84
                                               
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
    private:
hgs
parents:
diff changeset
    87
    
hgs
parents:
diff changeset
    88
        /**
hgs
parents:
diff changeset
    89
         * Two Phase Constructor
hgs
parents:
diff changeset
    90
         *
hgs
parents:
diff changeset
    91
         * since S60 3.2
hgs
parents:
diff changeset
    92
         * @param  animation element id and document pointer
hgs
parents:
diff changeset
    93
         * @return Animation element object
hgs
parents:
diff changeset
    94
         */
hgs
parents:
diff changeset
    95
         void                            ConstructL(  const TUint8 aElemID,
hgs
parents:
diff changeset
    96
                                                    CSvgDocumentImpl* aDoc );
hgs
parents:
diff changeset
    97
        
hgs
parents:
diff changeset
    98
        /**
hgs
parents:
diff changeset
    99
         * Constructor
hgs
parents:
diff changeset
   100
         *
hgs
parents:
diff changeset
   101
         * since S60 3.2
hgs
parents:
diff changeset
   102
         * @param aDoc a document pointer
hgs
parents:
diff changeset
   103
         * @return none
hgs
parents:
diff changeset
   104
         */                                                        
hgs
parents:
diff changeset
   105
        CSvgMediaAnimationElementImpl( CSvgDocumentImpl* aDoc );
hgs
parents:
diff changeset
   106
    public:
hgs
parents:
diff changeset
   107
         /**
hgs
parents:
diff changeset
   108
         * A method to (deep) clone the current element
hgs
parents:
diff changeset
   109
         *
hgs
parents:
diff changeset
   110
         * since S60 3.2
hgs
parents:
diff changeset
   111
         * @param None
hgs
parents:
diff changeset
   112
         * @return An MXmlElement pointer to the object that is a copy of 
hgs
parents:
diff changeset
   113
         * the current element
hgs
parents:
diff changeset
   114
         */
hgs
parents:
diff changeset
   115
         MXmlElement*        CloneL(MXmlElement* aParentElement);
hgs
parents:
diff changeset
   116
         
hgs
parents:
diff changeset
   117
        /**
hgs
parents:
diff changeset
   118
         * Destructor
hgs
parents:
diff changeset
   119
         *
hgs
parents:
diff changeset
   120
         * since S60 3.2
hgs
parents:
diff changeset
   121
         * @param none
hgs
parents:
diff changeset
   122
         * @return none
hgs
parents:
diff changeset
   123
         */
hgs
parents:
diff changeset
   124
        virtual                         ~CSvgMediaAnimationElementImpl();
hgs
parents:
diff changeset
   125
hgs
parents:
diff changeset
   126
        // From MXmlElement API
hgs
parents:
diff changeset
   127
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
        /**
hgs
parents:
diff changeset
   130
         * Set attribute interface for Animation element
hgs
parents:
diff changeset
   131
         * 
hgs
parents:
diff changeset
   132
         * since S60 3.2
hgs
parents:
diff changeset
   133
         * @param aName - A string buffer containing the name of the attribute
hgs
parents:
diff changeset
   134
         * @param aValue - A string buffer containing the value of the attribute
hgs
parents:
diff changeset
   135
         * @return An integer containing success/failure for this action
hgs
parents:
diff changeset
   136
         */
hgs
parents:
diff changeset
   137
        TInt                            SetAttributeL( const TDesC& aName,
hgs
parents:
diff changeset
   138
                                                       const TDesC& aValue );
hgs
parents:
diff changeset
   139
hgs
parents:
diff changeset
   140
        /**
hgs
parents:
diff changeset
   141
         * Set attribute interface for Animation element
hgs
parents:
diff changeset
   142
         *
hgs
parents:
diff changeset
   143
         * since S60 3.2
hgs
parents:
diff changeset
   144
         * @param aName - A string buffer containing the name of the attribute
hgs
parents:
diff changeset
   145
         * @return An integer containing success/failure for this action
hgs
parents:
diff changeset
   146
         */
hgs
parents:
diff changeset
   147
        TInt                            SetAttributeDesL( const TInt aNameId,
hgs
parents:
diff changeset
   148
										        	   const TDesC& aValue );
hgs
parents:
diff changeset
   149
hgs
parents:
diff changeset
   150
hgs
parents:
diff changeset
   151
        /**
hgs
parents:
diff changeset
   152
         * Returns x-y or width-height attributes for Animation element
hgs
parents:
diff changeset
   153
         *
hgs
parents:
diff changeset
   154
         * since S60 3.2
hgs
parents:
diff changeset
   155
         * @param
hgs
parents:
diff changeset
   156
         * @return An integer containing success/failure for this action
hgs
parents:
diff changeset
   157
         */
hgs
parents:
diff changeset
   158
        TInt                            GetAttributeFloat( const TInt aNameId,
hgs
parents:
diff changeset
   159
                                                           TFloatFixPt& aValue );
hgs
parents:
diff changeset
   160
hgs
parents:
diff changeset
   161
        /**
hgs
parents:
diff changeset
   162
         * Sets x-y or width-height attributes for Animatione element
hgs
parents:
diff changeset
   163
         *
hgs
parents:
diff changeset
   164
         * since S60 3.2
hgs
parents:
diff changeset
   165
         * @param
hgs
parents:
diff changeset
   166
         * @return An integer containing success/failure for this action
hgs
parents:
diff changeset
   167
         */
hgs
parents:
diff changeset
   168
        TInt                            SetAttributeFloatL( const TInt aNameId,
hgs
parents:
diff changeset
   169
                                                            TFloatFixPt aValue );
hgs
parents:
diff changeset
   170
hgs
parents:
diff changeset
   171
hgs
parents:
diff changeset
   172
        /**
hgs
parents:
diff changeset
   173
         * ReceiveEventL: This function will be called whenever the registered
hgs
parents:
diff changeset
   174
		 * event was happened.
hgs
parents:
diff changeset
   175
         *
hgs
parents:
diff changeset
   176
         * @since Series 60 3.1
hgs
parents:
diff changeset
   177
         * @param MSvgEvent* aEvent
hgs
parents:
diff changeset
   178
         * @return TBool ETrue if redraw is needed
hgs
parents:
diff changeset
   179
         */
hgs
parents:
diff changeset
   180
        TBool ReceiveEventL( MSvgEvent* aEvent );
hgs
parents:
diff changeset
   181
        
hgs
parents:
diff changeset
   182
        /**
hgs
parents:
diff changeset
   183
         * Resets the animation element,starts from initial position
hgs
parents:
diff changeset
   184
         *
hgs
parents:
diff changeset
   185
         * since S60 3.2
hgs
parents:
diff changeset
   186
         * @param none
hgs
parents:
diff changeset
   187
         * @return none
hgs
parents:
diff changeset
   188
         */    
hgs
parents:
diff changeset
   189
        void ResetAnimationL();
hgs
parents:
diff changeset
   190
        
hgs
parents:
diff changeset
   191
        /**
hgs
parents:
diff changeset
   192
         * Need method description
hgs
parents:
diff changeset
   193
         *
hgs
parents:
diff changeset
   194
         * since S60 3.2
hgs
parents:
diff changeset
   195
         * @param MSvgEvent
hgs
parents:
diff changeset
   196
         * @return none
hgs
parents:
diff changeset
   197
         */
hgs
parents:
diff changeset
   198
        void Reset( MSvgEvent* aEvent );
hgs
parents:
diff changeset
   199
hgs
parents:
diff changeset
   200
        /**
hgs
parents:
diff changeset
   201
         * Calls AnimProcL of animation element
hgs
parents:
diff changeset
   202
         *
hgs
parents:
diff changeset
   203
         * since S60 3.2
hgs
parents:
diff changeset
   204
         * @param
hgs
parents:
diff changeset
   205
         * @return TBool ETrue if child svg document is there
hgs
parents:
diff changeset
   206
         */
hgs
parents:
diff changeset
   207
    	TBool DoAnimProcL(MSvgEvent* aEvent);
hgs
parents:
diff changeset
   208
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
        /**
hgs
parents:
diff changeset
   211
         * Return wether an svg element is displayable, such as <rect>, <circle>, or
hgs
parents:
diff changeset
   212
         * an abstract element, such as <g>, <animate>.
hgs
parents:
diff changeset
   213
         *
hgs
parents:
diff changeset
   214
         * since S60 3.2
hgs
parents:
diff changeset
   215
         * @param None
hgs
parents:
diff changeset
   216
         * @return ETrue if element is viewable.
hgs
parents:
diff changeset
   217
         */
hgs
parents:
diff changeset
   218
        TBool               IsViewable(); 
hgs
parents:
diff changeset
   219
        
hgs
parents:
diff changeset
   220
        /**
hgs
parents:
diff changeset
   221
         * 
hgs
parents:
diff changeset
   222
         * since S60 3.2
hgs
parents:
diff changeset
   223
         * @param TBool
hgs
parents:
diff changeset
   224
         * @return none
hgs
parents:
diff changeset
   225
         */
hgs
parents:
diff changeset
   226
        void Print( TBool aIsEncodeOn );
hgs
parents:
diff changeset
   227
        
hgs
parents:
diff changeset
   228
        /**
hgs
parents:
diff changeset
   229
         * Draws the child svg in the animation element
hgs
parents:
diff changeset
   230
         * since S60 3.2
hgs
parents:
diff changeset
   231
         * @param GraphicsContext and SVGElement
hgs
parents:
diff changeset
   232
         * @return ETrue if draw is successful else EFalse 
hgs
parents:
diff changeset
   233
         */
hgs
parents:
diff changeset
   234
        TBool DrawL( CGfx2dGc* aGc, CSvgElementImpl* aElement );
hgs
parents:
diff changeset
   235
        
hgs
parents:
diff changeset
   236
        /**
hgs
parents:
diff changeset
   237
         * Sets the initial CTM on animation element
hgs
parents:
diff changeset
   238
         * since S60 3.2
hgs
parents:
diff changeset
   239
         * @param none
hgs
parents:
diff changeset
   240
         * @return none
hgs
parents:
diff changeset
   241
         */
hgs
parents:
diff changeset
   242
        void SetInitialCTM();
hgs
parents:
diff changeset
   243
hgs
parents:
diff changeset
   244
        /**
hgs
parents:
diff changeset
   245
         * Accessor function for obtaining the child SVG document
hgs
parents:
diff changeset
   246
         * @since S60 3.2
hgs
parents:
diff changeset
   247
         * @param none.
hgs
parents:
diff changeset
   248
         * @return CSvgDocumentImpl* Pointer to the document else NULL
hgs
parents:
diff changeset
   249
         */        
hgs
parents:
diff changeset
   250
        CSvgDocumentImpl*                GetChildDocument();
hgs
parents:
diff changeset
   251
        
hgs
parents:
diff changeset
   252
        /**
hgs
parents:
diff changeset
   253
         * 
hgs
parents:
diff changeset
   254
         * since S60 3.2
hgs
parents:
diff changeset
   255
         * @param align variabel to indicate alignment method, aMeetSlice which 
hgs
parents:
diff changeset
   256
                                                is for new viewport.
hgs
parents:
diff changeset
   257
         * @return none
hgs
parents:
diff changeset
   258
         */
hgs
parents:
diff changeset
   259
        void SetPreserveAspectRatioL( TSvgPreserveAspectAlignType aAlign,
hgs
parents:
diff changeset
   260
                                      TSvgMeetOrSliceType aMeetSlice );
hgs
parents:
diff changeset
   261
        
hgs
parents:
diff changeset
   262
        /**
hgs
parents:
diff changeset
   263
         * Sets the width of animation element
hgs
parents:
diff changeset
   264
         * since S60 3.2
hgs
parents:
diff changeset
   265
         * @param aValue a Width attribute value from Svg file
hgs
parents:
diff changeset
   266
         * @return
hgs
parents:
diff changeset
   267
         */
hgs
parents:
diff changeset
   268
        void SetWidth(TReal32 aValue);
hgs
parents:
diff changeset
   269
        
hgs
parents:
diff changeset
   270
        /**
hgs
parents:
diff changeset
   271
         * Sets the height of animation element
hgs
parents:
diff changeset
   272
         * since S60 3.2
hgs
parents:
diff changeset
   273
         * @param aValue a Height attribute value from Svg file
hgs
parents:
diff changeset
   274
         * @return none
hgs
parents:
diff changeset
   275
         */
hgs
parents:
diff changeset
   276
        void SetHeight(TReal32 aValue);
hgs
parents:
diff changeset
   277
       
hgs
parents:
diff changeset
   278
        /**
hgs
parents:
diff changeset
   279
         * prepares child svg document
hgs
parents:
diff changeset
   280
         * since S60 3.2
hgs
parents:
diff changeset
   281
         * @param aFileHandle for child svg
hgs
parents:
diff changeset
   282
         * @return MSvgError object
hgs
parents:
diff changeset
   283
         */
hgs
parents:
diff changeset
   284
        MSvgError* PrepareDomChildSvg( RFile& aFileHandle, TInt& aHandle, TInt aEngine);   
hgs
parents:
diff changeset
   285
        
hgs
parents:
diff changeset
   286
        /**
hgs
parents:
diff changeset
   287
         * prepares child svg document
hgs
parents:
diff changeset
   288
         * @param aFileHandle for child svg
hgs
parents:
diff changeset
   289
         * @return MSvgError object
hgs
parents:
diff changeset
   290
         */
hgs
parents:
diff changeset
   291
        MSvgError* PrepareDomChildSvg (const TDesC& aFileName,TInt& aHandle, TInt aEngine);  
hgs
parents:
diff changeset
   292
        
hgs
parents:
diff changeset
   293
        /**
hgs
parents:
diff changeset
   294
         * prepares child svg document
hgs
parents:
diff changeset
   295
         * since S60 3.2
hgs
parents:
diff changeset
   296
         * @param aFileHandle for child svg
hgs
parents:
diff changeset
   297
         * @return MSvgError object
hgs
parents:
diff changeset
   298
         */
hgs
parents:
diff changeset
   299
        MSvgError* PrepareDomChildSvg(const TDesC8& aByteData, TInt& aHandle, TInt aEngine );  
hgs
parents:
diff changeset
   300
                                              
hgs
parents:
diff changeset
   301
    public: // From CSvgMediaElementBase
hgs
parents:
diff changeset
   302
        /**
hgs
parents:
diff changeset
   303
        * From MSvgTimedEntityInterface
hgs
parents:
diff changeset
   304
        * The parent time container provides the timing clock to 
hgs
parents:
diff changeset
   305
        * the timed entity (audio, video, animation, document) 
hgs
parents:
diff changeset
   306
        * using this routine.
hgs
parents:
diff changeset
   307
        * @since Series 3.2
hgs
parents:
diff changeset
   308
        * @param aTick Current tick information 
hgs
parents:
diff changeset
   309
        * @return none.
hgs
parents:
diff changeset
   310
        */
hgs
parents:
diff changeset
   311
        void ParentTimeContainerTick( TSvgTick aTick );
hgs
parents:
diff changeset
   312
hgs
parents:
diff changeset
   313
        /**
hgs
parents:
diff changeset
   314
        * From MSvgTimedEntityInterface
hgs
parents:
diff changeset
   315
        * When the timed entity acts as timing master in the time container, 
hgs
parents:
diff changeset
   316
        * the time container gets the timed entity clock using this method 
hgs
parents:
diff changeset
   317
        * and feeds to rest of timed entities.
hgs
parents:
diff changeset
   318
        * @since Series 3.2
hgs
parents:
diff changeset
   319
        * @param aEntityCurTime Current Entity Time in msecs. 
hgs
parents:
diff changeset
   320
        * @return none.
hgs
parents:
diff changeset
   321
        */
hgs
parents:
diff changeset
   322
        void GetEntityCurrentTime( TUint32& 
hgs
parents:
diff changeset
   323
            aEntityCurTime );
hgs
parents:
diff changeset
   324
hgs
parents:
diff changeset
   325
        /**
hgs
parents:
diff changeset
   326
        * From MSvgTimedEntityInterface
hgs
parents:
diff changeset
   327
        * If some other element is resolved as syncMaster in the time container group, 
hgs
parents:
diff changeset
   328
        * this element can not act as sync master. 
hgs
parents:
diff changeset
   329
        * @since Series 3.2
hgs
parents:
diff changeset
   330
        * @param aSyncMasterStatus Indicates whether the element is currrently 
hgs
parents:
diff changeset
   331
        *                          Sync Master. 
hgs
parents:
diff changeset
   332
        * @return none.
hgs
parents:
diff changeset
   333
        */
hgs
parents:
diff changeset
   334
        void SetCurSyncMasterStatus( TBool aSyncMasterStatus );
hgs
parents:
diff changeset
   335
hgs
parents:
diff changeset
   336
        /**
hgs
parents:
diff changeset
   337
        * From MSvgTimedEntityInterface
hgs
parents:
diff changeset
   338
        * Check if timed entity can provide timing ticks to rest of time 
hgs
parents:
diff changeset
   339
        * container elements. This behavior could change dynamically. 
hgs
parents:
diff changeset
   340
        * For example, if audio clip is over, the audio element can't generate 
hgs
parents:
diff changeset
   341
        * ticks for others.
hgs
parents:
diff changeset
   342
        * @since Series 3.2
hgs
parents:
diff changeset
   343
        * @param none.
hgs
parents:
diff changeset
   344
        * @return TBool True if can generate timing tick.
hgs
parents:
diff changeset
   345
        */
hgs
parents:
diff changeset
   346
        TBool CanGenerateTick();
hgs
parents:
diff changeset
   347
hgs
parents:
diff changeset
   348
        /**
hgs
parents:
diff changeset
   349
        * From MSvgTimedEntityInterface
hgs
parents:
diff changeset
   350
        * If the timed entity needs to be in sync with the time container and 
hgs
parents:
diff changeset
   351
        * it has slipped beyond the sync tolerance limit, the method is called to 
hgs
parents:
diff changeset
   352
        * bring the element in sync with the time container.
hgs
parents:
diff changeset
   353
        * @since Series 3.2
hgs
parents:
diff changeset
   354
        * @param aSynctime Time for resync in msecs.
hgs
parents:
diff changeset
   355
        * @return none.
hgs
parents:
diff changeset
   356
        */
hgs
parents:
diff changeset
   357
        void ResyncTimedEntity( TUint32 aSynctime );
hgs
parents:
diff changeset
   358
            
hgs
parents:
diff changeset
   359
        /**
hgs
parents:
diff changeset
   360
        * From CSvgMediaElementBase
hgs
parents:
diff changeset
   361
        * This would be used for pausing the timed entity while other locked
hgs
parents:
diff changeset
   362
        * timed entities get loaded.
hgs
parents:
diff changeset
   363
        * @since S60 3.2
hgs
parents:
diff changeset
   364
        * @param none.
hgs
parents:
diff changeset
   365
        * @return none.
hgs
parents:
diff changeset
   366
        */
hgs
parents:
diff changeset
   367
        void PauseTimedEntity();
hgs
parents:
diff changeset
   368
hgs
parents:
diff changeset
   369
        /**
hgs
parents:
diff changeset
   370
        * From CSvgMediaElementBase
hgs
parents:
diff changeset
   371
        * This would be used for resuming the timed entity once all locked
hgs
parents:
diff changeset
   372
        * timed entities get loaded.
hgs
parents:
diff changeset
   373
        * @since S60 3.2
hgs
parents:
diff changeset
   374
        * @param none.
hgs
parents:
diff changeset
   375
        * @return none.
hgs
parents:
diff changeset
   376
        */
hgs
parents:
diff changeset
   377
        void ResumeTimedEntity();    
hgs
parents:
diff changeset
   378
hgs
parents:
diff changeset
   379
        /**
hgs
parents:
diff changeset
   380
        * From CSvgMediaElementBase
hgs
parents:
diff changeset
   381
        * This would be used for stoping the timed entity once all locked
hgs
parents:
diff changeset
   382
        * timed entities get loaded.
hgs
parents:
diff changeset
   383
        * @since S60 3.2
hgs
parents:
diff changeset
   384
        * @param none.
hgs
parents:
diff changeset
   385
        * @return none.
hgs
parents:
diff changeset
   386
        */
hgs
parents:
diff changeset
   387
        void StopTimedEntity();
hgs
parents:
diff changeset
   388
        
hgs
parents:
diff changeset
   389
hgs
parents:
diff changeset
   390
        /*
hgs
parents:
diff changeset
   391
        From MSvgTimedEntityInterface
hgs
parents:
diff changeset
   392
        Would return the type of object
hgs
parents:
diff changeset
   393
        @param none
hgs
parents:
diff changeset
   394
        @return type of object
hgs
parents:
diff changeset
   395
        */
hgs
parents:
diff changeset
   396
        TSvgObjectType ObjectType();
hgs
parents:
diff changeset
   397
        
hgs
parents:
diff changeset
   398
        /*
hgs
parents:
diff changeset
   399
        From MSvgTimedEntityInterface
hgs
parents:
diff changeset
   400
        Return CSvgTimeContainer object
hgs
parents:
diff changeset
   401
        @param none
hgs
parents:
diff changeset
   402
        @return CSvgTimeContainer
hgs
parents:
diff changeset
   403
        */
hgs
parents:
diff changeset
   404
        CSvgTimeContainer* GetChildTimeContainer();
hgs
parents:
diff changeset
   405
        
hgs
parents:
diff changeset
   406
    private: // From MSvgTimeContainerObserver
hgs
parents:
diff changeset
   407
        /**
hgs
parents:
diff changeset
   408
        * From MSvgTimeContainerObserver
hgs
parents:
diff changeset
   409
        * Indicates that all locked elements in child container are ready 
hgs
parents:
diff changeset
   410
        * to render.
hgs
parents:
diff changeset
   411
        * @since S60 3.2
hgs
parents:
diff changeset
   412
        * @param none.
hgs
parents:
diff changeset
   413
        * @return none.
hgs
parents:
diff changeset
   414
        */
hgs
parents:
diff changeset
   415
        void TimeContainerReady();
hgs
parents:
diff changeset
   416
hgs
parents:
diff changeset
   417
        /**
hgs
parents:
diff changeset
   418
        * From MSvgTimeContainerObserver        
hgs
parents:
diff changeset
   419
        * Indicates that at least one locked element in child container 
hgs
parents:
diff changeset
   420
        * is not ready to render.
hgs
parents:
diff changeset
   421
        * @since S60 3.2
hgs
parents:
diff changeset
   422
        * @param none.
hgs
parents:
diff changeset
   423
        * @return none.
hgs
parents:
diff changeset
   424
        */
hgs
parents:
diff changeset
   425
        void TimeContainerNotReady();
hgs
parents:
diff changeset
   426
            
hgs
parents:
diff changeset
   427
        private:
hgs
parents:
diff changeset
   428
        // From CSvgAnimationBase
hgs
parents:
diff changeset
   429
hgs
parents:
diff changeset
   430
        /**
hgs
parents:
diff changeset
   431
        * 
hgs
parents:
diff changeset
   432
        * 
hgs
parents:
diff changeset
   433
        * 
hgs
parents:
diff changeset
   434
        * @since S60 3.2
hgs
parents:
diff changeset
   435
        * @param MSvgTimerEvent.
hgs
parents:
diff changeset
   436
        * @return TBool.
hgs
parents:
diff changeset
   437
        */
hgs
parents:
diff changeset
   438
        virtual TBool AnimProcL( MSvgTimerEvent* aEvent );
hgs
parents:
diff changeset
   439
        
hgs
parents:
diff changeset
   440
        /**
hgs
parents:
diff changeset
   441
        * Creates key times and set animation time according to calcmode
hgs
parents:
diff changeset
   442
        * Sets first begin time, adds target element to event listener
hgs
parents:
diff changeset
   443
        * @since S60 3.2
hgs
parents:
diff changeset
   444
        * @param none.
hgs
parents:
diff changeset
   445
        * @return none.
hgs
parents:
diff changeset
   446
        */
hgs
parents:
diff changeset
   447
        virtual void InitAnimationL();
hgs
parents:
diff changeset
   448
        
hgs
parents:
diff changeset
   449
          /**
hgs
parents:
diff changeset
   450
        * 
hgs
parents:
diff changeset
   451
        * @since S60 3.2
hgs
parents:
diff changeset
   452
        * @param MSvgPreserveAspectRatio.
hgs
parents:
diff changeset
   453
        * @return none.
hgs
parents:
diff changeset
   454
        */
hgs
parents:
diff changeset
   455
        void GetPreserveAspectRatio( MSvgPreserveAspectRatio*& aAspectRatio );
hgs
parents:
diff changeset
   456
hgs
parents:
diff changeset
   457
        /**
hgs
parents:
diff changeset
   458
         * X co-ordinate is returned
hgs
parents:
diff changeset
   459
         *
hgs
parents:
diff changeset
   460
         * since S60 3.2
hgs
parents:
diff changeset
   461
         * @param none
hgs
parents:
diff changeset
   462
         * @return X position of Animation element
hgs
parents:
diff changeset
   463
         */
hgs
parents:
diff changeset
   464
                       
hgs
parents:
diff changeset
   465
        TFloatFixPt                      X();
hgs
parents:
diff changeset
   466
hgs
parents:
diff changeset
   467
hgs
parents:
diff changeset
   468
        /**
hgs
parents:
diff changeset
   469
         * Y co-ordinate is returned
hgs
parents:
diff changeset
   470
         *
hgs
parents:
diff changeset
   471
         * since S60 3.2
hgs
parents:
diff changeset
   472
         * @param none
hgs
parents:
diff changeset
   473
         * @return Y position of Animation element
hgs
parents:
diff changeset
   474
         */
hgs
parents:
diff changeset
   475
        TFloatFixPt                      Y();
hgs
parents:
diff changeset
   476
hgs
parents:
diff changeset
   477
hgs
parents:
diff changeset
   478
        /**
hgs
parents:
diff changeset
   479
         * Width is returned
hgs
parents:
diff changeset
   480
         *
hgs
parents:
diff changeset
   481
         * since S60 3.2
hgs
parents:
diff changeset
   482
         * @param none
hgs
parents:
diff changeset
   483
         * @return Width of Animation element
hgs
parents:
diff changeset
   484
         */
hgs
parents:
diff changeset
   485
        TFloatFixPt                      Width();
hgs
parents:
diff changeset
   486
hgs
parents:
diff changeset
   487
hgs
parents:
diff changeset
   488
        /**
hgs
parents:
diff changeset
   489
         * Height is returned
hgs
parents:
diff changeset
   490
         *
hgs
parents:
diff changeset
   491
         * since S60 3.2
hgs
parents:
diff changeset
   492
         * @param  none
hgs
parents:
diff changeset
   493
         * @return Height of Animation element
hgs
parents:
diff changeset
   494
         */
hgs
parents:
diff changeset
   495
        TFloatFixPt                      Height();
hgs
parents:
diff changeset
   496
        
hgs
parents:
diff changeset
   497
        
hgs
parents:
diff changeset
   498
        /**
hgs
parents:
diff changeset
   499
         * 
hgs
parents:
diff changeset
   500
         *
hgs
parents:
diff changeset
   501
         * since S60 3.2
hgs
parents:
diff changeset
   502
         * @param  TGfxRectangle2D
hgs
parents:
diff changeset
   503
         * @return 
hgs
parents:
diff changeset
   504
         */
hgs
parents:
diff changeset
   505
        void GetBBox( TGfxRectangle2D& aBbox );                              
hgs
parents:
diff changeset
   506
        
hgs
parents:
diff changeset
   507
        /**
hgs
parents:
diff changeset
   508
         * 
hgs
parents:
diff changeset
   509
         *
hgs
parents:
diff changeset
   510
         * since S60 3.2
hgs
parents:
diff changeset
   511
         * @param  TSvgFourPointRect
hgs
parents:
diff changeset
   512
         * @return none
hgs
parents:
diff changeset
   513
         */
hgs
parents:
diff changeset
   514
        void GetFourPointBBox(TSvgFourPointRect& aFourPointBbox);
hgs
parents:
diff changeset
   515
        
hgs
parents:
diff changeset
   516
        
hgs
parents:
diff changeset
   517
        /**
hgs
parents:
diff changeset
   518
         * 
hgs
parents:
diff changeset
   519
         *
hgs
parents:
diff changeset
   520
         * since S60 3.2
hgs
parents:
diff changeset
   521
         * @param  none
hgs
parents:
diff changeset
   522
         * @return 
hgs
parents:
diff changeset
   523
         */
hgs
parents:
diff changeset
   524
        void GetUnscaledBBox( TGfxRectangle2D& aBbox );
hgs
parents:
diff changeset
   525
        
hgs
parents:
diff changeset
   526
        
hgs
parents:
diff changeset
   527
        /**
hgs
parents:
diff changeset
   528
         * Notified when the mouse pointer enters a visible svg element.
hgs
parents:
diff changeset
   529
         *
hgs
parents:
diff changeset
   530
         * since S60 3.2
hgs
parents:
diff changeset
   531
         * param : aElements -- SVG elements containing the mouse point.
hgs
parents:
diff changeset
   532
         * param : aX -- x coordinate of mouse pointer.
hgs
parents:
diff changeset
   533
         * param : aY -- y coordinate of mouse pointer.
hgs
parents:
diff changeset
   534
         * @return : For future use.  Value is ignored.
hgs
parents:
diff changeset
   535
         */
hgs
parents:
diff changeset
   536
        virtual TBool MouseEntered( RPointerArray<CSvgElementImpl>& aElements,
hgs
parents:
diff changeset
   537
                                    TInt aX, TInt aY );
hgs
parents:
diff changeset
   538
        
hgs
parents:
diff changeset
   539
         /**
hgs
parents:
diff changeset
   540
         * Notified when the mouse pointer exits a visible svg element.
hgs
parents:
diff changeset
   541
         *
hgs
parents:
diff changeset
   542
         * since S60 3.2
hgs
parents:
diff changeset
   543
         * param : aElements -- SVG elements containing the mouse point.
hgs
parents:
diff changeset
   544
         * param : aX -- x coordinate of mouse pointer.
hgs
parents:
diff changeset
   545
         * param : aY -- y coordinate of mouse pointer.
hgs
parents:
diff changeset
   546
         * @return : For future use.  Value is ignored.
hgs
parents:
diff changeset
   547
         */                        
hgs
parents:
diff changeset
   548
        virtual TBool MouseExited( RPointerArray<CSvgElementImpl>& aElements,
hgs
parents:
diff changeset
   549
                                   TInt aX, TInt aY );
hgs
parents:
diff changeset
   550
        
hgs
parents:
diff changeset
   551
        
hgs
parents:
diff changeset
   552
         /**
hgs
parents:
diff changeset
   553
         * Notified when the mouse pointer has already entered a visible
hgs
parents:
diff changeset
   554
         * svg element and just moved but remains inside its bounding-box.
hgs
parents:
diff changeset
   555
         *
hgs
parents:
diff changeset
   556
         * since S60 3.2
hgs
parents:
diff changeset
   557
         * param : aElements -- SVG elements containing the mouse point.
hgs
parents:
diff changeset
   558
         * param : aX -- x coordinate of mouse pointer.
hgs
parents:
diff changeset
   559
         * param : aY -- y coordinate of mouse pointer.
hgs
parents:
diff changeset
   560
         * @return : For future use.  Value is ignored.
hgs
parents:
diff changeset
   561
         */                      
hgs
parents:
diff changeset
   562
        virtual TBool MouseMoved( RPointerArray<CSvgElementImpl>& aElements,
hgs
parents:
diff changeset
   563
                                   TInt aX, TInt aY );
hgs
parents:
diff changeset
   564
                                   
hgs
parents:
diff changeset
   565
        /**
hgs
parents:
diff changeset
   566
         * Notified when the mouse pointer is pressed down on visible svg element.
hgs
parents:
diff changeset
   567
         *
hgs
parents:
diff changeset
   568
         * since S60 3.2
hgs
parents:
diff changeset
   569
         * param : aElements -- SVG elements containing the mouse point.
hgs
parents:
diff changeset
   570
         * param : aX -- x coordinate of mouse pointer.
hgs
parents:
diff changeset
   571
         * param : aY -- y coordinate of mouse pointer.
hgs
parents:
diff changeset
   572
         * @return : For future use.  Value is ignored.
hgs
parents:
diff changeset
   573
         */                       
hgs
parents:
diff changeset
   574
        virtual TBool MousePressed( RPointerArray<CSvgElementImpl>& aElements,
hgs
parents:
diff changeset
   575
                                   TInt aX, TInt aY );
hgs
parents:
diff changeset
   576
                                   
hgs
parents:
diff changeset
   577
        /**
hgs
parents:
diff changeset
   578
         * Notified when the mouse pointer is released on on visible svg element.
hgs
parents:
diff changeset
   579
         *
hgs
parents:
diff changeset
   580
         * since S60 3.2
hgs
parents:
diff changeset
   581
         * param : aElements -- SVG elements containing the mouse point.
hgs
parents:
diff changeset
   582
         * param : aX -- x coordinate of mouse pointer.
hgs
parents:
diff changeset
   583
         * param : aY -- y coordinate of mouse pointer.
hgs
parents:
diff changeset
   584
         * @return : For future use.  Value is ignored.
hgs
parents:
diff changeset
   585
         */                           
hgs
parents:
diff changeset
   586
        virtual TBool MouseReleased( RPointerArray<CSvgElementImpl>& aElements,
hgs
parents:
diff changeset
   587
                                   TInt aX, TInt aY );                                                                                                              
hgs
parents:
diff changeset
   588
        
hgs
parents:
diff changeset
   589
        
hgs
parents:
diff changeset
   590
        /**
hgs
parents:
diff changeset
   591
         * updates the CTM
hgs
parents:
diff changeset
   592
         *
hgs
parents:
diff changeset
   593
         * since S60 3.2
hgs
parents:
diff changeset
   594
         * @param  none
hgs
parents:
diff changeset
   595
         * @return none
hgs
parents:
diff changeset
   596
         */                           
hgs
parents:
diff changeset
   597
        virtual void   UpdateCTM();
hgs
parents:
diff changeset
   598
        
hgs
parents:
diff changeset
   599
        
hgs
parents:
diff changeset
   600
        /**
hgs
parents:
diff changeset
   601
         * 
hgs
parents:
diff changeset
   602
         *
hgs
parents:
diff changeset
   603
         * since S60 3.2
hgs
parents:
diff changeset
   604
         * @param  none
hgs
parents:
diff changeset
   605
         * @return none
hgs
parents:
diff changeset
   606
         */
hgs
parents:
diff changeset
   607
        void DeactivateAnimation(); 
hgs
parents:
diff changeset
   608
        
hgs
parents:
diff changeset
   609
      protected:  
hgs
parents:
diff changeset
   610
      
hgs
parents:
diff changeset
   611
         /**
hgs
parents:
diff changeset
   612
         * does a deep copy of mediaanimation element
hgs
parents:
diff changeset
   613
         *
hgs
parents:
diff changeset
   614
         * since S60 3.2
hgs
parents:
diff changeset
   615
         * @param  CSvgMediaAnimationElementImpl element
hgs
parents:
diff changeset
   616
         * @return none
hgs
parents:
diff changeset
   617
         */
hgs
parents:
diff changeset
   618
       void                            CopyL( CSvgMediaAnimationElementImpl* aDestElement );
hgs
parents:
diff changeset
   619
      private:
hgs
parents:
diff changeset
   620
        // DRM related
hgs
parents:
diff changeset
   621
        TBool                               iDrmEnabled;
hgs
parents:
diff changeset
   622
hgs
parents:
diff changeset
   623
        // Thumbnail mode
hgs
parents:
diff changeset
   624
        TBool                               iIsThumbNailMode;
hgs
parents:
diff changeset
   625
hgs
parents:
diff changeset
   626
        // MSvgLoadingListener list
hgs
parents:
diff changeset
   627
        RPointerArray<MSvgLoadingListener>  iSvgLoadingListeners;
hgs
parents:
diff changeset
   628
hgs
parents:
diff changeset
   629
        // Keep track of elements currently having mouse pointer inside
hgs
parents:
diff changeset
   630
        // to report mouse-exit when it is moved.
hgs
parents:
diff changeset
   631
        RPointerArray<CSvgElementImpl>      iSvgMouseEnteredElements;
hgs
parents:
diff changeset
   632
hgs
parents:
diff changeset
   633
        // Flag to indicate Load or PrepareDom call.
hgs
parents:
diff changeset
   634
        TBool                               iIsLoadingRequest;
hgs
parents:
diff changeset
   635
hgs
parents:
diff changeset
   636
		TBool                               iMouseDownFlag;                                        
hgs
parents:
diff changeset
   637
        
hgs
parents:
diff changeset
   638
        TBool                               iFileIsLoaded;   //checks for parsing error                                   
hgs
parents:
diff changeset
   639
                                           
hgs
parents:
diff changeset
   640
         
hgs
parents:
diff changeset
   641
                                              
hgs
parents:
diff changeset
   642
        TFloatFixPt                     iScale;
hgs
parents:
diff changeset
   643
        CSvgFitToViewBoxImpl*           iViewBoxImpl;   
hgs
parents:
diff changeset
   644
        TFloatFixPt                     iX;
hgs
parents:
diff changeset
   645
        TFloatFixPt                     iY;
hgs
parents:
diff changeset
   646
        TBool iIsFocusable;        // To be implemented
hgs
parents:
diff changeset
   647
       // TBool iInitialVisibility;  // InitialVisibility of the Animatin element
hgs
parents:
diff changeset
   648
        // Referenced (target) element
hgs
parents:
diff changeset
   649
        CSvgElementImpl* iReferencedElement;
hgs
parents:
diff changeset
   650
        
hgs
parents:
diff changeset
   651
        
hgs
parents:
diff changeset
   652
        CSvgErrorImpl* iSvgError;   // error object
hgs
parents:
diff changeset
   653
        CSvgDocumentImpl* iNewDocument; // Document pointer for child svg
hgs
parents:
diff changeset
   654
        TGfxAffineTransform iOriginalRootTr; // For Transform
hgs
parents:
diff changeset
   655
        TBool iIsOriginalRootTrSet;          
hgs
parents:
diff changeset
   656
        TFloatFixPt                      iWidth;  
hgs
parents:
diff changeset
   657
        TFloatFixPt                      iHeight;
hgs
parents:
diff changeset
   658
        
hgs
parents:
diff changeset
   659
        enum TAnimationState        // State of animation element
hgs
parents:
diff changeset
   660
    	{
hgs
parents:
diff changeset
   661
    		EPlayerStateIdle,
hgs
parents:
diff changeset
   662
    		EPlayerStatePlaying,
hgs
parents:
diff changeset
   663
    		EPlayerStatePaused,
hgs
parents:
diff changeset
   664
    		EPlayerStateStop,
hgs
parents:
diff changeset
   665
    		EPlayerProhibit
hgs
parents:
diff changeset
   666
    	};
hgs
parents:
diff changeset
   667
    	
hgs
parents:
diff changeset
   668
        TAnimationState iAnimationStatus;
hgs
parents:
diff changeset
   669
        
hgs
parents:
diff changeset
   670
        enum TAnimationVisible        // Visibility State of animation element
hgs
parents:
diff changeset
   671
    	{
hgs
parents:
diff changeset
   672
    		EAnimationNotVisible,
hgs
parents:
diff changeset
   673
    		EAnimationInitialised,
hgs
parents:
diff changeset
   674
    		EAnimationVisible
hgs
parents:
diff changeset
   675
    	};
hgs
parents:
diff changeset
   676
    	
hgs
parents:
diff changeset
   677
        TAnimationVisible iInitialVisibility;
hgs
parents:
diff changeset
   678
        // Save the tick at the time animation starts
hgs
parents:
diff changeset
   679
        TSvgTick iBeginTick;
hgs
parents:
diff changeset
   680
        // Indicates whether time container issued a pause command
hgs
parents:
diff changeset
   681
        TBool iIsSyncPauseIssued;      
hgs
parents:
diff changeset
   682
        TBool iDurMediaTime;   // if duration is media
hgs
parents:
diff changeset
   683
        HBufC*  iChildSvgName ;        
hgs
parents:
diff changeset
   684
      	
hgs
parents:
diff changeset
   685
        
hgs
parents:
diff changeset
   686
    };
hgs
parents:
diff changeset
   687
hgs
parents:
diff changeset
   688
#endif // C_SVGMediaAnimationElementImpl_H