devsound/devsoundrefplugin/src/swcodecwrapper/mmfSwCodecUtility.cpp
author hgs
Fri, 08 Oct 2010 19:40:43 +0100
changeset 0 79dd3e2336a0
permissions -rw-r--r--
2010wk36_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     1
// Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     2
// All rights reserved.
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     7
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     8
// Initial Contributors:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    10
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    11
// Contributors:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    12
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    13
// Description:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    14
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    15
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    16
#include <e32std.h>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    17
#include "mmfSwCodecUtility.h"
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    18
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    19
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    20
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    21
/******************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    22
 * CMMFSwCodecUtility
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    23
 ******************************************************************/
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    24
CMMFSwCodecUtility::CMMFSwCodecUtility()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    25
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    26
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    27
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    28
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    29
CMMFSwCodecUtility::~CMMFSwCodecUtility()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    30
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    31
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    32
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    33
CMMFSwCodecUtility* CMMFSwCodecUtility::NewL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    34
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    35
	CMMFSwCodecUtility* self = new(ELeave) CMMFSwCodecUtility();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    36
	CleanupStack::PushL(self);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    37
	self->ConstructL();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    38
	CleanupStack::Pop();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    39
	return self;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    40
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    41
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    42
void CMMFSwCodecUtility::ConstructL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    43
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    44
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    45
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    46
void CMMFSwCodecUtility::ConfigAudioRamper(TInt64 aRampTime, TInt aSampleRate, TInt aChannels)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    47
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    48
	iRampSamples = I64LOW(((TInt64(aSampleRate) * aRampTime) /1000000 )); // Add this
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    49
	iRampSamplesLeft = iRampSamples;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    50
	iChannels = aChannels;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    51
	iRampIncr = 0;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    52
	iSkip = ETrue;	                       
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    53
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    54
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    55
TBool CMMFSwCodecUtility::RampAudio(CMMFDataBuffer* aBuffer)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    56
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    57
	TInt i=0;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    58
	TInt length = aBuffer->Data().Length()>>1;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    59
	TInt16* sample = REINTERPRET_CAST(TInt16*,&aBuffer->Data()[0]);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    60
	TInt64 theResult(0);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    61
	while ((i < length) && (iRampIncr < iRampSamples))
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    62
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    63
		theResult = sample[i];
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    64
		theResult *= iRampIncr;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    65
		theResult /= iRampSamples;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    66
		sample[i] = STATIC_CAST(TInt16, I64LOW(theResult) );
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    67
          
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    68
		if ((iChannels == 1) || (!iSkip))
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    69
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    70
			iRampIncr++;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    71
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    72
		iSkip = !iSkip;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    73
		i++;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    74
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    75
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    76
	if (iRampIncr < iRampSamples)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    77
		return ETrue;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    78
	else
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    79
		return EFalse;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    80
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    81
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    82