camcordermmfplugin/tsrc/public/basic/src/camcTestClient_visualcheckdsp.cpp
changeset 0 9b3e960ffc8a
child 42 605672cc2a86
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/camcordermmfplugin/tsrc/public/basic/src/camcTestClient_visualcheckdsp.cpp	Thu Dec 17 08:51:24 2009 +0200
@@ -0,0 +1,903 @@
+/*
+* Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:  Camcorder MMF API Test DLL
+*
+*/
+
+
+
+// INCLUDE FILES
+
+#include "CamcTestClient_visualcheckdsp.h"
+#include <AudioPreference.h>
+
+
+// EXTERNAL DATA STRUCTURES
+
+// EXTERNAL FUNCTION PROTOTYPES 
+ 
+// CONSTANTS
+
+// MACROS
+
+// LOCAL CONSTANTS AND MACROS
+
+// MODULE DATA STRUCTURES
+
+// LOCAL FUNCTION PROTOTYPES
+
+// FORWARD DECLARATIONS
+
+
+
+CCamcTestClient_visualcheckdsp::CCamcTestClient_visualcheckdsp () : CTimer(CActive::EPriorityHigh)
+    {
+    }
+
+
+CCamcTestClient_visualcheckdsp::~CCamcTestClient_visualcheckdsp ()
+    {
+#ifdef _DEBUG
+    RDebug::Print(_L("CamCTestClient VisualCheck: Destructor Start"));
+#endif
+    Cancel();
+    delete iCamc;
+#ifdef _DEBUG
+    RDebug::Print(_L("CamCTestClient VisualCheck: Destructor Start"));
+#endif
+    }
+
+CCamcTestClient_visualcheckdsp* CCamcTestClient_visualcheckdsp::NewL()
+    {
+    CCamcTestClient_visualcheckdsp* self = new(ELeave) CCamcTestClient_visualcheckdsp;
+    CleanupStack::PushL(self);
+    self->ConstructL( );
+    CleanupStack::Pop(self);
+    return self;
+    }
+
+void CCamcTestClient_visualcheckdsp::ConstructL( )
+    {
+    iCamc = CVideoRecorderUtility::NewL( *this, KAudioPriorityVideoRecording, EMdaPriorityPreferenceTimeAndQuality );
+    iOpenReady = EFalse;
+    iPrepareReady = EFalse;
+    iRecordingReady = EFalse;
+    iPaused = EFalse;
+    i2ndTime = EFalse;
+    iDoublePause = EFalse;
+    iStartRecording2ndTime = EFalse;
+    
+    CTimer::ConstructL();
+    iTimeout = 0;
+    iClosed = 0;
+    CActiveScheduler::Add(this);
+    }
+
+
+void CCamcTestClient_visualcheckdsp::Start_Active_ObjectL ( TestClientVCdspActions aAction, TInt aCameraHandle )
+    {
+    
+    iUiLevelCameraHandle = aCameraHandle;
+    TUid controllerUid = {0x101F8503};	//implementation uid
+    TUid formatUid = {0};
+    TUid formatUidG2 = {0x101F86D6};
+    TUid formatUidMP4 = {0x101F873D};
+    
+    
+    iAction = aAction;                  //iAction might be set to NULL after action has been executed
+    TBuf<50> fileName;
+    
+#if ( defined (__WINS__) || defined (__WINSCW__) )
+    _LIT(KFileName1,"c:\\recordQCIF_dsp_1.3gp");
+    _LIT(KFileName2,"c:\\recordQCIF_dsp_2.3gp");
+    _LIT(KFileName3,"c:\\recordQCIF_dsp_3.3gp");
+    _LIT(KFileName4,"c:\\recordQCIF_dsp_4.3gp");
+    _LIT(KFileName5,"c:\\recordQCIF_dsp_5.3gp");
+    _LIT(KFileName6,"c:\\recordQCIF_dsp_6.3gp");
+    _LIT(KFileName7,"c:\\recordQCIF_dsp_7.3gp");
+    _LIT(KFileName8,"c:\\recordQCIF_dsp_8.3gp");
+    _LIT(KFileName9_a,"c:\\recordQCIF_dsp_9_a.3gp");
+    _LIT(KFileName9_b,"c:\\recordQCIF_dsp_9_b.3gp");
+    _LIT(KFileName10,"c:\\recordQCIF_dsp_10.3gp");
+    _LIT(KFileName11,"c:\\recordQCIF_dsp_11.3gp");
+    _LIT(KFileName12,"c:\\recordQCIF_dsp_12.3gp");
+    _LIT(KFileName14,"c:\\recordQCIF_dsp_14.3gp");
+    _LIT(KFileName15,"c:\\recordQCIF_dsp_15.3gp");
+    _LIT(KFileName16,"c:\\recordQCIF_dsp_16.3gp");
+    _LIT(KFileName17,"c:\\recordQCIF_dsp_17.3gp");
+    _LIT(KFileName17_A,"c:\\recordQCIF_dsp_17_a.3gp");
+    _LIT(KFileName18,"c:\\recordQCIF_dsp_18.3g2");
+    _LIT(KFileName19,"c:\\recordQCIF_dsp_19.3g2");
+    _LIT(KFileName20,"c:\\recordQCIF_dsp_20.3g2");
+    _LIT(KFileName21,"c:\\recordQCIF_dsp_21.mp4");
+#else 
+    _LIT(KFileName1,"E:\\recordQCIF_dsp_1.3gp");
+    _LIT(KFileName2,"E:\\recordQCIF_dsp_2.3gp");
+    _LIT(KFileName3,"E:\\recordQCIF_dsp_3.3gp");
+    _LIT(KFileName4,"E:\\recordQCIF_dsp_4.3gp");
+    _LIT(KFileName5,"E:\\recordQCIF_dsp_5.3gp");
+    _LIT(KFileName6,"E:\\recordQCIF_dsp_6.3gp");
+    _LIT(KFileName7,"E:\\recordQCIF_dsp_7.3gp");
+    _LIT(KFileName8,"E:\\recordQCIF_dsp_8.3gp");
+    _LIT(KFileName9_a,"E:\\recordQCIF_dsp_9_a.3gp");
+    _LIT(KFileName9_b,"E:\\recordQCIF_dsp_9_b.3gp");
+    _LIT(KFileName10,"E:\\recordQCIF_dsp_10.3gp");
+    _LIT(KFileName11,"E:\\recordQCIF_dsp_11.3gp");
+    _LIT(KFileName12,"E:\\recordQCIF_dsp_12.3gp");
+    _LIT(KFileName14,"E:\\recordQCIF_dsp_14.3gp");
+    _LIT(KFileName15,"C:\\recordQCIF_dsp_15.3gp");
+    _LIT(KFileName16,"E:\\recordQCIF_dsp_16.3gp");
+    _LIT(KFileName17,"E:\\recordQCIF_dsp_17.3gp");
+    _LIT(KFileName17_A,"E:\\recordQCIF_dsp_17_a.3gp");
+    _LIT(KFileName18,"E:\\recordQCIF_dsp_18.3g2");
+    _LIT(KFileName19,"E:\\recordQCIF_dsp_19.3g2");
+    _LIT(KFileName20,"E:\\recordQCIF_dsp_20.3g2");
+    _LIT(KFileName21,"E:\\recordQCIF_dsp_21.mp4");
+#endif
+    switch(iAction)
+        {
+        case K_VC_dsp_test_case_1:
+            {
+            fileName = KFileName1;
+            break;
+            }
+        case K_VC_dsp_test_case_2:
+            {
+            fileName = KFileName2;
+            break;
+            }
+        case K_VC_dsp_test_case_3:
+            {
+            fileName = KFileName3;
+            break;
+            }
+        case K_VC_dsp_test_case_4:
+            {
+            fileName = KFileName4;
+            break;
+            }
+        case K_VC_dsp_test_case_5:
+            {
+            fileName = KFileName5;
+            break;
+            }
+        case K_VC_dsp_test_case_6:
+            {
+            fileName = KFileName6;
+            break;
+            }
+        case K_VC_dsp_test_case_7:
+            {
+            fileName = KFileName7;
+            break;
+            }
+        case K_VC_dsp_test_case_8:
+            {
+            fileName = KFileName8;
+            break;
+            }
+        case K_VC_dsp_test_case_9_a:
+            {
+            fileName = KFileName9_a;
+            break;
+            }
+        case K_VC_dsp_test_case_9_b:
+            {
+            fileName = KFileName9_b;
+            break;
+            }
+        case K_VC_dsp_test_case_10:
+            {
+            fileName = KFileName10;
+            break;
+            }
+        case K_VC_dsp_test_case_11:
+            {
+            fileName = KFileName11;
+            break;
+            }
+        case K_VC_dsp_test_case_12:
+            {
+            fileName = KFileName12;
+            break;
+            }
+        case K_VC_dsp_test_case_14:
+            {
+            fileName = KFileName14;
+            break;
+            }
+        case K_VC_dsp_test_case_15:
+            {
+            fileName = KFileName15;
+            break;
+            }
+        case K_VC_dsp_test_case_16:
+            {
+            fileName = KFileName16;
+            break;
+            }
+        case K_VC_dsp_test_case_17:
+            {
+            fileName = KFileName17;
+            break;
+            }
+        case K_VC_dsp_test_case_17_a:
+            {
+            fileName = KFileName17_A;
+            break;
+            }
+        case K_VC_dsp_test_case_18:
+            {
+            fileName = KFileName18;
+            break;
+            }
+        case K_VC_dsp_test_case_19:
+            {
+            fileName = KFileName19;
+            break;
+            }
+        case K_VC_dsp_test_case_20:
+            {
+            fileName = KFileName20;
+            break;
+            }
+        case K_VC_dsp_test_case_21:
+            {
+            fileName = KFileName21;
+            break;
+            }
+        default:
+            break;
+        }
+    
+    TInt err = KErrNone;
+    switch ( iAction )
+        {
+        case K_VC_dsp_test_case_9_a :
+            TRAP(err,
+                iCamc->OpenFileL( fileName, iUiLevelCameraHandle, 
+                controllerUid,
+                formatUid,
+                _L8("video/H263-2000; profile=0; level=45"),
+                TFourCC(' ', 'A', 'M', 'R') ));
+            break;
+        case K_VC_dsp_test_case_17 :
+        case K_VC_dsp_test_case_17_a :
+            TRAP(err,
+                iCamc->OpenFileL( fileName, iUiLevelCameraHandle, 
+                controllerUid,
+                formatUid,
+                _L8("video/mp4v-es"),
+                TFourCC(' ', 'A', 'M', 'R') ));
+            break;
+        case K_VC_dsp_test_case_18:
+            TRAP(err,
+                iCamc->OpenFileL( fileName, iUiLevelCameraHandle, 
+                controllerUid,
+                formatUidG2,
+                _L8("video/H263-2000"),
+                TFourCC(' ', 'A', 'M', 'R') ));
+            break;
+        case K_VC_dsp_test_case_19:
+            TRAP(err,
+                iCamc->OpenFileL( fileName, iUiLevelCameraHandle, 
+                controllerUid,
+                formatUidG2,
+                _L8("video/mp4v-es"),
+                TFourCC(' ', 'Q', '1', '3') ));
+            break;
+        case K_VC_dsp_test_case_20:
+            TRAP(err,
+                iCamc->OpenFileL( fileName, iUiLevelCameraHandle, 
+                controllerUid,
+                formatUidG2,
+                _L8("video/H263-2000"),
+                TFourCC(' ', 'Q', '1', '3') ));
+            break;
+        case K_VC_dsp_test_case_21:
+            TRAP(err,
+                iCamc->OpenFileL( fileName, iUiLevelCameraHandle, 
+                controllerUid,
+                formatUidMP4,
+                _L8("video/mp4v-es; profile-level-id=3"),
+                TFourCC(' ', 'A', 'A', 'C') ));
+            break;
+        default:
+            {
+            TRAP(err,
+                iCamc->OpenFileL( fileName, iUiLevelCameraHandle, 
+                controllerUid,
+                formatUid,
+                _L8("video/H263-2000"),
+                TFourCC(' ', 'A', 'M', 'R') ));
+            }
+        }
+    if (err)
+        {
+        User::Leave(99);
+        }
+    iOpenReady = EFalse;
+    
+    // Main part of program is a wait loop
+    // This function completes when the scheduler stops
+    CActiveScheduler::Start();
+    
+    if ( iError )
+        {
+        User::Leave( iError );
+        }
+    }
+    
+    void CCamcTestClient_visualcheckdsp::RunL()
+        {
+        
+        // Trap RunL, to catch if the AO leaves.
+        // A Walkaround...
+        // RunError() should be used in this case, but
+        // Apparently, it is not possible to use the AO RunError() virtual function
+        // for that purpose, it is not called.
+        
+        TRAPD( err,RunLTrappedL() );
+        if ( err )
+            {
+            SomethingInActiveObjectIsLeaving(err);
+            }
+        }
+    
+    void CCamcTestClient_visualcheckdsp::RunLTrappedL()
+        {
+#ifdef _DEBUG
+        RDebug::Print(_L("CamCTestClient VisualCheck:RunL"));
+#endif
+        if ( iOpenReady ) 
+            {
+            iOpenReady = EFalse;
+            
+            switch(iAction)
+                {  
+                case K_VC_dsp_test_case_1:
+                    {
+                    break; 
+                    }
+                case K_VC_dsp_test_case_2:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(128,96));
+                    iCamc->SetVideoFrameRateL(TReal32(5));
+                    iCamc->SetVideoBitRateL(TInt(28000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(12200); 
+                    iCamc->SetMaxClipSizeL(95000);
+                    break; 
+                    }
+                case K_VC_dsp_test_case_3:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(128,96));
+                    iCamc->SetVideoFrameRateL(TReal32(7.5));
+                    iCamc->SetVideoBitRateL(TInt(28000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(6700); 
+                    iCamc->SetMaxClipSizeL(95000);
+                    break; 
+                    }
+                case K_VC_dsp_test_case_4:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(128,96));
+                    iCamc->SetVideoFrameRateL(TReal32(15));
+                    iCamc->SetVideoBitRateL(TInt(28000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(5150); 
+                    iCamc->SetMaxClipSizeL(250000);
+                    break; 
+                    }
+                case K_VC_dsp_test_case_5:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(5));
+                    iCamc->SetVideoBitRateL(TInt(42000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(7400); 
+                    iCamc->SetMaxClipSizeL(95000);
+                    break;
+                    }
+                case K_VC_dsp_test_case_6:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(7.5));
+                    iCamc->SetVideoBitRateL(TInt(42000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(4750); 
+                    iCamc->SetMaxClipSizeL(95000);
+                    break;
+                    }
+                case K_VC_dsp_test_case_7:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(15));
+                    iCamc->SetVideoBitRateL(TInt(42000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(12200); 
+                    break;
+                    }
+                case K_VC_dsp_test_case_8:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(7.5));
+                    iCamc->SetVideoBitRateL(TInt(64000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(12200); 
+                    iCamc->SetMaxClipSizeL(250000);
+                    break;              
+                    }
+                case K_VC_dsp_test_case_9_a:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(15));
+                    iCamc->SetVideoBitRateL(TInt(128000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(12200); 
+                    break;
+                    }
+                case K_VC_dsp_test_case_9_b:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(15));
+                    iCamc->SetVideoBitRateL(TInt(64000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(12200); 
+                    break;
+                    }
+                case K_VC_dsp_test_case_10:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(7.5));
+                    iCamc->SetVideoBitRateL(TInt(42000));    
+                    iCamc->SetAudioEnabledL(EFalse); 
+                    iCamc->SetMaxClipSizeL(95000);
+                    break;
+                    }
+                case K_VC_dsp_test_case_11:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(15));
+                    iCamc->SetVideoBitRateL(TInt(64000));
+                    iCamc->SetAudioEnabledL(EFalse); 
+                    iCamc->SetMaxClipSizeL(500000);
+                    break;
+                    }
+                case K_VC_dsp_test_case_12:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(128,96));
+                    iCamc->SetVideoFrameRateL(TReal32(15));
+                    iCamc->SetVideoBitRateL(KMMFVariableVideoBitRate);
+                    iCamc->SetMaxClipSizeL(95000);
+                    break;
+                    }
+                case K_VC_dsp_test_case_15:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(15));
+                    iCamc->SetVideoBitRateL(KMMFVariableVideoBitRate);
+                    break;
+                    }    
+                case K_VC_dsp_test_case_16:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(10));
+                    iCamc->SetVideoBitRateL(TInt(64000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(12200); 
+                    break;
+                    }    
+                case K_VC_dsp_test_case_17:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(128,96));
+                    iCamc->SetVideoFrameRateL(TReal32(15));
+                    iCamc->SetVideoBitRateL(TInt(64000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(12200); 
+                    break;
+                    }    
+                case K_VC_dsp_test_case_17_a:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(128,96));
+                    iCamc->SetVideoFrameRateL(TReal32(15));
+                    iCamc->SetVideoBitRateL(TInt(64000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(12200); 
+                    iCamc->SetMaxClipSizeL(500000);
+                    break;
+                    }
+                case K_VC_dsp_test_case_18:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(10));
+                    iCamc->SetVideoBitRateL(TInt(64000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(12200); 
+                    break;
+                    }    
+                case K_VC_dsp_test_case_19:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(10));
+                    iCamc->SetVideoBitRateL(TInt(64000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetMaxClipSizeL(300000);
+                    //bitrate setting TBD
+                    iCamc->SetAudioBitRateL(6800); 
+                    break;
+                    }
+                case K_VC_dsp_test_case_20:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(176,144));
+                    iCamc->SetVideoFrameRateL(TReal32(15));
+                    iCamc->SetVideoBitRateL(TInt(64000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    //bitrate setting TBD
+                    iCamc->SetAudioBitRateL(6800); 
+                    break;
+                    }
+                case K_VC_dsp_test_case_21:
+                    {
+                    iCamc->SetVideoFrameSizeL(TSize(352,288));
+                    iCamc->SetVideoFrameRateL(TReal32(15));
+                    iCamc->SetVideoBitRateL(TInt(384000));
+                    iCamc->SetAudioEnabledL(ETrue); 
+                    iCamc->SetAudioBitRateL(32000); 
+                    break;
+                    }
+                default:
+                    break;
+            }
+            
+            
+            
+            iCamc->Prepare();
+        }
+        else if ( iPrepareReady ) 
+            {
+            iPrepareReady = EFalse;    
+            iCamc->Record();
+            switch(iAction)
+                {
+                case K_VC_dsp_test_case_1:
+                    {
+                    CTimer::After( 30 * TInt32 ( 1E6 ) );  // Records for 30 sec
+                    break;
+                    }
+                case K_VC_dsp_test_case_2:
+                case K_VC_dsp_test_case_3:
+                case K_VC_dsp_test_case_4:
+                case K_VC_dsp_test_case_5:
+                case K_VC_dsp_test_case_6:
+                case K_VC_dsp_test_case_19:
+                    {
+                    // The timeout will be generated by the SetMaxClipSize.
+                    break;
+                    }
+                case K_VC_dsp_test_case_14:
+                    {
+                    CTimer::After( 1 * TInt32 ( 1E6 ) );
+                    break;
+                    }
+                case K_VC_dsp_test_case_16:
+                case K_VC_dsp_test_case_17:
+                case K_VC_dsp_test_case_17_a:
+                case K_VC_dsp_test_case_18:
+                    {
+                    CTimer::After( 10 * TInt32 ( 1E6 ) );  // Records for 10 sec
+                    iStartRecording2ndTime = EFalse;
+                    break;
+                    }
+                case K_VC_dsp_test_case_12:
+                    {
+                    CTimer::After( 4 * TInt32 ( 1E6 ) );  // Records for 4 sec
+                    iStartRecording2ndTime = EFalse;
+                    }
+                    break;
+                case K_VC_dsp_test_case_20:
+                    {
+                    CTimer::After( 15 * TInt32 ( 1E6 ) );  // Records for 15 sec + pause + another 15 sec
+                    iStartRecording2ndTime = EFalse;
+                    break;
+                    }
+                case K_VC_dsp_test_case_21:
+                    {
+                    CTimer::After( 30 * TInt32 ( 1E6 ) );  // Records for 30 sec + pause + another 30 sec
+                    iStartRecording2ndTime = EFalse;
+                    break;
+                    }
+
+                default:
+                    {
+                    CTimer::After( 10 * TInt32 ( 1E6 ) );
+                    break;          
+                    }
+                }
+            }
+        else if ( iRecordingReady )
+            {
+            iRecordingReady = EFalse;
+            iCamc->Close();
+            iClosed = ETrue;
+            CTimer::After(1000);
+            }
+        else if (iClosed)
+            {
+            CActiveScheduler::Stop();
+            }
+        else if ( iPaused ) //resume
+            {
+            switch(iAction)
+                {
+                case K_VC_dsp_test_case_7:
+                    {
+                    iCamc->Record();
+                    CTimer::After( 50 * TInt32 ( 1E6 ) ); // Records for 50 sec.
+                    iPaused = EFalse;
+                    iAction = K_VC_dsp_none;         
+                    break;
+                    }
+                case K_VC_dsp_test_case_9_a: 
+                    {
+                    if ( iDoublePause )
+                        {             
+                        iCamc->Record();
+                        CTimer::After( 2*60 * TInt32 ( 1E6 ) ); // Record 2 minutes
+                        iPaused = EFalse;
+                        iAction = K_VC_dsp_none;
+                        }
+                    else 
+                        {
+                        iCamc->Record();
+                        CTimer::After(  2*60 * TInt32 ( 1E6 ) ); // Record 2 minutes
+                        iPaused = EFalse;
+                        iDoublePause = ETrue;
+                        }
+                    break;
+                    }
+                case K_VC_dsp_test_case_9_b: 
+                    {
+                    if ( iDoublePause )
+                        {             
+                        iCamc->Record();
+                        CTimer::After( 2*60 * TInt32 ( 1E6 ) ); // Record 2 minutes
+                        iPaused = EFalse;
+                        iAction = K_VC_dsp_none;
+                        }
+                    else 
+                        {
+                        iCamc->Record();
+                        CTimer::After(  2*60 * TInt32 ( 1E6 ) ); // Record 2 minutes
+                        iPaused = EFalse;
+                        iDoublePause = ETrue;
+                        }
+                    break;
+                    }
+                case K_VC_dsp_test_case_12:
+                case K_VC_dsp_test_case_19:
+                    {
+                    iCamc->Record();
+                    iPaused = EFalse;  
+                    break;
+                    }
+                case K_VC_dsp_test_case_20:
+                    {
+                    iCamc->Record();
+                    CTimer::After( 15 * TInt32 ( 1E6 ) ); // Records for 15 sec.
+                    iPaused = EFalse;  
+                    iAction = K_VC_dsp_none;
+                    break;
+                    }
+                case K_VC_dsp_test_case_21:
+                    {
+                    iCamc->Record();
+                    CTimer::After( 30 * TInt32 ( 1E6 ) ); // Records for 30 sec.
+                    iPaused = EFalse;  
+                    iAction = K_VC_dsp_none;
+                    break;
+                    }
+                case K_VC_dsp_test_case_15:
+                    {
+                    if ( iDoublePause )
+                        {             
+                        iCamc->Record();
+                        iAction = K_VC_dsp_none;
+                        // Record until disk full
+                        }
+                    else 
+                        {
+                        iCamc->Record();
+                        CTimer::After(   2*60 * TInt32 ( 1E6 ) ); // Record 2 minutes
+                        iPaused = EFalse;
+                        iDoublePause = ETrue;
+                        }
+                    break;
+                    }
+                default:
+                    break;
+                }
+            }
+        else //timer
+            {
+            switch(iAction)
+                {     
+                case K_VC_dsp_test_case_7:
+                    {
+                    iCamc->PauseL();
+                    iPaused = ETrue;
+                    CTimer::After( 5 * TInt32 ( 1E6 ) ); // Pause 5 sec
+                    break;
+                    }
+                case K_VC_dsp_test_case_8: 
+                    {
+                    if ( i2ndTime )
+                        {
+                        // Volume down
+                        iCamc->SetGainL( 1 );
+                        iAction = K_VC_dsp_none;
+                        }
+                    else 
+                        {                
+                        // Volume Up
+                        TInt aSetGain;
+                        aSetGain = iCamc->MaxGainL();
+                        iCamc->SetGainL( aSetGain );
+                        CTimer::After( 15 * TInt32 ( 1E6 ) );
+                        i2ndTime = ETrue;            
+                        }
+                    break;
+                    }
+                case K_VC_dsp_test_case_9_a:      
+                case K_VC_dsp_test_case_9_b:      
+                case K_VC_dsp_test_case_15:
+                    {
+                    iCamc->PauseL();
+                    iPaused = ETrue;          
+                    
+                    if ( i2ndTime )
+                        {
+                        CTimer::After( 30 * TInt32 ( 1E6 ) ); // Pauses for 30s
+                        }
+                    else 
+                        {                
+                        CTimer::After( 10 * TInt32 ( 1E6 ) ); // Pauses for 10s
+                        i2ndTime = ETrue;            
+                        }
+                    break;
+                    }
+                case K_VC_dsp_test_case_10:
+                    {
+                    iCamc->SetVideoBitRateL( VIDEO_BIT_RATE_10  );
+                    break;
+                    }
+                case K_VC_dsp_test_case_11:
+                case K_VC_dsp_test_case_17:
+                case K_VC_dsp_test_case_17_a:
+                    {
+                    iCamc->SetVideoBitRateL( VIDEO_BIT_RATE_11  );
+                    iAction = K_VC_dsp_none;
+                    break;
+                    }
+                case K_VC_dsp_test_case_12:
+                case K_VC_dsp_test_case_19:
+                case K_VC_dsp_test_case_20:
+                case K_VC_dsp_test_case_21:
+                    {
+                    iCamc->PauseL();
+                    iPaused = ETrue;
+                    CTimer::After( 10 * TInt32 ( 1E6 ) );
+                    break;
+                    }
+                case K_VC_dsp_test_case_16:
+                    {
+                    if(iStartRecording2ndTime)
+                        {
+                        iPrepareReady = ETrue;    
+                        CTimer::After( 10 * TInt32 ( 1E6 ) );
+                        iAction = K_VC_dsp_none;    
+                        }
+                    else
+                        {
+                        iCamc->Stop();
+                        CTimer::After( 3 * TInt32 ( 1E6 ) );
+                        iStartRecording2ndTime = ETrue;
+                        }
+                    break;
+                    }
+                default:
+                    iCamc->Stop();
+                    // Simulates that iRecording has been completed through the 
+                    // MvruoRecordComplete callback
+                    iRecordingReady=ETrue;				
+                    CTimer::After( 1 * TInt32 ( 1E6 ) );
+                    
+                }
+            }
+        
+}
+
+void CCamcTestClient_visualcheckdsp::DoCancel()
+    {
+    iCamc->Stop();
+    iCamc->Close();
+    delete iCamc;
+    iCamc = NULL;
+    }
+
+void CCamcTestClient_visualcheckdsp::MvruoOpenComplete( TInt aError )
+    {
+    if (aError)
+        {        
+        SomethingInActiveObjectIsLeaving(aError);
+        }
+    else
+        {
+        iOpenReady = ETrue;
+        RunL(); // RunL is trapped, cannot actually leave.
+        }
+    }
+
+void CCamcTestClient_visualcheckdsp::MvruoPrepareComplete( TInt aError )
+    {    
+    if (aError)
+        {
+        SomethingInActiveObjectIsLeaving(aError);
+        }
+    else
+        {
+        iPrepareReady = ETrue;
+        RunL(); // RunL is trapped, cannot actually leave.
+        }
+    }
+
+void CCamcTestClient_visualcheckdsp::MvruoRecordComplete( TInt aError )
+    {
+#ifdef _DEBUG
+    RDebug::Print(_L("CamCTestClient VisualCheck:Record Complete"));
+#endif
+    if ((aError) && (aError != KErrCompletion))
+        {
+        SomethingInActiveObjectIsLeaving(aError);
+        }
+    else
+        {
+        iRecordingReady = ETrue;
+        RunL(); // RunL is trapped, cannot actually leave.
+        }
+    }
+
+void CCamcTestClient_visualcheckdsp::MvruoEvent(const TMMFEvent& /*aEvent*/) 
+    {
+    /* Should be never called ... */  
+    SomethingInActiveObjectIsLeaving(99);
+    }
+
+void CCamcTestClient_visualcheckdsp::SomethingInActiveObjectIsLeaving (TInt aError)
+    {
+    
+#ifdef _DEBUG
+    RDebug::Print(_L("CamCTestClient VisualCheck: SomethingInActiveObjectIsLeaving "));
+#endif
+    // Something in the active object is leaving
+    // or a fatal error has been found.
+    
+    // Stop the active object scheduler.
+    iError=aError;
+    iCamc->Stop();
+    CActiveScheduler::Stop();
+    }
+
+
+