devsoundextensions/effects/SrcDoppler/SourceDopplerProxy/Src/SourceDopplerProxy.cpp
author hgs
Tue, 02 Nov 2010 12:28:51 +0000
changeset 6 fe9d1bf55678
parent 0 b8ed18f6c07b
permissions -rw-r--r--
2010wk46_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     1
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     2
* Copyright (c) 2004 Nokia Corporation and/or its subsidiary(-ies). 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     3
* All rights reserved.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     8
*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     9
* Initial Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    11
*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    12
* Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    13
*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    14
* Description:   Implementation of the Source Doppler Proxy class
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    15
*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    16
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    17
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    18
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    21
// INCLUDE FILES
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
#ifdef _DEBUG
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
#include <e32svr.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
#endif
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
#include "SourceDopplerProxy.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
#include "SourceDopplerEventObserver.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
#include <CustomInterfaceUtility.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
// ============================ MEMBER FUNCTIONS ===============================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
// CSourceDopplerProxy::CSourceDopplerProxy
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
// C++ default constructor can NOT contain any code, that
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
// might leave.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
CSourceDopplerProxy::CSourceDopplerProxy(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
	TMMFMessageDestinationPckg aMessageHandler,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
	MCustomCommand& aCustomCommand,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
	CCustomInterfaceUtility* aCustomInterfaceUtility )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
	: 	iCustomCommand(&aCustomCommand),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
		iMessageHandler(aMessageHandler),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
		iCustomInterfaceUtility(aCustomInterfaceUtility)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    50
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    51
// Destructor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    52
CSourceDopplerProxy::~CSourceDopplerProxy()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
    // Remove the custom interface message handler before we destroy the proxy.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
    if(iCustomInterfaceUtility)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
        iCustomInterfaceUtility->RemoveCustomInterface(iMessageHandler);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
	delete iDopplerEventObserver;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
	delete iCustomInterfaceUtility;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
// CSourceDopplerProxy::NewL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
// Static function for creating an instance of the SourceDoppler object.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
EXPORT_C CSourceDopplerProxy* CSourceDopplerProxy::NewL(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
	TMMFMessageDestinationPckg aMessageHandler,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
    MCustomCommand& aCustomCommand,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
    CCustomInterfaceUtility* aCustomInterfaceUtility )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
    CSourceDopplerProxy* self = new (ELeave) CSourceDopplerProxy(aMessageHandler, aCustomCommand, aCustomInterfaceUtility);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
    CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
    self->ConstructL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
    CleanupStack::Pop(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
    return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
// CSourceDopplerProxy::ConstructL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
void CSourceDopplerProxy::ConstructL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
    iDopplerEventObserver = CSourceDopplerEventObserver::NewL(iMessageHandler, *iCustomCommand, *this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
    StartObserver();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
    TEfDopplerDataPckg dataPckgFrom;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
    // sends a message to fetch initial data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
	iCustomCommand->CustomCommandSync(iMessageHandler, (TInt)ESourceDopplerOfInitialize, KNullDesC8, KNullDesC8, dataPckgFrom);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
	SetEffectData(dataPckgFrom);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
// CSourceDopplerProxy::ApplyL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
// Apply the SourceDoppler settings.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
EXPORT_C void CSourceDopplerProxy::ApplyL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
#ifdef _DEBUG
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
    RDebug::Print(_L("CSourceDopplerProxy::Apply"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
#endif
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
	if (iHaveUpdateRights )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
		iDopplerData.iEnabled = iEnabled;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
		iDopplerData.iEnforced = iEnforced;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
		iDopplerData.iHaveUpdateRights = iHaveUpdateRights;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
		iCustomCommand->CustomCommandSync(iMessageHandler, (TInt)ESourceDopplerOfApply, DoEffectData(), KNullDesC8);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
		User::Leave(KErrAccessDenied);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
// CSourceDopplerProxy::StartObserver
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
// Starts the event observer. The event observer monitors asynchronous events
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
// from the message handler.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
void CSourceDopplerProxy::StartObserver()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
#ifdef _DEBUG
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
    RDebug::Print(_L("CSourceDopplerProxy::StartObserver"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
#endif
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
	iDopplerEventObserver->Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
// CSourceDopplerProxy::DopplerEvent
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
// Checks which data member has changed and notify the observers.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
void CSourceDopplerProxy::SourceDopplerEvent(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
	const TDesC8& aBuffer )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   142
#ifdef _DEBUG
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   143
    RDebug::Print(_L("CSourceDopplerProxy::SourceDopplerEvent"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   144
#endif
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   145
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
	TEfDopplerDataPckg dataPckgFrom;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
	dataPckgFrom.Copy(aBuffer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
	TEfDoppler newDopplerData = dataPckgFrom();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
	TUint8 event = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
	if ( newDopplerData.iEnabled != iDopplerData.iEnabled )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
		iDopplerData.iEnabled = newDopplerData.iEnabled;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
		iEnabled = newDopplerData.iEnabled;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
		if ( iDopplerData.iEnabled )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
			event = MAudioEffectObserver::KEnabled;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   159
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   160
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   161
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   162
			event = MAudioEffectObserver::KDisabled;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   163
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   164
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   165
	else if ( newDopplerData.iEnforced != iDopplerData.iEnforced )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   166
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   167
		iDopplerData.iEnforced = newDopplerData.iEnforced;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   168
		iEnforced = newDopplerData.iEnforced;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   169
		if ( iDopplerData.iEnforced )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   170
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   171
			event = MAudioEffectObserver::KEnforced;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   172
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   173
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   174
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   175
			event = MAudioEffectObserver::KNotEnforced;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   176
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   177
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   178
	else if ( newDopplerData.iHaveUpdateRights != iDopplerData.iHaveUpdateRights )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   179
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   180
		iDopplerData.iHaveUpdateRights = newDopplerData.iHaveUpdateRights;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   181
		iHaveUpdateRights = newDopplerData.iHaveUpdateRights;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   182
		if ( iDopplerData.iHaveUpdateRights )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   183
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   184
			event = MAudioEffectObserver::KGainedUpdateRights;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   185
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   186
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   187
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   188
			event = MAudioEffectObserver::KLostUpdateRights;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   189
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   190
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   191
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   192
		else if ( newDopplerData.iVelocityX != iDopplerData.iVelocityX )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   193
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   194
			iDopplerData.iVelocityX = newDopplerData.iVelocityX;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   195
			event = MSourceDopplerObserver::KCartesianVelocityChanged;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   196
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   197
		else if ( newDopplerData.iVelocityY != iDopplerData.iVelocityY )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   198
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   199
			iDopplerData.iVelocityY = newDopplerData.iVelocityY;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   200
			event = MSourceDopplerObserver::KCartesianVelocityChanged;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   201
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   202
		else if ( newDopplerData.iVelocityZ != iDopplerData.iVelocityZ )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   203
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   204
			iDopplerData.iVelocityZ = newDopplerData.iVelocityZ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   205
			event = MSourceDopplerObserver::KCartesianVelocityChanged;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   206
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   207
		else if ( newDopplerData.iAzimuth != iDopplerData.iAzimuth )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   208
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   209
			iDopplerData.iAzimuth = newDopplerData.iAzimuth;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   210
			event = MSourceDopplerObserver::KSphericalVelocityChanged;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   211
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   212
		else if ( newDopplerData.iElevation != iDopplerData.iElevation )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   213
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   214
			iDopplerData.iElevation = newDopplerData.iElevation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   215
			event = MSourceDopplerObserver::KSphericalVelocityChanged;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   216
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   217
		else if ( newDopplerData.iRadius != iDopplerData.iRadius )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   218
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   219
			iDopplerData.iRadius = newDopplerData.iRadius;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   220
			event = MSourceDopplerObserver::KSphericalVelocityChanged;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   221
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   222
		else if ( newDopplerData.iFactor != iDopplerData.iFactor )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   223
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   224
			iDopplerData.iFactor = newDopplerData.iFactor;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   225
			event = MSourceDopplerObserver::KFactorChanged;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   226
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   227
		else if ( newDopplerData.iMaxFactor != iDopplerData.iMaxFactor )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   228
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   229
			iDopplerData.iMaxFactor = newDopplerData.iMaxFactor;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   230
			event = MSourceDopplerObserver::KMaxFactorChanged;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   231
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   232
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   233
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   234
	if (!event)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   235
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   236
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   237
	for ( TInt i = 0; i < iObservers.Count(); i++ )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   238
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   239
		iObservers[i]->EffectChanged(this, event);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   240
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   241
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   242
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   243
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   244
// ========================== OTHER EXPORTED FUNCTIONS =========================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   245
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   246
// End of File
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   247