devsound/a3fdevsound/src/devsoundadaptor/cdevplaycontrol.h
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) 2006-2009 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:
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
#ifndef CDEVPLAYCONTROL_H
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
#define CDEVPLAYCONTROL_H
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
#include <e32base.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
#include "cdevcommoncontrol.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
#include <a3f/maudiodatasupplier.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
#include <a3f/maudioprocessingunitobserver.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
#include <a3f/a3f_trace_utils.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
class MMMFBufferSource;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
 * CDevPlayControl.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
 *
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
 * ?description
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
 *
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
 * @lib mmfdevsoundadaptation.lib
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
 * @since
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
NONSHARABLE_CLASS(CDevPlayControl) :public CDevCommonControl,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
									public MMMFAudioDataSupplier
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
public:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    50
	* Destructor.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    51
	* Releases all resources and deletes all objects owned by this instance.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    52
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
	~CDevPlayControl();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
	static CDevPlayControl* NewL(CDevAudio* aDevAudio, MDevSoundAdaptationObserver& aDevSoundObserver);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
	void ConstructL(CDevAudio* aDevAudio, MDevSoundAdaptationObserver& aAdaptationObserver);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
	// from base class CDevAudioControl
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
	* Initialize playing state control components
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
	* @since
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
	* @return error code
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
	virtual TInt Initialize(TUid aFormat);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
	* Initializes the audio device and starts the play process. This
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
	* function queries and acquires the audio policy before initializing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
	* audio device. If there was an error during policy initialization,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
	* PlayError() function will be called on the observer with error code
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
	* KErrAccessDenied, otherwise BufferToBeFilled() function will be called
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
	* with a buffer reference. After reading data into the buffer reference
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
	* passed, the client should call PlayData() to play data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
	* The amount of data that can be played is specified in
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
	* CMMFBuffer::RequestSize(). Any data that is read into buffer beyond
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
	* this size will be ignored.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
	* Leaves on failure.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
	* @since
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
	* @return void
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
	virtual TInt ProcessInit();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
	* Plays data in the buffer at the current volume.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
	* The client should fill the buffer with audio data before calling this
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
	* function. The observer gets a reference to the buffer along with the
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
	* callback function BufferToBeFilled(). When playing of the audio sample
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
	* is complete, successfully or otherwise, the function PlayError() on
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
	* the observer is called.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
	* The last buffer of the audio stream being played should have the last
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
	* buffer flag set using CMMFBuffer::SetLastBuffer(TBool). If a
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
	* subsequent attempt to play the clip is made, this flag will need
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
	* resetting by the client.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
	* @return void
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
	virtual void ProcessData();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
	/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
	Call-back indicating that is the last buffer has been processed
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
	virtual void ProcessingFinished (MAudioStream& aStream);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
	// from base class MAudioDataSupplier
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
	* Request a buffer to be filled with audio data by the data supplier.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
	*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
	* The supplier should fill the buffer as quickly as possible and then call
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
	* MBufferSource::BufferFilled() passing the filled buffer as a parameter.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
	*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
	* @param aSource a pointer to the source requesting the buffer
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
	* @param aBuffer a pointer to the buffer to fill
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
	virtual void BufferToBeFilled(MMMFBufferSource* aSource, CMMFBuffer* aBuffer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
	* Indicates that all buffers previously requested by this source have become
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
	* invalid and must not be used.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
	*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
	* @param aSource the source whose previous buffer requests should be ignored.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
	virtual void DiscardBuffers(MMMFBufferSource* aSource);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
	// from base class CDevCommonControl
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
	void FinishWithError(TInt aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
	* Called when a ProcessingFinished callback is received
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
	*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
	* @since
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
	* @param TBool& aAyncCompletion
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
	* @return an error code KErrNone if successful
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
	virtual TInt ProcessingFinishedReceived(TBool& aAyncCompletion);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
	/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
	Used to send a stop call when there is a error in the buffer
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
	void BufferErrorEvent();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   142
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   143
	virtual TInt ProcessingError(TBool& aAyncCompletion);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   144
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   145
private:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
	CDevPlayControl();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
private: // data
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
	/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
	* Casted convenience pointer to DevAudio::iAudioSource
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
	* Not own.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
	*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
	MMMFBufferSource *iBufferSource;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
	};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
#endif // CDEVPLAYCONTROL_H