mmshplugins/mmcctranscoder/tsrc/stubs/inc/mmcctranscoder.h
changeset 22 496ad160a278
parent 0 f0cf47e981f9
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/mmshplugins/mmcctranscoder/tsrc/stubs/inc/mmcctranscoder.h	Fri Jun 11 13:36:18 2010 +0300
@@ -0,0 +1,156 @@
+/*
+* Copyright (c) 2007 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:  Plugin interface to be implemented in order to get transcoding
+*                functionality
+*
+*/
+
+
+#ifndef MCCTRANSCODER_H
+#define MCCTRANSCODER_H
+
+//  INCLUDES
+#include <e32base.h>
+#include <e32std.h>
+#include <mmccevents.h>
+
+// CLASS DECLARATION
+class CMccTranscoderImpl;
+
+// CONSTS
+
+// Plugin Interface UID
+#define KMmfUidPluginInterfaceMccTranscoder  0x10282898
+
+/**
+* Class for setting up codec values for transcoding.
+*/  
+class TMccTranscoderCodecInfo
+	{
+    public:
+		TUint32 iBitrate;
+		TReal iFramerate;
+		TUint32 iVideoWidth; 
+		TUint32 iVideoHeight;
+		TUint32 iSamplingFreq; 
+		TBuf8<256> iMimeType;
+		TUid iFourCC; 
+		TUint32 iReserved1; 
+		TUint32 iReserved2; 
+	};
+
+/**
+* Class for setting up transcoding.
+*/  
+class TMccTranscodeFileMsg
+    {
+    public:
+    
+        TFileName  iSourceFile;
+        
+        TFileName  iDesFile;
+        
+        TUint32    iQuality;
+        
+        TMccTranscoderCodecInfo iVideoCodec;
+        
+        TMccTranscoderCodecInfo iAudioCodec;
+    };
+    
+typedef TPckgBuf<TMccTranscodeFileMsg> TMccTranscodeFileMsgBuffer; 
+
+
+/**
+*  Observer interface for clients to receive events from transcoder.
+*/
+class MMccTranscoderObserver
+    {
+	public:
+    
+    /**
+    * Callback function to receive transcoder events
+    * @param aEvent Received transcoder events
+    */
+    virtual void MccTranscoderEventReceived( TMccEvent& aEvent ) = 0;
+    };
+    
+/**
+*  MCC subsystem transcoder interface. Class is used for transcoding audio and video
+*  files from one codec to another. Transcoding can be also done with old codec in order
+*  to change bitrate.
+*/
+class CMccTranscoder : public CBase
+    {
+    public:  // Constructors and destructor
+        /**
+        * Two-phased constructor.
+        */
+        static CMccTranscoder* NewL();
+
+        /**
+        * Destructor.
+        */
+        virtual ~CMccTranscoder();
+
+    public:  // New functions
+
+       /**
+        * Registers observer for transcoding events.
+        * @param aObserver observer for transcoding events.
+        */
+        virtual void RegisterEventObserver( MMccTranscoderObserver& aObserver );
+        
+       /**
+        * Unregisters observer for transcoding events.
+        */
+        virtual void UnregisterEventObserver();
+       
+       /**
+        * Starts transcoding of media file.
+        * @param aSessionId session identifier for transcoding, updated on return
+        * @param aVal TMccTranscodeFileMsgBuffer containing transcode parameters
+        */
+        virtual void TranscodeFileL( TUint32& aSessionId, const TDesC8& aVal );
+        
+       /**
+        * Cancels transcoding of media file.
+        * @param aSessionId session identifier for transcoding
+        */
+        virtual void CancelTranscodeFileL( TUint32 aSessionId );
+    
+    private:
+        /**
+        * C++ default constructor.
+        */
+        CMccTranscoder();
+
+        /**
+        * By default Symbian 2nd phase constructor is private.
+        *
+        * @param aSource    Source of the data for the payload format plugin
+        */
+        void ConstructL();
+
+    private:    // data
+        CMccTranscoderImpl* iTranscoderImpl;
+        
+    private:    // Friend classes
+    
+    #ifdef EUNIT_TEST
+       friend class UT_CMccTranscoder;
+    #endif
+        
+    };
+
+#endif