svgtopt/SVG/SVGEngine/src/SVGTimer.cpp
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) 2003 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:  SVG Engine source file
hgs
parents:
diff changeset
    15
 *
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#include "SVGTimer.h"
hgs
parents:
diff changeset
    20
#include "SVGEngineImpl.h"
hgs
parents:
diff changeset
    21
#include "GfxAffineTransform.h"
hgs
parents:
diff changeset
    22
#include "GfxPoint2D.h"
hgs
parents:
diff changeset
    23
#include "SVGTimeContainer.h"
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    26
// Two phase constructor
hgs
parents:
diff changeset
    27
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    28
CSvgTimer* CSvgTimer::NewLC( CSvgTimeContainer* aTimeContainer )
hgs
parents:
diff changeset
    29
    {
hgs
parents:
diff changeset
    30
    CSvgTimer* self = new ( ELeave ) CSvgTimer( aTimeContainer );
hgs
parents:
diff changeset
    31
    CleanupStack::PushL( self );
hgs
parents:
diff changeset
    32
    self->ConstructL();
hgs
parents:
diff changeset
    33
    return self;
hgs
parents:
diff changeset
    34
    }
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
//
hgs
parents:
diff changeset
    37
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    38
// Two phase constructor
hgs
parents:
diff changeset
    39
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    40
CSvgTimer* CSvgTimer::NewL( CSvgTimeContainer* aTimeContainer )
hgs
parents:
diff changeset
    41
    {
hgs
parents:
diff changeset
    42
    CSvgTimer* self = NewLC( aTimeContainer );
hgs
parents:
diff changeset
    43
    CleanupStack::Pop();
hgs
parents:
diff changeset
    44
    return self;
hgs
parents:
diff changeset
    45
    }
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    48
// Private method that builds the heap objects or performs leavable actions
hgs
parents:
diff changeset
    49
// during object construction
hgs
parents:
diff changeset
    50
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    51
void CSvgTimer::ConstructL()
hgs
parents:
diff changeset
    52
    {
hgs
parents:
diff changeset
    53
    // Call the base class ConstructL
hgs
parents:
diff changeset
    54
    CTimer::ConstructL();
hgs
parents:
diff changeset
    55
    // Add to active scheduler
hgs
parents:
diff changeset
    56
    CActiveScheduler::Add( this );
hgs
parents:
diff changeset
    57
    }
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
//
hgs
parents:
diff changeset
    60
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    61
// Constructor
hgs
parents:
diff changeset
    62
// Initialized with a pointer to the time container
hgs
parents:
diff changeset
    63
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    64
CSvgTimer::CSvgTimer( CSvgTimeContainer* aTimeContainer ) : 
hgs
parents:
diff changeset
    65
    CTimer( CActive::EPriorityStandard ),
hgs
parents:
diff changeset
    66
    iTimeContainer( aTimeContainer )
hgs
parents:
diff changeset
    67
    {
hgs
parents:
diff changeset
    68
    ChangeFrameDuration( KMinFrameDelay );
hgs
parents:
diff changeset
    69
    SetStrictFrameDuration( EFalse );
hgs
parents:
diff changeset
    70
    ResetTime();
hgs
parents:
diff changeset
    71
    }
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
//
hgs
parents:
diff changeset
    74
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    75
// Destructor
hgs
parents:
diff changeset
    76
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    77
CSvgTimer::~CSvgTimer()
hgs
parents:
diff changeset
    78
    {
hgs
parents:
diff changeset
    79
    Cancel();
hgs
parents:
diff changeset
    80
    }
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    83
// Reset the time
hgs
parents:
diff changeset
    84
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    85
void CSvgTimer::ResetTime()
hgs
parents:
diff changeset
    86
    {
hgs
parents:
diff changeset
    87
    iTime = 0;
hgs
parents:
diff changeset
    88
    iFrames = 0;
hgs
parents:
diff changeset
    89
    iFirstFrameDrawn = EFalse;
hgs
parents:
diff changeset
    90
    }
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    93
// Change the duration of the timer in milliseconds
hgs
parents:
diff changeset
    94
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    95
void CSvgTimer::ChangeFrameDuration( TUint32 aFrameDuration )
hgs
parents:
diff changeset
    96
    {
hgs
parents:
diff changeset
    97
    // If delay duration is less then minimum-delay, set to minimum-delay
hgs
parents:
diff changeset
    98
    if ( aFrameDuration < KMinFrameDelay )
hgs
parents:
diff changeset
    99
        {
hgs
parents:
diff changeset
   100
        aFrameDuration =  KMinFrameDelay;
hgs
parents:
diff changeset
   101
        }
hgs
parents:
diff changeset
   102
    iFrameDuration = aFrameDuration;
hgs
parents:
diff changeset
   103
    }
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   106
// Return the frames per 10-seconds
hgs
parents:
diff changeset
   107
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   108
TUint CSvgTimer::Fps()
hgs
parents:
diff changeset
   109
    {
hgs
parents:
diff changeset
   110
	if ( iTime == 0 )
hgs
parents:
diff changeset
   111
		{
hgs
parents:
diff changeset
   112
		return 0;
hgs
parents:
diff changeset
   113
		}
hgs
parents:
diff changeset
   114
	// iTime is in milliseconds
hgs
parents:
diff changeset
   115
	return ( 10000 * iFrames ) / iTime ;
hgs
parents:
diff changeset
   116
    }
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
hgs
parents:
diff changeset
   119
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   120
// Standard Active Object DoCancel
hgs
parents:
diff changeset
   121
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   122
void CSvgTimer::DoCancel()
hgs
parents:
diff changeset
   123
    {
hgs
parents:
diff changeset
   124
    CTimer::DoCancel();
hgs
parents:
diff changeset
   125
    }
hgs
parents:
diff changeset
   126
hgs
parents:
diff changeset
   127
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   128
// Standard Active Object RunL
hgs
parents:
diff changeset
   129
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   130
void CSvgTimer::RunL()
hgs
parents:
diff changeset
   131
    {
hgs
parents:
diff changeset
   132
    // Check if timed entity not null
hgs
parents:
diff changeset
   133
    if ( !iTimeContainer )
hgs
parents:
diff changeset
   134
        {
hgs
parents:
diff changeset
   135
        return;
hgs
parents:
diff changeset
   136
        }
hgs
parents:
diff changeset
   137
    
hgs
parents:
diff changeset
   138
#if 0    
hgs
parents:
diff changeset
   139
    // Check engine and document
hgs
parents:
diff changeset
   140
    if ( !iSvgEngine || !iSvgEngine->Document() )
hgs
parents:
diff changeset
   141
        {
hgs
parents:
diff changeset
   142
        return;
hgs
parents:
diff changeset
   143
        }
hgs
parents:
diff changeset
   144
hgs
parents:
diff changeset
   145
	// wait for images to finish decoding
hgs
parents:
diff changeset
   146
    if ( !iSvgEngine->ReadyToRender() )
hgs
parents:
diff changeset
   147
    	{
hgs
parents:
diff changeset
   148
        CActive::Deque();
hgs
parents:
diff changeset
   149
        CActiveScheduler::Add( this );
hgs
parents:
diff changeset
   150
        CTimer::After( 10 * 1000 );
hgs
parents:
diff changeset
   151
        return;
hgs
parents:
diff changeset
   152
		}
hgs
parents:
diff changeset
   153
#endif
hgs
parents:
diff changeset
   154
    /********************** Generate first frame ********************/
hgs
parents:
diff changeset
   155
    if ( !iFirstFrameDrawn )
hgs
parents:
diff changeset
   156
    	{
hgs
parents:
diff changeset
   157
        iFirstFrameDrawn = ETrue;
hgs
parents:
diff changeset
   158
    	}
hgs
parents:
diff changeset
   159
	else
hgs
parents:
diff changeset
   160
		{
hgs
parents:
diff changeset
   161
		/********************** After first frame ********************/
hgs
parents:
diff changeset
   162
		TTime currentTime;
hgs
parents:
diff changeset
   163
		currentTime.HomeTime();
hgs
parents:
diff changeset
   164
		TUint32 elapsedTime = GetElapsedMilliseconds( iPreviousFrameTime, currentTime );
hgs
parents:
diff changeset
   165
hgs
parents:
diff changeset
   166
		// Cap elapsed time, if needed
hgs
parents:
diff changeset
   167
		if ( iIsStrictFrameDuration &&
hgs
parents:
diff changeset
   168
			 elapsedTime > iFrameDuration )
hgs
parents:
diff changeset
   169
			{
hgs
parents:
diff changeset
   170
			elapsedTime = iFrameDuration;
hgs
parents:
diff changeset
   171
			}
hgs
parents:
diff changeset
   172
hgs
parents:
diff changeset
   173
		// Generate frame
hgs
parents:
diff changeset
   174
		iTime += elapsedTime;
hgs
parents:
diff changeset
   175
		}
hgs
parents:
diff changeset
   176
hgs
parents:
diff changeset
   177
    // Mark time of new frame
hgs
parents:
diff changeset
   178
    iPreviousFrameTime.HomeTime();
hgs
parents:
diff changeset
   179
hgs
parents:
diff changeset
   180
    // Generate new frame
hgs
parents:
diff changeset
   181
    TUint32 sleepTime = GenerateFrameL( iTime );
hgs
parents:
diff changeset
   182
hgs
parents:
diff changeset
   183
		// Sleep to next frame
hgs
parents:
diff changeset
   184
	if ( 
hgs
parents:
diff changeset
   185
	( iTimeContainer->Document()->Engine()->SVGEngineState() == ESVGEngineRunning ) 
hgs
parents:
diff changeset
   186
	&& ( iTimeContainer->GetCurTick().iParentTcTick < iTimeContainer->Document()->AnimationDuration() ) 
hgs
parents:
diff changeset
   187
	)
hgs
parents:
diff changeset
   188
	
hgs
parents:
diff changeset
   189
		{
hgs
parents:
diff changeset
   190
        // Dequeue to move this ActiveObject to the end of the list
hgs
parents:
diff changeset
   191
        // to share processor with other AOs.
hgs
parents:
diff changeset
   192
		CActive::Deque();
hgs
parents:
diff changeset
   193
		CActiveScheduler::Add( this );
hgs
parents:
diff changeset
   194
		CTimer::After( 1000 * sleepTime );
hgs
parents:
diff changeset
   195
		}
hgs
parents:
diff changeset
   196
    }
hgs
parents:
diff changeset
   197
hgs
parents:
diff changeset
   198
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   199
// void CSvgTimer::SVGStop()
hgs
parents:
diff changeset
   200
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   201
void CSvgTimer::SVGStop()
hgs
parents:
diff changeset
   202
    {
hgs
parents:
diff changeset
   203
    if ( IsActive() )
hgs
parents:
diff changeset
   204
        {
hgs
parents:
diff changeset
   205
        Cancel(); // stop current timer
hgs
parents:
diff changeset
   206
        }
hgs
parents:
diff changeset
   207
    iFirstFrameDrawn = EFalse;
hgs
parents:
diff changeset
   208
    }
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   211
// void CSvgTimer::SVGResume()
hgs
parents:
diff changeset
   212
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   213
void CSvgTimer::SVGResume( TInt32 aTime )
hgs
parents:
diff changeset
   214
    {
hgs
parents:
diff changeset
   215
    if ( !IsActive() )
hgs
parents:
diff changeset
   216
        {
hgs
parents:
diff changeset
   217
        if ( aTime < 0 )
hgs
parents:
diff changeset
   218
            {
hgs
parents:
diff changeset
   219
            // Error, ( negative time ) set to default
hgs
parents:
diff changeset
   220
            aTime = 1000;
hgs
parents:
diff changeset
   221
            }
hgs
parents:
diff changeset
   222
            
hgs
parents:
diff changeset
   223
        CTimer::After( aTime ); // invoke initial timer event
hgs
parents:
diff changeset
   224
        }
hgs
parents:
diff changeset
   225
    }
hgs
parents:
diff changeset
   226
hgs
parents:
diff changeset
   227
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   228
// void CSvgTimer::SetStartTime()
hgs
parents:
diff changeset
   229
// Reset animation time to zero
hgs
parents:
diff changeset
   230
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   231
void CSvgTimer::SetStartTime()
hgs
parents:
diff changeset
   232
    {
hgs
parents:
diff changeset
   233
    SetSeekTime( 0 );
hgs
parents:
diff changeset
   234
    }
hgs
parents:
diff changeset
   235
hgs
parents:
diff changeset
   236
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   237
// void CSvgTimer::SetSeekTime( TUint32 aTime )
hgs
parents:
diff changeset
   238
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   239
void CSvgTimer::SetSeekTime( TUint32 aTime )
hgs
parents:
diff changeset
   240
    {
hgs
parents:
diff changeset
   241
    // update the current time.
hgs
parents:
diff changeset
   242
    iFirstFrameDrawn = EFalse;
hgs
parents:
diff changeset
   243
#if 0
hgs
parents:
diff changeset
   244
    // the current home time needs to be updated.
hgs
parents:
diff changeset
   245
    if ( iSvgEngine && iSvgEngine->Document() && aTime != iTime )
hgs
parents:
diff changeset
   246
        {
hgs
parents:
diff changeset
   247
        TSvgTimerEvent timeEvent( aTime );
hgs
parents:
diff changeset
   248
        iSvgEngine->Document()->Reset( &timeEvent );
hgs
parents:
diff changeset
   249
        }
hgs
parents:
diff changeset
   250
#endif
hgs
parents:
diff changeset
   251
    iTime = aTime;
hgs
parents:
diff changeset
   252
hgs
parents:
diff changeset
   253
     if ( !IsActive() )
hgs
parents:
diff changeset
   254
        {
hgs
parents:
diff changeset
   255
        CTimer::After( 1000 );
hgs
parents:
diff changeset
   256
        }
hgs
parents:
diff changeset
   257
hgs
parents:
diff changeset
   258
    }
hgs
parents:
diff changeset
   259
hgs
parents:
diff changeset
   260
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   261
// void CSvgTimer::SetStrictFrameDuration( TBool aKeepStrictFrameDuration )
hgs
parents:
diff changeset
   262
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   263
void CSvgTimer::SetStrictFrameDuration( TBool aKeepStrictFrameDuration )
hgs
parents:
diff changeset
   264
    {
hgs
parents:
diff changeset
   265
    iIsStrictFrameDuration = aKeepStrictFrameDuration;
hgs
parents:
diff changeset
   266
    }
hgs
parents:
diff changeset
   267
hgs
parents:
diff changeset
   268
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   269
// TUint32 CSvgTimer::GenerateFrameL( TUint32 aTime )
hgs
parents:
diff changeset
   270
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   271
TUint32 CSvgTimer::GenerateFrameL( TUint32 aTime )
hgs
parents:
diff changeset
   272
    {
hgs
parents:
diff changeset
   273
    TTime startTime;
hgs
parents:
diff changeset
   274
    startTime.HomeTime();
hgs
parents:
diff changeset
   275
    TSvgTick lTick;
hgs
parents:
diff changeset
   276
    lTick.iRealTimeTick = aTime;
hgs
parents:
diff changeset
   277
    lTick.iParentTcTick = 0;
hgs
parents:
diff changeset
   278
    
hgs
parents:
diff changeset
   279
    iTimeContainer->ParentTimeContainerTick( lTick );
hgs
parents:
diff changeset
   280
    
hgs
parents:
diff changeset
   281
#if 0
hgs
parents:
diff changeset
   282
    // Request to drawn frame at given time
hgs
parents:
diff changeset
   283
    TSvgTimerEvent timeEvent( aTime );
hgs
parents:
diff changeset
   284
    iSvgEngine->ProcessEventL( iSvgEngine->Document(), &timeEvent );
hgs
parents:
diff changeset
   285
#endif
hgs
parents:
diff changeset
   286
    TTime endTime;
hgs
parents:
diff changeset
   287
    endTime.HomeTime();
hgs
parents:
diff changeset
   288
hgs
parents:
diff changeset
   289
    TUint32 elapsedTime = GetElapsedMilliseconds( startTime, endTime );
hgs
parents:
diff changeset
   290
hgs
parents:
diff changeset
   291
    // Calculate sleep time to next frame
hgs
parents:
diff changeset
   292
    TUint32 sleepTime = KMinSleepDuration;
hgs
parents:
diff changeset
   293
    if ( elapsedTime < iFrameDuration )
hgs
parents:
diff changeset
   294
        {
hgs
parents:
diff changeset
   295
        sleepTime = iFrameDuration - elapsedTime;
hgs
parents:
diff changeset
   296
        if ( sleepTime < KMinSleepDuration )
hgs
parents:
diff changeset
   297
            {
hgs
parents:
diff changeset
   298
            sleepTime = KMinSleepDuration;
hgs
parents:
diff changeset
   299
            }
hgs
parents:
diff changeset
   300
        }
hgs
parents:
diff changeset
   301
hgs
parents:
diff changeset
   302
	iFrames++;
hgs
parents:
diff changeset
   303
    return sleepTime;
hgs
parents:
diff changeset
   304
    }
hgs
parents:
diff changeset
   305
hgs
parents:
diff changeset
   306
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   307
// TUint32 CSvgTimer::GetElapsedMilliseconds( TTime& aStart, TTime& aEnd )
hgs
parents:
diff changeset
   308
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   309
TUint32 CSvgTimer::GetElapsedMilliseconds( TTime& aStart, TTime& aEnd )
hgs
parents:
diff changeset
   310
    {
hgs
parents:
diff changeset
   311
    TTimeIntervalMicroSeconds interval64 = aEnd.MicroSecondsFrom( aStart );
hgs
parents:
diff changeset
   312
    // in milliseconds
hgs
parents:
diff changeset
   313
    return I64INT( interval64.Int64() ) / 1000;
hgs
parents:
diff changeset
   314
    }