multimediacommsengine/tsrc/mccstub/inc/mmcccodecamrwb.h
changeset 0 1bce908db942
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/multimediacommsengine/tsrc/mccstub/inc/mmcccodecamrwb.h	Tue Feb 02 01:04:58 2010 +0200
@@ -0,0 +1,221 @@
+/*
+* Copyright (c) 2004 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:    Class is used for configuring AMR WB codec.
+*
+*/
+
+
+
+
+#ifndef __MCC_CODEC_AMR_WB_H__
+#define __MCC_CODEC_AMR_WB_H__
+
+//  INCLUDES
+#include "mmcccodecamr.h"
+
+// CONSTANTS
+
+// AMR-WB Codec possible bitrates
+const TInt KAmrWbBitrate660( 6600 );
+const TInt KAmrWbBitrate885( 8850 );
+const TInt KAmrWbBitrate1265( 12650 );
+const TInt KAmrWbBitrate1425( 14250 );
+const TInt KAmrWbBitrate1585( 15850 );
+const TInt KAmrWbBitrate1825( 18250 );
+const TInt KAmrWbBitrate1985( 19850 );
+const TInt KAmrWbBitrate2305( 23050 );
+const TInt KAmrWbBitrate2385( 23850 );
+
+const TUint KMccAllowedAmrWbBitrate660     = 0x0001;
+const TUint KMccAllowedAmrWbBitrate885     = 0x0002;
+const TUint KMccAllowedAmrWbBitrate1265    = 0x0004;
+const TUint KMccAllowedAmrWbBitrate1425    = 0x0008;
+const TUint KMccAllowedAmrWbBitrate1585    = 0x0010;
+const TUint KMccAllowedAmrWbBitrate1825    = 0x0020;
+const TUint KMccAllowedAmrWbBitrate1985    = 0x0040;
+const TUint KMccAllowedAmrWbBitrate2305    = 0x0080;
+const TUint KMccAllowedAmrWbBitrate2385    = 0x0100;
+const TUint KMccAllowedAmrWbBitrateAll     = 0x0FFF;
+
+// Allowed bitrates bitfield can contain additional information
+const TUint KMccAllowedAmrWbAdditionalInfo   = 0xF000;
+
+// If this bit is not present, mode-change-period=1
+const TUint KMccAllowedAmrWbModeChangePeriod2   = 0x1000;
+
+// If this bit is not present, mode-change-neighbor=0
+const TUint KMccAllowedAmrWbModeChangeNeighbor1 = 0x2000;
+
+const TUint KAmrWbSamplingFreq( 16000 );
+
+const TInt KAMRMode8( 8 );
+
+const TInt KAmrWbDefaultFrameSize( 64 );
+
+// CLASS DECLARATION
+/**
+*  Container class for the codec information.
+*
+*  @lib MCCInterface.dll
+*  @since Series 60 3.0
+*/
+NONSHARABLE_CLASS( CMccCodecAmrWb ) : public CMccCodecAMR
+    {
+    public:  // Constructors and destructor
+
+        /**
+        * Two-phased constructor.
+        */
+        static CMccCodecAmrWb* NewL();
+        
+        /**
+        * Destructor.
+        */
+        virtual ~CMccCodecAmrWb();
+        
+    public: // New functions
+    
+    public: // From CMccCodecInformation 
+
+        /**
+        * From CMccCodecInformation
+        */
+        CMccCodecInformation* CloneDefaultsL();
+        
+        /**
+        * From CMccCodecInformation
+        */
+        CMccCodecInformation* CloneDetailedL();
+        
+    private:
+        /**
+        * C++ default constructor.
+        */
+        CMccCodecAmrWb();
+
+        /**
+        * By default Symbian 2nd phase constructor is private.
+        */
+        void ConstructL();
+    
+    
+    /**
+    *   Set functions
+    */          
+    public: 
+
+        /**
+        * From CMccCodecInformation. Sets bitrate used with codec.
+        * @since     Series 60 3.0
+        * @param     aBitrate     New bitrate value
+        * @return    KErrNotSupported if codec doesn't support bitrate value issued; otherwise KErrNone.
+        */
+        TInt SetBitrate( TUint aBitrate );
+        
+        /**
+        * From CMccCodecInformation. Sets the bitrate from the mode set .
+        * @since     Series 60 3.0
+        * @param     aBitrate     The mode set
+        * @return    mode set value
+        */
+        void SetBitrateModeSet( TUint aModeSet );
+        
+        /**
+        * From CMccCodecInformation. Sets the sampling frequency.
+        * @since    Series 60 3.0
+        * @param    aSamplingFreq   Sampling frequency to be used
+        * @return   KErrNotSupported if codec doesn't support sampling frequency issued; otherwise KErrNone.
+        */
+        TInt SetSamplingFreq( TUint32 aSamplingFreq );
+
+        /**
+        * From CMccCodecInformation. Sets the sdp name.
+        * @since Series 60 3.0
+        * @param aRtpId - [input] RTP session ID
+        * @return One of the standard system-wide error codes.
+        */
+        TInt SetSdpName( const TDesC8& aSdpName );
+               
+        /**
+        * Sets the allowed bitrates for the codec.
+        * @since Series 60 3.0
+        * @param aBitrateMask bitrate mask.
+        * @return KErrNotSupported if codec doesnt' support the bitrate mask
+        *     value issued; otherwise KErrNone.
+        */
+        TInt SetAllowedBitrates( TUint aBitrateMask );
+
+
+    protected: // From CMccCodecAMR 
+     
+        /**
+        * Sets bitrate used with codec.
+        * @since Series 60 3.0
+        * @param aBitrateMask bitrate mask, sets the largest bitrate
+        * @return KErrNotSupported if codec doesn't support bitrate value
+        *     issued; otherwise KErrNone.
+        */
+        TInt SetBitrateFromBitrateMask( TUint aBitrateMask ); 
+        
+        /**
+        * From CMccCodecInformation. Gets the mode set of a bitrate.
+        * @since     Series 60 3.0
+        * @param     aBitrate     The bitrate value
+        * @return     mode set value
+        */
+        TInt GetBitrateModeSet( TUint aBitrate );
+        
+        /**
+        * From CMccCodecInformation. Gets the bitrate mask from the mode set .
+        * @since     Series 60 3.0
+        * @param     aMode The mode set
+        * @param    aBitrateMask reference to bitrateMask
+        * @return KErrNotSupported if codec doesnt' support the bitrate mask
+        *     value issued; otherwise KErrNone.
+        */
+        TInt GetBitrateMaskFromMode( TUint aMode, TUint& aBitrateMask  );
+
+    
+        /**
+        * Gets the allowed bitrates for the codec.
+        * @since  Series 60 3.0
+        * @param  aBitrateMask RArray<TUint> reference 
+        * @return KErrNotSupported if codec doesnt' support the function
+        *         otherwise KErrNone.
+        */
+        TInt GetAllowedBitratesArrayL( RArray<TUint>& aBitratesArray );
+        
+    protected:  // New functions
+    
+    protected:  // Functions from base classes
+
+        
+    public:     // Data    
+    
+    protected:  // Data
+    
+    private:    // Data  
+        
+private:
+
+    #ifdef TEST_EUNIT
+        friend class UT_CMccCodecAmrWb;
+    #endif
+      
+    };
+
+
+#endif      // __MCC_CODEC_AMR_WB_H__
+
+// End of File