tsrc/consoleplayer/thumbnail/src/thumbnailtester.cpp
author hgs
Fri, 03 Sep 2010 19:37:02 -0500
changeset 33 e1b6d78dfe6a
permissions -rw-r--r--
201035
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
 * Copyright (c) 2010 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:
hgs
parents:
diff changeset
    15
 * Source file for the main class of the Thumbnail Tester test app.
hgs
parents:
diff changeset
    16
 * 
hgs
parents:
diff changeset
    17
 */
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#include "thumbnailtester.h"
hgs
parents:
diff changeset
    20
#include "yuv2rgb24.h"
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include <e32base.h>
hgs
parents:
diff changeset
    23
#include <e32debug.h>
hgs
parents:
diff changeset
    24
#include <f32file.h>
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
const TInt KFontSize = 15;
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
// Thumbnail tester implementation
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
void CThumbnailTester::ExecuteL()
hgs
parents:
diff changeset
    31
    {
hgs
parents:
diff changeset
    32
    CThumbnailTester* self = new(ELeave) CThumbnailTester;
hgs
parents:
diff changeset
    33
    CleanupStack::PushL( self );
hgs
parents:
diff changeset
    34
    self->InitL();
hgs
parents:
diff changeset
    35
    self->Main();
hgs
parents:
diff changeset
    36
    CleanupStack::PopAndDestroy( self );    
hgs
parents:
diff changeset
    37
    }
hgs
parents:
diff changeset
    38
    
hgs
parents:
diff changeset
    39
CThumbnailTester::CThumbnailTester() : 
hgs
parents:
diff changeset
    40
    CTestAppBase( KFontSize )
hgs
parents:
diff changeset
    41
    {    
hgs
parents:
diff changeset
    42
    }
hgs
parents:
diff changeset
    43
    
hgs
parents:
diff changeset
    44
CThumbnailTester::~CThumbnailTester()
hgs
parents:
diff changeset
    45
    {
hgs
parents:
diff changeset
    46
    Cancel();
hgs
parents:
diff changeset
    47
    
hgs
parents:
diff changeset
    48
    if( iGc && iFullScreenWindow )
hgs
parents:
diff changeset
    49
	      {
hgs
parents:
diff changeset
    50
        iGc->Activate(*iFullScreenWindow);
hgs
parents:
diff changeset
    51
        
hgs
parents:
diff changeset
    52
        iFullScreenWindow->Invalidate();
hgs
parents:
diff changeset
    53
        iFullScreenWindow->BeginRedraw();
hgs
parents:
diff changeset
    54
        
hgs
parents:
diff changeset
    55
        iGc->Reset();
hgs
parents:
diff changeset
    56
        
hgs
parents:
diff changeset
    57
        iGc->UseFont(iFont);                
hgs
parents:
diff changeset
    58
        iGc->SetBrushColor(KRgbDarkBlue);
hgs
parents:
diff changeset
    59
        
hgs
parents:
diff changeset
    60
        iGc->Clear();
hgs
parents:
diff changeset
    61
hgs
parents:
diff changeset
    62
        if( iFinalResult == KErrNone )
hgs
parents:
diff changeset
    63
            {
hgs
parents:
diff changeset
    64
            // KRgbWhite seems to be having problems (0xffffff) in some emulators,
hgs
parents:
diff changeset
    65
            // but 0xfefefe is working, so use that instead of white.        
hgs
parents:
diff changeset
    66
            iGc->SetPenColor(0xfefefe);                 
hgs
parents:
diff changeset
    67
            }
hgs
parents:
diff changeset
    68
        else
hgs
parents:
diff changeset
    69
            {
hgs
parents:
diff changeset
    70
            iGc->SetPenColor(KRgbRed);
hgs
parents:
diff changeset
    71
            }
hgs
parents:
diff changeset
    72
    
hgs
parents:
diff changeset
    73
        iBuffer.Format( _L("THUMBNAILTESTER EXIT, result = %i"), iFinalResult );
hgs
parents:
diff changeset
    74
        iGc->DrawText( iBuffer, TPoint(5, 20) );
hgs
parents:
diff changeset
    75
       
hgs
parents:
diff changeset
    76
        iFullScreenWindow->EndRedraw();
hgs
parents:
diff changeset
    77
        
hgs
parents:
diff changeset
    78
        iGc->Deactivate();
hgs
parents:
diff changeset
    79
        
hgs
parents:
diff changeset
    80
        iFullScreenWindow->SetVisible( ETrue );
hgs
parents:
diff changeset
    81
        
hgs
parents:
diff changeset
    82
        WaitForAnyKey();
hgs
parents:
diff changeset
    83
        }    
hgs
parents:
diff changeset
    84
    
hgs
parents:
diff changeset
    85
    }
hgs
parents:
diff changeset
    86
    
hgs
parents:
diff changeset
    87
void CThumbnailTester::InitL()
hgs
parents:
diff changeset
    88
    {
hgs
parents:
diff changeset
    89
    BaseConstructL( NULL, 0 );  // this app doesn't use the option pages concept
hgs
parents:
diff changeset
    90
    
hgs
parents:
diff changeset
    91
    iFullScreenWindow = new(ELeave) RWindow( iWs );
hgs
parents:
diff changeset
    92
    User::LeaveIfError( iFullScreenWindow->Construct( *iWindowGroup, KNullWsHandle ) );
hgs
parents:
diff changeset
    93
    iFullScreenWindow->SetExtent( TPoint(0,0), iDisplaySize );
hgs
parents:
diff changeset
    94
    iFullScreenWindow->SetNonTransparent();
hgs
parents:
diff changeset
    95
    iFullScreenWindow->SetBackgroundColor(KRgbBlack);
hgs
parents:
diff changeset
    96
    iFullScreenWindow->SetVisible(false);
hgs
parents:
diff changeset
    97
    iFullScreenWindow->Activate();
hgs
parents:
diff changeset
    98
        
hgs
parents:
diff changeset
    99
    iGc->Activate(*iFullScreenWindow);
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
    iFullScreenWindow->BeginRedraw();
hgs
parents:
diff changeset
   102
    
hgs
parents:
diff changeset
   103
    iGc->Reset();    
hgs
parents:
diff changeset
   104
    iGc->UseFont(iFont);                
hgs
parents:
diff changeset
   105
    iGc->SetBrushStyle(CWindowGc::ESolidBrush);
hgs
parents:
diff changeset
   106
    iGc->SetBrushColor(KRgbBlack);    
hgs
parents:
diff changeset
   107
    iGc->Clear();
hgs
parents:
diff changeset
   108
    
hgs
parents:
diff changeset
   109
    iFullScreenWindow->EndRedraw();
hgs
parents:
diff changeset
   110
    
hgs
parents:
diff changeset
   111
    iGc->Deactivate();    
hgs
parents:
diff changeset
   112
    }
hgs
parents:
diff changeset
   113
hgs
parents:
diff changeset
   114
void CThumbnailTester::Main()
hgs
parents:
diff changeset
   115
    {    
hgs
parents:
diff changeset
   116
    TRAPD( err, MainL() ); 
hgs
parents:
diff changeset
   117
    
hgs
parents:
diff changeset
   118
    RDebug::Printf( "THUMBNAILTESTER Completed, err=%i", err );    
hgs
parents:
diff changeset
   119
    }
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
void CThumbnailTester::MainL()        
hgs
parents:
diff changeset
   122
    {
hgs
parents:
diff changeset
   123
    TFileName filename;
hgs
parents:
diff changeset
   124
    
hgs
parents:
diff changeset
   125
    SelectFileWithHistoryL( TPoint(0,0), iDisplaySize, filename, KHistoryFilename, KMaxHistoryEntries );
hgs
parents:
diff changeset
   126
    
hgs
parents:
diff changeset
   127
    GenerateThumbnailL( filename );
hgs
parents:
diff changeset
   128
    }
hgs
parents:
diff changeset
   129
  
hgs
parents:
diff changeset
   130
void CThumbnailTester::GenerateThumbnailL( TDes& aFileName )
hgs
parents:
diff changeset
   131
    {
hgs
parents:
diff changeset
   132
    SelectIntegerL( TPoint(0,0), iDisplaySize, _L("Select starting position(seconds):"), 0, 9999, iStartPositionInMs );
hgs
parents:
diff changeset
   133
    
hgs
parents:
diff changeset
   134
    // Convert from seconds to ms.
hgs
parents:
diff changeset
   135
    iStartPositionInMs *= 1000;
hgs
parents:
diff changeset
   136
        
hgs
parents:
diff changeset
   137
    _LIT( KFull,   "Full speed" );
hgs
parents:
diff changeset
   138
    _LIT( KMedium, "100 millisecond delay" );
hgs
parents:
diff changeset
   139
    _LIT( KSlow,   "1 second delay" );
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
    RPointerArray<TDesC> speed;
hgs
parents:
diff changeset
   142
    speed.Append( &KFull );
hgs
parents:
diff changeset
   143
    speed.Append( &KMedium );
hgs
parents:
diff changeset
   144
    speed.Append( &KSlow );
hgs
parents:
diff changeset
   145
    
hgs
parents:
diff changeset
   146
    TInt index = SelectFromListL( TPoint(0,0), iDisplaySize, _L("Select speed:"), speed );
hgs
parents:
diff changeset
   147
    
hgs
parents:
diff changeset
   148
    speed.Reset();
hgs
parents:
diff changeset
   149
    
hgs
parents:
diff changeset
   150
    switch( index )
hgs
parents:
diff changeset
   151
        {
hgs
parents:
diff changeset
   152
        case 0:
hgs
parents:
diff changeset
   153
            iDelayBetweenFrames = 0;
hgs
parents:
diff changeset
   154
            break;
hgs
parents:
diff changeset
   155
        case 1:
hgs
parents:
diff changeset
   156
            iDelayBetweenFrames = 100000;  // 1/10 second
hgs
parents:
diff changeset
   157
            break;
hgs
parents:
diff changeset
   158
        case 2:
hgs
parents:
diff changeset
   159
            iDelayBetweenFrames = 1000000;  // 1 second
hgs
parents:
diff changeset
   160
            break;
hgs
parents:
diff changeset
   161
        }
hgs
parents:
diff changeset
   162
hgs
parents:
diff changeset
   163
    RFile file;    
hgs
parents:
diff changeset
   164
    User::LeaveIfError( file.Open( iFs, aFileName, EFileShareReadersOnly | EFileStream | EFileRead ) );
hgs
parents:
diff changeset
   165
    
hgs
parents:
diff changeset
   166
    iThumbnailUtility = CHXThumbnailUtility::NewL(*this);
hgs
parents:
diff changeset
   167
hgs
parents:
diff changeset
   168
    bool done = false;
hgs
parents:
diff changeset
   169
hgs
parents:
diff changeset
   170
    iStopThumbnailGeneration = false;
hgs
parents:
diff changeset
   171
    
hgs
parents:
diff changeset
   172
    StartMonitoringWindowEvents();
hgs
parents:
diff changeset
   173
    
hgs
parents:
diff changeset
   174
    TInt originalStartPositionInMs = iStartPositionInMs;
hgs
parents:
diff changeset
   175
    
hgs
parents:
diff changeset
   176
    while( !done )
hgs
parents:
diff changeset
   177
        {
hgs
parents:
diff changeset
   178
        iThumbnailUtility->OpenFileL( file, iStartPositionInMs );
hgs
parents:
diff changeset
   179
hgs
parents:
diff changeset
   180
        // OpenFileL will block until all bitmaps have been passed to PacketReady.
hgs
parents:
diff changeset
   181
        
hgs
parents:
diff changeset
   182
        // This isn't necessarily exact, but advance the start position by the time represented
hgs
parents:
diff changeset
   183
        // by the number of renderered frames.
hgs
parents:
diff changeset
   184
        iStartPositionInMs = originalStartPositionInMs + (iTotalFramesRendered * 1000) / iFrameRateInSec;
hgs
parents:
diff changeset
   185
                
hgs
parents:
diff changeset
   186
        done = ((iFramesRendered < 5) || iStopThumbnailGeneration);
hgs
parents:
diff changeset
   187
        
hgs
parents:
diff changeset
   188
        iFramesRendered = 0;
hgs
parents:
diff changeset
   189
        }
hgs
parents:
diff changeset
   190
    
hgs
parents:
diff changeset
   191
    Cancel();
hgs
parents:
diff changeset
   192
 
hgs
parents:
diff changeset
   193
    WaitForAnyKey();
hgs
parents:
diff changeset
   194
    
hgs
parents:
diff changeset
   195
    delete iThumbnailUtility;
hgs
parents:
diff changeset
   196
    iThumbnailUtility = NULL;
hgs
parents:
diff changeset
   197
    
hgs
parents:
diff changeset
   198
    file.Close();    
hgs
parents:
diff changeset
   199
    }
hgs
parents:
diff changeset
   200
           
hgs
parents:
diff changeset
   201
bool CThumbnailTester::ConsumeKeyEvent( TInt /*aKeyCode*/ )
hgs
parents:
diff changeset
   202
    {
hgs
parents:
diff changeset
   203
    // Stop thumbnail generation when a key is pressed.
hgs
parents:
diff changeset
   204
    iStopThumbnailGeneration = true;
hgs
parents:
diff changeset
   205
    iThumbnailUtility->CancelThumb();
hgs
parents:
diff changeset
   206
    return true;
hgs
parents:
diff changeset
   207
    }
hgs
parents:
diff changeset
   208
hgs
parents:
diff changeset
   209
void CThumbnailTester::ExecuteOperation( TInt aOperation, const TDesC& aOperationText )
hgs
parents:
diff changeset
   210
    {    
hgs
parents:
diff changeset
   211
    }
hgs
parents:
diff changeset
   212
hgs
parents:
diff changeset
   213
void CThumbnailTester::MetaDataReady(TInt aError)
hgs
parents:
diff changeset
   214
    {
hgs
parents:
diff changeset
   215
    RDebug::Printf( "THUMBNAILTESTER MetadataReady(%i)", aError );
hgs
parents:
diff changeset
   216
    
hgs
parents:
diff changeset
   217
    // Get basic meta data.
hgs
parents:
diff changeset
   218
    
hgs
parents:
diff changeset
   219
    TUint lCount = 0;
hgs
parents:
diff changeset
   220
    TUint i=0;
hgs
parents:
diff changeset
   221
    
hgs
parents:
diff changeset
   222
    iThumbnailUtility->GetMetaDataCount(lCount);
hgs
parents:
diff changeset
   223
hgs
parents:
diff changeset
   224
    RDebug::Printf( "THUMBNAILTESTER metadata count=%i", lCount );
hgs
parents:
diff changeset
   225
    
hgs
parents:
diff changeset
   226
    for (i=0; i<lCount; i++)
hgs
parents:
diff changeset
   227
        {
hgs
parents:
diff changeset
   228
        HBufC *pDes = NULL;           
hgs
parents:
diff changeset
   229
        HXMetaDataKeys::EHXMetaDataId id;        
hgs
parents:
diff changeset
   230
        iThumbnailUtility->GetMetaDataAt(i, id, pDes);
hgs
parents:
diff changeset
   231
hgs
parents:
diff changeset
   232
        const char* key = "";
hgs
parents:
diff changeset
   233
        
hgs
parents:
diff changeset
   234
        for( TInt j = 0; j < sizeof(HXMetaDataKeyTab)/sizeof(HXMetaDataKeys); j++ )
hgs
parents:
diff changeset
   235
            {
hgs
parents:
diff changeset
   236
            if( id == HXMetaDataKeyTab[j].m_id )
hgs
parents:
diff changeset
   237
                {
hgs
parents:
diff changeset
   238
                key = HXMetaDataKeyTab[j].m_pHXKey;
hgs
parents:
diff changeset
   239
                }
hgs
parents:
diff changeset
   240
            }
hgs
parents:
diff changeset
   241
        
hgs
parents:
diff changeset
   242
        for( TInt j = 0; j < sizeof(HXStreamMetaDataKeyTab)/sizeof(HXMetaDataKeys); j++ )
hgs
parents:
diff changeset
   243
            {
hgs
parents:
diff changeset
   244
            if( id == HXStreamMetaDataKeyTab[j].m_id )
hgs
parents:
diff changeset
   245
                {
hgs
parents:
diff changeset
   246
                key = HXStreamMetaDataKeyTab[j].m_pHXKey;
hgs
parents:
diff changeset
   247
                }
hgs
parents:
diff changeset
   248
            }
hgs
parents:
diff changeset
   249
        
hgs
parents:
diff changeset
   250
        RDebug::Printf( "THUMBNAILTESTER metadata[%i] id=%i key=%s", i, id, key );        
hgs
parents:
diff changeset
   251
        
hgs
parents:
diff changeset
   252
        TInt current = 0;
hgs
parents:
diff changeset
   253
        TBuf8<400> outputLine;
hgs
parents:
diff changeset
   254
        while( current < pDes->Length() )
hgs
parents:
diff changeset
   255
            {
hgs
parents:
diff changeset
   256
            char c = pDes->Des()[current];                
hgs
parents:
diff changeset
   257
            char c2 = c;
hgs
parents:
diff changeset
   258
            if( c2 < ' ' || c2 > '~' )
hgs
parents:
diff changeset
   259
                {
hgs
parents:
diff changeset
   260
                c2 = ' ';
hgs
parents:
diff changeset
   261
                }
hgs
parents:
diff changeset
   262
            
hgs
parents:
diff changeset
   263
            outputLine.AppendFormat(_L8("%02x/%c "), c, c2 ); 
hgs
parents:
diff changeset
   264
            
hgs
parents:
diff changeset
   265
            current++;
hgs
parents:
diff changeset
   266
            
hgs
parents:
diff changeset
   267
            if( (current % 20 == 0) || current == pDes->Length()  )
hgs
parents:
diff changeset
   268
                {
hgs
parents:
diff changeset
   269
                outputLine.Append( '\0' );
hgs
parents:
diff changeset
   270
                RDebug::Printf( (char*)outputLine.Ptr() );
hgs
parents:
diff changeset
   271
                outputLine.SetLength(0);
hgs
parents:
diff changeset
   272
                }            
hgs
parents:
diff changeset
   273
            }        
hgs
parents:
diff changeset
   274
        
hgs
parents:
diff changeset
   275
        if (id == HXMetaDataKeys::EHXFrameSize && pDes)
hgs
parents:
diff changeset
   276
            {
hgs
parents:
diff changeset
   277
            TPtr pFrameSizePtr = pDes->Des();
hgs
parents:
diff changeset
   278
            _LIT(KChar_x, "x");
hgs
parents:
diff changeset
   279
            TInt xLoc = pFrameSizePtr.Find(KChar_x);
hgs
parents:
diff changeset
   280
            if (xLoc != KErrNotFound)
hgs
parents:
diff changeset
   281
                {                           
hgs
parents:
diff changeset
   282
                TLex lexWidth(pFrameSizePtr.Mid(0, xLoc));
hgs
parents:
diff changeset
   283
                TLex lexHeight(pFrameSizePtr.Mid(xLoc+1));
hgs
parents:
diff changeset
   284
                lexWidth.Val(iWidth);  // Storing into local iWidth variable
hgs
parents:
diff changeset
   285
                lexHeight.Val(iHeight);  // Storing into local iHeight variable  
hgs
parents:
diff changeset
   286
                }
hgs
parents:
diff changeset
   287
            }
hgs
parents:
diff changeset
   288
        else if (id == HXMetaDataKeys::EHXDuration && pDes)
hgs
parents:
diff changeset
   289
            {
hgs
parents:
diff changeset
   290
            TLex lexDuration(pDes->Des());
hgs
parents:
diff changeset
   291
            lexDuration.Val(iDuration);
hgs
parents:
diff changeset
   292
            }        
hgs
parents:
diff changeset
   293
        else if (id == HXMetaDataKeys::EHXFramesPerSecond && pDes)
hgs
parents:
diff changeset
   294
            {
hgs
parents:
diff changeset
   295
            TLex lexFramesPerSecond(pDes->Des());           
hgs
parents:
diff changeset
   296
            lexFramesPerSecond.Val(iFrameRateInSec);            
hgs
parents:
diff changeset
   297
            }
hgs
parents:
diff changeset
   298
        else if (id == HXMetaDataKeys::EHXClipBitRate && pDes)
hgs
parents:
diff changeset
   299
            {
hgs
parents:
diff changeset
   300
            TLex lexBitRate(pDes->Des());           
hgs
parents:
diff changeset
   301
            lexBitRate.Val(iClipBitRate);            
hgs
parents:
diff changeset
   302
            }
hgs
parents:
diff changeset
   303
        else if (id == HXMetaDataKeys::EHXVideoBitRate && pDes)
hgs
parents:
diff changeset
   304
            {
hgs
parents:
diff changeset
   305
            TLex lexBitRate(pDes->Des());           
hgs
parents:
diff changeset
   306
            lexBitRate.Val(iVideoBitRate);            
hgs
parents:
diff changeset
   307
            }
hgs
parents:
diff changeset
   308
        else if (id == HXMetaDataKeys::EHXAudioBitRate && pDes)
hgs
parents:
diff changeset
   309
            {
hgs
parents:
diff changeset
   310
            TLex lexBitRate(pDes->Des());           
hgs
parents:
diff changeset
   311
            lexBitRate.Val(iAudioBitRate);            
hgs
parents:
diff changeset
   312
            }
hgs
parents:
diff changeset
   313
        
hgs
parents:
diff changeset
   314
        } // end for
hgs
parents:
diff changeset
   315
    
hgs
parents:
diff changeset
   316
    iTotalFrameCount = ( (iDuration+500)/1000 ) * iFrameRateInSec;
hgs
parents:
diff changeset
   317
    
hgs
parents:
diff changeset
   318
    RDebug::Printf( "THUMBNAILTESTER width=%i", iWidth );
hgs
parents:
diff changeset
   319
    RDebug::Printf( "THUMBNAILTESTER height=%i", iHeight );
hgs
parents:
diff changeset
   320
    RDebug::Printf( "THUMBNAILTESTER frame rate=%i", iFrameRateInSec );
hgs
parents:
diff changeset
   321
    RDebug::Printf( "THUMBNAILTESTER duration=%i", iDuration );
hgs
parents:
diff changeset
   322
    RDebug::Printf( "THUMBNAILTESTER frame count=%i", iTotalFrameCount );
hgs
parents:
diff changeset
   323
    RDebug::Printf( "THUMBNAILTESTER clip bit rate=%i", iClipBitRate );
hgs
parents:
diff changeset
   324
    RDebug::Printf( "THUMBNAILTESTER video bit rate=%i", iVideoBitRate );
hgs
parents:
diff changeset
   325
    RDebug::Printf( "THUMBNAILTESTER audio bit rate=%i", iAudioBitRate );
hgs
parents:
diff changeset
   326
    }
hgs
parents:
diff changeset
   327
hgs
parents:
diff changeset
   328
void CThumbnailTester::PacketReady(TInt /*aError*/, void *pYuvBuffer, TUint32 /*aYuvBufferSize*/)
hgs
parents:
diff changeset
   329
    {
hgs
parents:
diff changeset
   330
    // TODO: HANDLE aError
hgs
parents:
diff changeset
   331
    
hgs
parents:
diff changeset
   332
    iFramesRendered++;
hgs
parents:
diff changeset
   333
    iTotalFramesRendered++;
hgs
parents:
diff changeset
   334
    
hgs
parents:
diff changeset
   335
    // Convert from YUV420 to RGB24.
hgs
parents:
diff changeset
   336
    
hgs
parents:
diff changeset
   337
    const TInt KBytesPerPixel = 3; // 24-bit rgb takes 3 bytes
hgs
parents:
diff changeset
   338
    
hgs
parents:
diff changeset
   339
    TUint32 rgbBufferSize = iWidth * iHeight * KBytesPerPixel;
hgs
parents:
diff changeset
   340
    TUint8 *pRgbBuffer =(TUint8*) User::AllocL(rgbBufferSize);
hgs
parents:
diff changeset
   341
        
hgs
parents:
diff changeset
   342
    CYuv2Rgb24* yuvConverter = NULL; 
hgs
parents:
diff changeset
   343
    TRAPD(err, yuvConverter = new(ELeave) CYuv2Rgb24);
hgs
parents:
diff changeset
   344
    
hgs
parents:
diff changeset
   345
    // TODO: CHECK ERROR
hgs
parents:
diff changeset
   346
hgs
parents:
diff changeset
   347
    TRAP(err, yuvConverter->ConstructL(iWidth, iHeight, iWidth, iHeight))
hgs
parents:
diff changeset
   348
hgs
parents:
diff changeset
   349
    // TODO: CHECK ERROR
hgs
parents:
diff changeset
   350
hgs
parents:
diff changeset
   351
    TInt scanLineLength = iWidth * KBytesPerPixel;
hgs
parents:
diff changeset
   352
    
hgs
parents:
diff changeset
   353
    TUint8* yBuf = (TUint8*)pYuvBuffer;
hgs
parents:
diff changeset
   354
    TUint8* uBuf = yBuf + iWidth*iHeight;
hgs
parents:
diff changeset
   355
    TUint8* vBuf = uBuf + (iWidth*iHeight)/4;    
hgs
parents:
diff changeset
   356
    
hgs
parents:
diff changeset
   357
    yuvConverter->Convert(yBuf, uBuf, vBuf, iWidth, iHeight, pRgbBuffer, scanLineLength);
hgs
parents:
diff changeset
   358
    
hgs
parents:
diff changeset
   359
    delete yuvConverter;        
hgs
parents:
diff changeset
   360
hgs
parents:
diff changeset
   361
    // Use RGB24 buffer to create CFbsBitmap.
hgs
parents:
diff changeset
   362
    
hgs
parents:
diff changeset
   363
    CFbsBitmap* pBitmap = NULL;
hgs
parents:
diff changeset
   364
    
hgs
parents:
diff changeset
   365
    TRAP(err, pBitmap = new (ELeave) CFbsBitmap);
hgs
parents:
diff changeset
   366
    if( err == KErrNone )
hgs
parents:
diff changeset
   367
        {
hgs
parents:
diff changeset
   368
        err = pBitmap->Create(TSize(iWidth, iHeight), EColor16M); 
hgs
parents:
diff changeset
   369
    
hgs
parents:
diff changeset
   370
        if( err == KErrNone )
hgs
parents:
diff changeset
   371
            {
hgs
parents:
diff changeset
   372
            // fill image from rgb buffer to input bitmap buffer 
hgs
parents:
diff changeset
   373
            TPtr8 linePtr(0,0); 
hgs
parents:
diff changeset
   374
            TInt lineLength = pBitmap->ScanLineLength(iWidth, EColor16M); 
hgs
parents:
diff changeset
   375
            for(int j=0, i=0; j<iHeight; j++, i+=lineLength)
hgs
parents:
diff changeset
   376
                {
hgs
parents:
diff changeset
   377
                linePtr.Set(pRgbBuffer+i, lineLength, lineLength);
hgs
parents:
diff changeset
   378
                pBitmap->SetScanLine((TDes8&)linePtr,j); 
hgs
parents:
diff changeset
   379
                }
hgs
parents:
diff changeset
   380
                
hgs
parents:
diff changeset
   381
            iGc->Activate(*iSelectionWindow);
hgs
parents:
diff changeset
   382
            
hgs
parents:
diff changeset
   383
            iSelectionWindow->Invalidate();
hgs
parents:
diff changeset
   384
            iSelectionWindow->BeginRedraw();
hgs
parents:
diff changeset
   385
            
hgs
parents:
diff changeset
   386
            iGc->Reset();
hgs
parents:
diff changeset
   387
            
hgs
parents:
diff changeset
   388
            iGc->UseFont(iFont);                
hgs
parents:
diff changeset
   389
            iGc->SetBrushColor(KRgbDarkBlue);
hgs
parents:
diff changeset
   390
            
hgs
parents:
diff changeset
   391
            iGc->Clear();
hgs
parents:
diff changeset
   392
            
hgs
parents:
diff changeset
   393
            // KRgbWhite seems to be having problems (0xffffff) in some emulators,
hgs
parents:
diff changeset
   394
            // but 0xfefefe is working, so use that instead of white.        
hgs
parents:
diff changeset
   395
            iGc->SetPenColor(0xfefefe);
hgs
parents:
diff changeset
   396
hgs
parents:
diff changeset
   397
            TPoint topLeft( iDisplaySize.iWidth/2 - iWidth/2, 
hgs
parents:
diff changeset
   398
                            iDisplaySize.iHeight/2 - iHeight/2 ); 
hgs
parents:
diff changeset
   399
            iGc->BitBlt( topLeft, pBitmap );
hgs
parents:
diff changeset
   400
            
hgs
parents:
diff changeset
   401
            const TInt KColumn = 3;
hgs
parents:
diff changeset
   402
            const TInt KRowIncrement = KFontSize + 1;
hgs
parents:
diff changeset
   403
            TInt row = KRowIncrement;
hgs
parents:
diff changeset
   404
hgs
parents:
diff changeset
   405
            iBuffer.Format( _L("Frame # %i"), iFramesRendered );
hgs
parents:
diff changeset
   406
            iGc->DrawText( iBuffer, TPoint(KColumn, row) );
hgs
parents:
diff changeset
   407
            row += KRowIncrement;
hgs
parents:
diff changeset
   408
hgs
parents:
diff changeset
   409
            iBuffer.Format( _L("Total frames rendered: %i"), iTotalFramesRendered );
hgs
parents:
diff changeset
   410
            iGc->DrawText( iBuffer, TPoint(KColumn, row) );
hgs
parents:
diff changeset
   411
            row += KRowIncrement;
hgs
parents:
diff changeset
   412
hgs
parents:
diff changeset
   413
            iBuffer.Format( _L("Start time(ms): %i"), iStartPositionInMs );
hgs
parents:
diff changeset
   414
            iGc->DrawText( iBuffer, TPoint(KColumn, row) );
hgs
parents:
diff changeset
   415
            row += KRowIncrement;
hgs
parents:
diff changeset
   416
hgs
parents:
diff changeset
   417
            iBuffer.Format( _L("Display size: %ix%i"), iDisplaySize.iWidth, iDisplaySize.iHeight );
hgs
parents:
diff changeset
   418
            iGc->DrawText( iBuffer, TPoint(KColumn, row) );
hgs
parents:
diff changeset
   419
            row += KRowIncrement;
hgs
parents:
diff changeset
   420
            
hgs
parents:
diff changeset
   421
            iBuffer.Format( _L("Video size: %ix%i"), iWidth, iHeight );
hgs
parents:
diff changeset
   422
            iGc->DrawText( iBuffer, TPoint(KColumn, row) );
hgs
parents:
diff changeset
   423
            row += KRowIncrement;            
hgs
parents:
diff changeset
   424
            
hgs
parents:
diff changeset
   425
            iBuffer.Format( _L("Total frame count: %i"), iTotalFrameCount );
hgs
parents:
diff changeset
   426
            iGc->DrawText( iBuffer, TPoint(KColumn, row) );
hgs
parents:
diff changeset
   427
            row += KRowIncrement;            
hgs
parents:
diff changeset
   428
            
hgs
parents:
diff changeset
   429
            iBuffer.Format( _L("Duration: %i"), iDuration );
hgs
parents:
diff changeset
   430
            iGc->DrawText( iBuffer, TPoint(KColumn, row) );
hgs
parents:
diff changeset
   431
            row += KRowIncrement;            
hgs
parents:
diff changeset
   432
            
hgs
parents:
diff changeset
   433
            iBuffer.Format( _L("Frame rate: %i"), iFrameRateInSec );
hgs
parents:
diff changeset
   434
            iGc->DrawText( iBuffer, TPoint(KColumn, row) );
hgs
parents:
diff changeset
   435
            row += KRowIncrement;            
hgs
parents:
diff changeset
   436
            
hgs
parents:
diff changeset
   437
            iBuffer.Format( _L("Clip bit rate: %i"), iClipBitRate );
hgs
parents:
diff changeset
   438
            iGc->DrawText( iBuffer, TPoint(KColumn, row) );
hgs
parents:
diff changeset
   439
            row += KRowIncrement;            
hgs
parents:
diff changeset
   440
            
hgs
parents:
diff changeset
   441
            iBuffer.Format( _L("Video bit rate: %i"), iVideoBitRate );
hgs
parents:
diff changeset
   442
            iGc->DrawText( iBuffer, TPoint(KColumn, row) );
hgs
parents:
diff changeset
   443
            row += KRowIncrement;            
hgs
parents:
diff changeset
   444
            
hgs
parents:
diff changeset
   445
            iBuffer.Format( _L("Audio bit rate: %i"), iAudioBitRate );
hgs
parents:
diff changeset
   446
            iGc->DrawText( iBuffer, TPoint(KColumn, row) );
hgs
parents:
diff changeset
   447
            row += KRowIncrement;            
hgs
parents:
diff changeset
   448
hgs
parents:
diff changeset
   449
            iGc->DrawText( _L("<Press key to stop then another to exit>"), TPoint(KColumn, iDisplaySize.iHeight-10) );
hgs
parents:
diff changeset
   450
            
hgs
parents:
diff changeset
   451
            iSelectionWindow->EndRedraw();
hgs
parents:
diff changeset
   452
            
hgs
parents:
diff changeset
   453
            iGc->Deactivate();
hgs
parents:
diff changeset
   454
            
hgs
parents:
diff changeset
   455
            iSelectionWindow->SetVisible( ETrue );            
hgs
parents:
diff changeset
   456
            }
hgs
parents:
diff changeset
   457
        
hgs
parents:
diff changeset
   458
        delete pBitmap;
hgs
parents:
diff changeset
   459
        }
hgs
parents:
diff changeset
   460
    
hgs
parents:
diff changeset
   461
    delete pRgbBuffer;    
hgs
parents:
diff changeset
   462
hgs
parents:
diff changeset
   463
    User::After( iDelayBetweenFrames );    
hgs
parents:
diff changeset
   464
    }
hgs
parents:
diff changeset
   465
hgs
parents:
diff changeset
   466
void CThumbnailTester::EndOfPackets()
hgs
parents:
diff changeset
   467
    {
hgs
parents:
diff changeset
   468
    RDebug::Printf( "THUMBNAILTESTER end of packets" );
hgs
parents:
diff changeset
   469
    }
hgs
parents:
diff changeset
   470
hgs
parents:
diff changeset
   471
GLDEF_C TInt E32Main()
hgs
parents:
diff changeset
   472
    {
hgs
parents:
diff changeset
   473
    __UHEAP_MARK;
hgs
parents:
diff changeset
   474
    
hgs
parents:
diff changeset
   475
    CActiveScheduler* scheduler = new CActiveScheduler;
hgs
parents:
diff changeset
   476
    CTrapCleanup* cleanup = CTrapCleanup::New();
hgs
parents:
diff changeset
   477
    if( scheduler != NULL && cleanup != NULL )
hgs
parents:
diff changeset
   478
    {
hgs
parents:
diff changeset
   479
        CActiveScheduler::Install( scheduler );
hgs
parents:
diff changeset
   480
        TRAP_IGNORE( CThumbnailTester::ExecuteL() );
hgs
parents:
diff changeset
   481
    }
hgs
parents:
diff changeset
   482
    delete cleanup;
hgs
parents:
diff changeset
   483
    delete scheduler;
hgs
parents:
diff changeset
   484
    REComSession::FinalClose();
hgs
parents:
diff changeset
   485
    __UHEAP_MARKEND;
hgs
parents:
diff changeset
   486
    return 0;
hgs
parents:
diff changeset
   487
    }
hgs
parents:
diff changeset
   488