mmaudio_pub/drm_audio_player_api/tsrc/DRMAudioPlay/src/SimpleSoundPlayer.cpp
changeset 0 b8ed18f6c07b
child 5 b220a9341636
equal deleted inserted replaced
-1:000000000000 0:b8ed18f6c07b
       
     1 /*
       
     2 * Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies).
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description: DRM Player
       
    15 *
       
    16 */
       
    17 
       
    18 #include "SimpleSoundPlayer.h"
       
    19 
       
    20 const TInt CSimpleSoundPlayer::KPlayerActionPlay = 1;
       
    21 const TInt CSimpleSoundPlayer::KPlayerActionPause = 2;
       
    22 const TInt CSimpleSoundPlayer::KPlayerActionStopPlayFile = 3;
       
    23 const TInt CSimpleSoundPlayer::KPlayerActionReportPosition = 4;
       
    24 const TInt CSimpleSoundPlayer::KPlayerActionReportDuration = 5;
       
    25 const TInt CSimpleSoundPlayer::KPlayerActionStopPlayDes = 6;
       
    26 const TInt CSimpleSoundPlayer::KPlayerActionReportVolume = 7;
       
    27 const TInt CSimpleSoundPlayer::KPlayerActionStopPlayUrl = 8;
       
    28 const TInt CSimpleSoundPlayer::KPlayerActionStopPlayFileHandler = 9;
       
    29 const TInt CSimpleSoundPlayer::KPlayerActionOpen = 10;
       
    30 const TInt CSimpleSoundPlayer::KPlayerActionOpenFileHandler = 11;
       
    31 const TInt CSimpleSoundPlayer::KplayerActionSetVolume = 12;
       
    32 const TInt CSimpleSoundPlayer::KplayerActionGetBalance = 13;
       
    33 const TInt CSimpleSoundPlayer::KplayerActionGetBitRate = 14;
       
    34 const TInt CSimpleSoundPlayer::KplayerActionGetAudioLoadingProgress = 15;
       
    35 const TInt CSimpleSoundPlayer::KplayerActionRegisterForAudioLoadingNotification = 16;
       
    36 const TInt CSimpleSoundPlayer::KplayerActionControllerImplementationInformation = 17;
       
    37 const TInt CSimpleSoundPlayer::KplayerActionMaxVolume = 18;
       
    38 const TInt CSimpleSoundPlayer::KplayerActionSetBalance = 19;
       
    39 const TInt CSimpleSoundPlayer::KplayerActionSetPriority = 20;
       
    40 const TInt CSimpleSoundPlayer::KplayerActionSetRepeats = 21;
       
    41 const TInt CSimpleSoundPlayer::KPlayerActionGetMetaDataEntry = 22;
       
    42 const TInt CSimpleSoundPlayer::KPlayerActionGetNumberOfMetaDataEntries = 23;
       
    43 
       
    44 
       
    45 CSimpleSoundPlayer::CSimpleSoundPlayer(CTestModuleIf &aConsole, CStifLogger &aLogger, TBool aImmediate, TBool aFileType)
       
    46 			: iConsole(aConsole) , iImmediate(aImmediate) , iLogger(aLogger) , iSoundOpen(EFalse),
       
    47 				iFinalError(KErrNone), iFileType(aFileType)
       
    48 	{
       
    49 	iSupervisor =0 ;
       
    50 	iEventTarget=0;
       
    51 	iParameters =0;
       
    52 	iPlayerId =0 ;
       
    53 	iPlayVolume = false;
       
    54 	iMetaInfo = false;
       
    55 	iMetaInfoTest = false;
       
    56 	iPlayWindow = false;
       
    57 	iClearWindow = false;
       
    58 	iSetBalance = false;
       
    59 	iFsOpened = false;
       
    60 	iDontPlayAudioClip = false;
       
    61 	iIsLoopPlayEnabled = EFalse;
       
    62 	}
       
    63 
       
    64 void CSimpleSoundPlayer::ConstructUrlL(const TDesC &aUrl, TInt aIapId, const TDesC8 &aMime)
       
    65 	{
       
    66 	iMdaPlayer=CDrmPlayerUtility::NewL(*this, KAudioPriorityRealOnePlayer,
       
    67        							 TMdaPriorityPreference(KAudioPrefRealOneLocalPlayback));
       
    68 	//KUseDefaultIap
       
    69 	iMdaPlayer->OpenUrlL(aUrl, aIapId, aMime );
       
    70 	iSoundOpen=ETrue;
       
    71 
       
    72 	_LIT(KPlayerCreated, "SoundPlayerCreated");
       
    73 	iConsole.Printf(100, KPlayerCreated, KPlayerCreated);
       
    74 	}
       
    75 CSimpleSoundPlayer* CSimpleSoundPlayer::NewUrlL(const TDesC &aUrl, TInt aIapId, const TDesC8 &aMime, CTestModuleIf &aConsole, CStifLogger &aLogger, TBool aImmediate)
       
    76 	{
       
    77     CSimpleSoundPlayer* self = NewUrlLC(aUrl, aIapId, aMime, aConsole, aLogger, aImmediate);
       
    78 	CleanupStack::Pop(self);
       
    79     return self;
       
    80 	}
       
    81 CSimpleSoundPlayer* CSimpleSoundPlayer::NewUrlLC(const TDesC &aUrl, TInt aIapId, const TDesC8 &aMime, CTestModuleIf &aConsole, CStifLogger &aLogger, TBool aImmediate)
       
    82 	{
       
    83     CSimpleSoundPlayer* self = new (ELeave) CSimpleSoundPlayer(aConsole, aLogger, aImmediate);
       
    84     CleanupStack::PushL(self);
       
    85     self->ConstructUrlL(aUrl, aIapId, aMime);
       
    86     return self;
       
    87 	}
       
    88 
       
    89 
       
    90 void CSimpleSoundPlayer::ConstructL(const TDesC8 &aDescriptor)
       
    91 	{
       
    92 	// Create a file audio player utility instance
       
    93 	//iMdaPlayer=CMdaAudioPlayerUtility::NewFilePlayerL(aFile, *this);	//Para usar creación inmediata
       
    94 
       
    95 	if (iImmediate)
       
    96 		{
       
    97 		if (iFileType)
       
    98 			{
       
    99 			iMdaPlayer=CDrmPlayerUtility::NewDesPlayerReadOnlyL(aDescriptor,*this, KAudioPriorityRealOnePlayer,
       
   100 			        		TMdaPriorityPreference(KAudioPrefRealOneLocalPlayback));    //For inmediate instantiation
       
   101 			}
       
   102 		else
       
   103 			{
       
   104 			iMdaPlayer=CDrmPlayerUtility::NewDesPlayerL(aDescriptor,*this, KAudioPriorityRealOnePlayer,
       
   105 						        		TMdaPriorityPreference(KAudioPrefRealOneLocalPlayback));    //For inmediate instantiation
       
   106 			}
       
   107 
       
   108 	/*	iMdaPlayer=CDrmPlayerUtility::NewL(*this, KAudioPriorityRealOnePlayer,
       
   109        							 TMdaPriorityPreference(KAudioPrefRealOneLocalPlayback));		//Por Pasos
       
   110 		iMdaPlayer->OpenDesL(aDescriptor);
       
   111 		iSoundOpen=ETrue;	*/
       
   112 		}
       
   113 	else if (!iImmediate)
       
   114 		{
       
   115 		iMdaPlayer=CDrmPlayerUtility::NewL(*this, KAudioPriorityRealOnePlayer,
       
   116        							 TMdaPriorityPreference(KAudioPrefRealOneLocalPlayback));		//Por Pasos
       
   117 		iMdaPlayer->OpenDesL(aDescriptor);
       
   118 		iSoundOpen=ETrue;
       
   119 		}
       
   120 	_LIT(KPlayerCreated, "SoundPlayerCreated");
       
   121 	iConsole.Printf(100, KPlayerCreated, KPlayerCreated);
       
   122 	}
       
   123 CSimpleSoundPlayer* CSimpleSoundPlayer::NewL(const TDesC8 &aDescriptor, CTestModuleIf &aConsole, CStifLogger &aLogger, TBool aImmediate, TBool aDesReadOnly)
       
   124 	{
       
   125     CSimpleSoundPlayer* self = NewLC(aDescriptor, aConsole, aLogger, aImmediate, aDesReadOnly);
       
   126 	CleanupStack::Pop(self);
       
   127     return self;
       
   128 	}
       
   129 CSimpleSoundPlayer* CSimpleSoundPlayer::NewLC(const TDesC8 &aDescriptor, CTestModuleIf &aConsole, CStifLogger &aLogger, TBool aImmediate, TBool aDesReadOnly)
       
   130 	{
       
   131     CSimpleSoundPlayer* self = new (ELeave) CSimpleSoundPlayer(aConsole, aLogger, aImmediate, aDesReadOnly);
       
   132     CleanupStack::PushL(self);
       
   133     self->ConstructL(aDescriptor);
       
   134     return self;
       
   135 	}
       
   136 
       
   137 void CSimpleSoundPlayer::ConstructL(const TFileName &aFile)
       
   138 	{
       
   139 	// Create a file audio player utility instance
       
   140 	//iMdaPlayer=CMdaAudioPlayerUtility::NewFilePlayerL(aFile, *this);	//For inmediate instantiation
       
   141     if (iImmediate)
       
   142         {
       
   143         iMdaPlayer=CDrmPlayerUtility::NewFilePlayerL(aFile,*this, KAudioPriorityRealOnePlayer,
       
   144         		TMdaPriorityPreference(KAudioPrefRealOneLocalPlayback));    //For inmediate instantiation
       
   145         }
       
   146     else if (!iImmediate)
       
   147     	{
       
   148     	iImmediate = ETrue;
       
   149 		iMdaPlayer=CDrmPlayerUtility::NewL(*this, KAudioPriorityRealOnePlayer,
       
   150        							 TMdaPriorityPreference(KAudioPrefRealOneLocalPlayback));		//Instantiation by steps
       
   151 
       
   152 		if (iFileType)
       
   153 			{
       
   154 			TMMFileSource FileName = aFile;
       
   155 			iLogger.Log(_L("Opening file [%S] with FileType 1") , &FileName.Name());
       
   156 //			TRAPD(err1,iMdaPlayer->OpenFileL(FileName));
       
   157 			iMdaPlayer->OpenFileL(FileName);
       
   158 			}
       
   159 		else
       
   160 			{
       
   161 			iLogger.Log(_L("Opening file with FileType 0"));
       
   162 //			TRAPD(err,iMdaPlayer->OpenFileL(aFile));
       
   163 			iMdaPlayer->OpenFileL(aFile);
       
   164 			}
       
   165 
       
   166 		iSoundOpen=ETrue;
       
   167    		}
       
   168 
       
   169 	_LIT(KPlayerCreated, "SoundPlayerCreated");
       
   170 	iConsole.Printf(100, KPlayerCreated, KPlayerCreated);
       
   171 	}
       
   172 
       
   173 CSimpleSoundPlayer* CSimpleSoundPlayer::NewLC(const TFileName &aFile, CTestModuleIf &aConsole, CStifLogger &aLogger, TBool aImmediate, TBool aFileType)
       
   174 	{
       
   175     CSimpleSoundPlayer* self = new (ELeave) CSimpleSoundPlayer(aConsole, aLogger, aImmediate, aFileType);
       
   176     CleanupStack::PushL(self);
       
   177     self->ConstructL(aFile);
       
   178     return self;
       
   179 	}
       
   180 
       
   181 CSimpleSoundPlayer* CSimpleSoundPlayer::NewL(const TFileName &aFile, CTestModuleIf &aConsole, CStifLogger &aLogger, TBool aImmediate, TBool aFileType)
       
   182 	{
       
   183     CSimpleSoundPlayer* self = NewLC(aFile, aConsole, aLogger, aImmediate, aFileType);
       
   184 	CleanupStack::Pop(self);
       
   185     return self;
       
   186 	}
       
   187 
       
   188 void CSimpleSoundPlayer::ConstructL(const RFile &aFile)
       
   189 	{
       
   190 	// Create a file audio player utility instance
       
   191 	//iMdaPlayer=CMdaAudioPlayerUtility::NewFilePlayerL(aFile, *this);	//For inmediate instantiation
       
   192 
       
   193 	// iMdaPlayer=CDrmPlayerUtility::NewL(*this, KAudioPriorityRealOnePlayer, TMdaPriorityPreference(KAudioPrefRealOneLocalPlayback));		//Instantiation by steps
       
   194 	iMdaPlayer=CDrmPlayerUtility::NewL(*this, EMdaPriorityNormal, TMdaPriorityPreference(EMdaPriorityPreferenceTimeAndQuality));	
       
   195 	iMdaPlayer->OpenFileL(aFile);
       
   196 	iSoundOpen=ETrue;
       
   197 
       
   198 	_LIT(KPlayerCreated, "SoundPlayerCreated");
       
   199 	iConsole.Printf(100, KPlayerCreated, KPlayerCreated);
       
   200 	}
       
   201 
       
   202 CSimpleSoundPlayer* CSimpleSoundPlayer::NewLC(const RFile &aFile, CTestModuleIf &aConsole, CStifLogger &aLogger, TBool aImmediate)
       
   203 	{
       
   204     CSimpleSoundPlayer* self = new (ELeave) CSimpleSoundPlayer(aConsole, aLogger, aImmediate);
       
   205     CleanupStack::PushL(self);
       
   206     self->ConstructL(aFile);
       
   207     return self;
       
   208 	}
       
   209 
       
   210 CSimpleSoundPlayer* CSimpleSoundPlayer::NewL(const RFile &aFile, CTestModuleIf &aConsole, CStifLogger &aLogger, TBool aImmediate)
       
   211 	{
       
   212     CSimpleSoundPlayer* self = NewLC(aFile, aConsole, aLogger, aImmediate);
       
   213 	CleanupStack::Pop(self);
       
   214     return self;
       
   215 	}
       
   216 
       
   217 void CSimpleSoundPlayer::MdapcInitComplete(TInt aError, const TTimeIntervalMicroSeconds &/*aDuration*/)
       
   218 	{
       
   219 	iLogger.Log(_L("MapcInitComplete"));
       
   220 	if (iFsOpened)
       
   221 	    {
       
   222 		iFs.Close();
       
   223 		iFsOpened = false;
       
   224 	    }
       
   225 	if (iImmediate)
       
   226 		{
       
   227 		if (aError == KErrNone)
       
   228 			{
       
   229 			_LIT(KGonnaPlay, "MapcInitComplete, GoingToPlay");
       
   230 			_LIT(KGoing, "Going to");
       
   231 			_LIT(KDone, "Done Started Playing");
       
   232 			iConsole.Printf(100, KGonnaPlay, KGoing);
       
   233 			if (iPlayVolume)
       
   234 			{
       
   235 		//	TInt VolumeHigh;
       
   236 			iLogger.Log(_L("SetVolume") );
       
   237 			iMdaPlayer->SetVolume(iMdaPlayer->MaxVolume());
       
   238 			iLogger.Log(_L("SetVolume(iMdaPlayer->MaxVolume())  max=(%d)"),  iMdaPlayer->MaxVolume() );
       
   239 			}
       
   240 			if (iMetaInfo)
       
   241 			    {
       
   242 				TInt NumMetaDatas = 0;
       
   243 				TInt MetaDataError = iMdaPlayer->GetNumberOfMetaDataEntries(NumMetaDatas);
       
   244 				if ( MetaDataError )
       
   245 				    {	//Error getting meta data info
       
   246 					Exit(MetaDataError);
       
   247 				    }
       
   248 //				else
       
   249 				if (iMetaInfoTest)
       
   250 				    {	//No error yet
       
   251 					TInt currMetaDataIndex = 0;
       
   252 					CMMFMetaDataEntry* currMetaData = NULL;
       
   253 					for ( currMetaDataIndex=0 ; currMetaDataIndex < NumMetaDatas ; currMetaDataIndex++)
       
   254 					    {
       
   255 					    currMetaData = iMdaPlayer->GetMetaDataEntryL(currMetaDataIndex);
       
   256 						iLogger.Log(_L("MetaData[%d]: Name: [%S], Value: [%S]") , currMetaDataIndex , &(currMetaData->Name()) , &(currMetaData->Value()) );
       
   257 //						currMetaData = NULL;
       
   258 					    }
       
   259 					delete currMetaData;
       
   260 					currMetaData = NULL;
       
   261 				    }
       
   262 			    }
       
   263 			if (iPlayWindow)
       
   264 			    {
       
   265 				TInt err = iMdaPlayer->SetPlayWindow(iStartPosition, iEndPosition);
       
   266 				iLogger.Log(_L("SetPlayWindow, start=[%d]"),iStartPosition.Int64());
       
   267 				iLogger.Log(_L("SetPlayWindow, end=[%d]"), iEndPosition.Int64() );
       
   268 				iLogger.Log(_L("SetPlayWindow, error = [%d]"),err);
       
   269 				if (iClearWindow)
       
   270 				    {
       
   271 					iLogger.Log(_L("ClearPlayWindow"));
       
   272 					iMdaPlayer->ClearPlayWindow();
       
   273 				    }
       
   274 			    }
       
   275 			if (iSetBalance)
       
   276 			    {
       
   277 				SetBalance(iBalance);
       
   278 			    }
       
   279             if (iDontPlayAudioClip)
       
   280                 {
       
   281                 iState = EReady;
       
   282                 Exit(aError);
       
   283                 }
       
   284             else
       
   285                 {
       
   286                 iState = EPlaying;
       
   287                 iLastPlayTime.HomeTime();
       
   288                 iLastStopTime.HomeTime();
       
   289                 // do not manually set the position here. if play window is set then the position is set to 0 (iPosition)
       
   290                 // instead the position must be set to the play window start position otherwise it crashes. 
       
   291                 if (!iPlayWindow)
       
   292                     {
       
   293                     iLogger.Log(_L("Position before Play (%d)"), I64INT(iPosition.Int64())/1000000);
       
   294                     iMdaPlayer->SetPosition(iPosition);
       
   295                     }
       
   296                 iMdaPlayer->Play();
       
   297                 iLogger.Log(_L("Play() was called"));
       
   298                 iConsole.Printf(100, KGonnaPlay, KDone);
       
   299                 }
       
   300 			}
       
   301 		else
       
   302 			{
       
   303 			iLogger.Log(_L("InitError (%d)"), aError);
       
   304 			iState = ENotReady;
       
   305 			Exit(aError);
       
   306 			}
       
   307 		}
       
   308 	else
       
   309 		{
       
   310 		iLogger.Log(_L("InitComplete, error(%d)") , aError);
       
   311 		iState = aError ? ENotReady : EReady;
       
   312 		if (aError)
       
   313 			{
       
   314 			Exit(aError);
       
   315 			}
       
   316 		}
       
   317 	}
       
   318 
       
   319 TInt CSimpleSoundPlayer::Pause()
       
   320 	{
       
   321 	iLogger.Log(_L("Requested Pause"));
       
   322 	iState=EPaused;
       
   323 	iMdaPlayer->Pause();
       
   324 	return KErrNone;
       
   325 	}
       
   326 
       
   327 TInt CSimpleSoundPlayer::OpenL(const TFileName &aFileName , const TBool &aImmediate=ETrue)
       
   328 	{
       
   329 	TMMFileSource FileName = aFileName;
       
   330 //	TMMFileSource* FileName = aFileName;
       
   331 //	FileName->TMMFileSource((TDesC*)aFileName);//= (TMMSource*) aFileName;
       
   332 	iImmediate = aImmediate;
       
   333 //	Stop();
       
   334 //	iLogger.Log(_L("Stop before opening file"));
       
   335 
       
   336 	iLogger.Log(_L("Opening [%S]") , &aFileName);
       
   337 	iMdaPlayer->OpenFileL(FileName);
       
   338 	iSoundOpen=ETrue;
       
   339 	iLogger.Log(_L("Opened"));
       
   340 	return KErrNone;
       
   341 	}
       
   342 
       
   343 TInt CSimpleSoundPlayer::OpenFileHandlerL(const TFileName &aFileName , const TBool &aImmediate=ETrue)
       
   344 	{
       
   345 	iImmediate = aImmediate;
       
   346 //	Stop();
       
   347 //	iLogger.Log(_L("Stop before opening file"));
       
   348 
       
   349 	iLogger.Log(_L("Opening [%S]") , &aFileName);
       
   350 
       
   351 //	RFs aFs;
       
   352 //	RFile aFileHandler;
       
   353 	User::LeaveIfError(iFs.Connect());
       
   354 	iFs.ShareProtected();
       
   355 
       
   356 	User::LeaveIfError(iFileHandler.Open( iFs, aFileName, EFileRead));
       
   357 	iMdaPlayer->OpenFileL(iFileHandler);
       
   358 
       
   359 	iFileHandler.Close();
       
   360 	iFsOpened = ETrue;
       
   361 //	aFs.Close();
       
   362 
       
   363 	iSoundOpen=ETrue;
       
   364 	iLogger.Log(_L("Opened"));
       
   365 	return KErrNone;
       
   366 	}
       
   367 
       
   368 TInt CSimpleSoundPlayer::OpenUrlL(const TDesC &aUrl, TInt aIapId, const TDesC8 &aMime)
       
   369 	{
       
   370 	iLogger.Log(_L("Opening url [%S] with IapId [%s]") , &aUrl , aIapId );
       
   371 	iLogger.Log(_L8("   and MIME Type [%S]") , &aMime);
       
   372 	iMdaPlayer->OpenUrlL(aUrl, aIapId, aMime);
       
   373 	return ETrue;
       
   374 	}
       
   375 
       
   376 TInt CSimpleSoundPlayer::OpenDesL(const TDesC8 &aSoundDes , const TBool &aImmediate)
       
   377 	{
       
   378 	iImmediate = aImmediate;
       
   379 	Stop();
       
   380 	iLogger.Log(_L("Stop before opening descriptor"));
       
   381 
       
   382 	iLogger.Log(_L("Closed, opening second descriptor of length (%d)") , aSoundDes.Length() );
       
   383 
       
   384 	iMdaPlayer->OpenDesL(aSoundDes);
       
   385 	iSoundOpen=ETrue;
       
   386 	iLogger.Log(_L("Opened"));
       
   387 	////iAutoClose = ETrue;	///K
       
   388 	return KErrNone;
       
   389 	}
       
   390 
       
   391 TInt CSimpleSoundPlayer::Play()
       
   392 	{
       
   393 	if(iState==EReady || iState==EPaused)
       
   394 		{
       
   395 		iState=EPlaying;
       
   396 		iLastPlayTime.HomeTime();
       
   397 		iLastStopTime.HomeTime();
       
   398 		iMdaPlayer->Play();
       
   399 		iLogger.Log(_L("Requested Play"));
       
   400 		}
       
   401 	else
       
   402 		{
       
   403 		iLogger.Log(_L("Requested Play, Not Ready to play"));
       
   404 		iImmediate = true;
       
   405 		}
       
   406 	return KErrNone;
       
   407 	}
       
   408 
       
   409 TInt CSimpleSoundPlayer::Stop(const TBool &aAlsoClose)
       
   410 	{
       
   411 	iLogger.Log(_L("Requested Stop,,,,,"));
       
   412 	iMdaPlayer->Stop();
       
   413 	iLogger.Log(_L("Requested Stop,,,,, successful"));
       
   414 	iLastStopTime.HomeTime();
       
   415 	if (aAlsoClose)
       
   416 		{
       
   417 		iLogger.Log(_L("iMdaPlayer->Close()" ));
       
   418 		iMdaPlayer->Close();
       
   419 		iLogger.Log(_L("iMdaPlayer->Close() successful" ));
       
   420 		iSoundOpen=EFalse;
       
   421 		iState = ENotReady;
       
   422 		}
       
   423 	else
       
   424 		{
       
   425 		if (iState==EPlaying || iState==EPaused) {iState = EReady;}
       
   426 		}
       
   427 	return KErrNone;
       
   428 	}
       
   429 
       
   430 void CSimpleSoundPlayer::MdapcPlayComplete(TInt aError)
       
   431 	{
       
   432 	iLastStopTime.HomeTime();
       
   433 	iLogger.Log(_L("MapcPlayComplete, error (%d)") , aError);
       
   434 
       
   435 	_LIT(KGonnaPlay, "MapcPlayComplete, GoingToPlay");
       
   436 	_LIT(KGoing, "Going to");
       
   437 
       
   438 	iConsole.Printf(100, KGonnaPlay, KGoing);
       
   439 
       
   440 	iState = aError ? ENotReady : EReady;
       
   441 	iConsole.Printf(100, KGonnaPlay, KGoing);
       
   442 
       
   443 	Exit(aError);
       
   444 	if (iEventTarget && iParameters)
       
   445 		{
       
   446 		Stop();
       
   447 		iEventTarget->ExecuteL(iParameters) ;
       
   448 		}
       
   449 	}
       
   450 
       
   451 CSimpleSoundPlayer::~CSimpleSoundPlayer()
       
   452 	{
       
   453 	iLogger.Log(_L("Trying to stop player") );
       
   454 	iMdaPlayer->Stop();
       
   455 	iLogger.Log(_L("Trying to close player") );
       
   456 	iMdaPlayer->Close();
       
   457 	iLogger.Log(_L("  Player stopped") );
       
   458     delete iMdaPlayer;
       
   459     iMdaPlayer = NULL;
       
   460 
       
   461 	delete iEventTarget;
       
   462    	delete iParameters;
       
   463     delete iSupervisor;
       
   464 	}
       
   465 
       
   466 TTimeIntervalMicroSeconds CSimpleSoundPlayer::GetDuration()
       
   467 	{
       
   468 	TTimeIntervalMicroSeconds duration = iMdaPlayer->Duration();
       
   469 	iLogger.Log(_L("CMdaAudioPlayerUtility::Duration() returned [%d]") , duration.Int64() );
       
   470 	return duration;
       
   471 	}
       
   472 
       
   473 TTimeIntervalMicroSeconds CSimpleSoundPlayer::GetPlayDuration() { return iLastStopTime.MicroSecondsFrom(iLastPlayTime); }
       
   474 
       
   475 TTime CSimpleSoundPlayer::GetPlayStartTime() { return iLastPlayTime; }
       
   476 
       
   477 TTime CSimpleSoundPlayer::GetPlayStopTime() { return iLastStopTime; }
       
   478 
       
   479 TInt CSimpleSoundPlayer::GetBitRate(TUint &aBitRate)
       
   480 	{
       
   481 	TInt error = iMdaPlayer->GetBitRate(aBitRate);
       
   482 	iLogger.Log(_L("Retrieving BitRate (%d), error(%d)") , aBitRate, error);
       
   483 	return error;
       
   484 	}
       
   485 
       
   486 TInt CSimpleSoundPlayer::GetBalance(TInt &aBalance)
       
   487 	{
       
   488 	TInt error = iMdaPlayer->GetBalance(aBalance);
       
   489 	iLogger.Log(_L("Retrieving Balance (%d), error(%d)") , aBalance, error);
       
   490 	return error;
       
   491 	}
       
   492 
       
   493 TInt CSimpleSoundPlayer::SetBalance(TInt aBalance=KMMFBalanceCenter)
       
   494 	{
       
   495 	TInt error=KErrNone;
       
   496 	TInt error2=KErrNone;
       
   497 	TInt OldBalance=0;
       
   498 
       
   499 	iLogger.Log(_L("Changing Balance "));
       
   500 
       
   501 	error=iMdaPlayer->GetBalance(OldBalance);
       
   502 	if (error)
       
   503 		{
       
   504 		iLogger.Log(_L("   Error getting old balance (%d)"), error) ;
       
   505 		}
       
   506 	else
       
   507 		{
       
   508 		iLogger.Log(_L("   Previous balance: %d"), OldBalance);
       
   509 		}
       
   510 	iLogger.Log(_L("   Setting balance to %d"), aBalance);
       
   511 	error2 = iMdaPlayer->SetBalance(aBalance);
       
   512 	if (error2)
       
   513 		{
       
   514 		iLogger.Log(_L("   Error setting new balance (%d)") , error);
       
   515 		}
       
   516 	else
       
   517 		{
       
   518 		error=iMdaPlayer->GetBalance(OldBalance);
       
   519 		if (error)
       
   520 			{
       
   521 			iLogger.Log(_L("   Error getting new balance (%d)"), error) ;
       
   522 			}
       
   523 		else
       
   524 			{
       
   525 			iLogger.Log(_L("   Current balance: %d"), OldBalance);
       
   526 			}
       
   527 		}
       
   528 
       
   529 	if (OldBalance!= aBalance)
       
   530 	{
       
   531 		Exit(-1502);
       
   532 	}
       
   533 
       
   534 	return error2;
       
   535 	}
       
   536 
       
   537 TInt CSimpleSoundPlayer::SetPriority(TInt aPriority, TMdaPriorityPreference aPref)
       
   538 	{
       
   539 	iLogger.Log(_L("Trying to set priority settings to (%d),(%d) ") , aPriority, aPref);
       
   540 	TInt PriorityError = iMdaPlayer->SetPriority(aPriority, aPref);
       
   541 	if (PriorityError)
       
   542 		{
       
   543 		iLogger.Log(_L("Error setting priority to (%d),(%d) ") , aPriority, aPref);
       
   544 		}
       
   545 	else
       
   546 		{
       
   547 		iLogger.Log(_L("Priority set to (%d),(%d)") , aPriority, aPref);
       
   548 		}
       
   549 	return PriorityError;
       
   550 	}
       
   551 
       
   552 void CSimpleSoundPlayer::SetPosition(const TTimeIntervalMicroSeconds &aPosition)
       
   553 	{
       
   554 	iMdaPlayer->SetPosition(aPosition);
       
   555 	}
       
   556 
       
   557 
       
   558 TInt CSimpleSoundPlayer::GetPosition(TTimeIntervalMicroSeconds &aPosition)
       
   559 	{
       
   560 	TTimeIntervalMicroSeconds position;
       
   561 	TInt PositionError = iMdaPlayer->GetPosition(position);
       
   562 
       
   563 	if (!PositionError)
       
   564 		{
       
   565 		iLogger.Log(_L("Current position [%d]") , position.Int64());
       
   566 		if (iState != EPlaying) {iLogger.Log(_L("  But not playing"));}
       
   567 		if ( ! iSoundOpen ) {iLogger.Log(_L("  But not open"));}
       
   568 		aPosition=position;
       
   569 		}
       
   570 	else
       
   571 		{
       
   572 		Exit(PositionError);
       
   573 		}
       
   574 	return PositionError;
       
   575 	}
       
   576 
       
   577 void CSimpleSoundPlayer::Exit(TInt aExitCode)
       
   578 	{
       
   579 	iFinalError = aExitCode;
       
   580 	if (iSupervisor)
       
   581 		{
       
   582 		iSupervisor->NotifyDestruction();
       
   583 		}
       
   584 	else
       
   585 		{
       
   586 		CActiveScheduler::Stop();
       
   587 		}
       
   588 	}
       
   589 
       
   590 void CSimpleSoundPlayer::SetVolumeRamp(const TTimeIntervalMicroSeconds &aRampDuration)
       
   591 	{
       
   592 	iMdaPlayer->SetVolumeRamp(aRampDuration);
       
   593 	}
       
   594 
       
   595 void CSimpleSoundPlayer::SetVolume(TInt aNewVolume)
       
   596 	{
       
   597 	iMdaPlayer->SetVolume(aNewVolume);
       
   598 	}
       
   599 
       
   600 TInt CSimpleSoundPlayer::GetVolume(TInt &aVolume)
       
   601 	{
       
   602 	TInt VolumeError = iMdaPlayer->GetVolume(aVolume);
       
   603 	if (VolumeError)
       
   604 		{
       
   605 		iLogger.Log(_L("Error (%d) getting volume") , VolumeError );
       
   606 		}
       
   607 	else
       
   608 		{
       
   609 		iLogger.Log(_L("Getting volume: (%d)") , aVolume);
       
   610 		}
       
   611 	return VolumeError;
       
   612 	}
       
   613 
       
   614 TInt CSimpleSoundPlayer::MaxVolume()
       
   615 	{
       
   616 	return iMdaPlayer->MaxVolume();
       
   617 	}
       
   618 
       
   619 void CSimpleSoundPlayer::SetRepeats(TInt aRepeatNumberOfTimes, const TTimeIntervalMicroSeconds &aTrailingSilence)
       
   620 	{
       
   621 	iMdaPlayer->SetRepeats(aRepeatNumberOfTimes , aTrailingSilence);
       
   622 	if ((aRepeatNumberOfTimes == -2) || (aRepeatNumberOfTimes > 0))
       
   623 	    iIsLoopPlayEnabled = ETrue;
       
   624 	else
       
   625 	    iIsLoopPlayEnabled = EFalse;
       
   626 	}
       
   627 
       
   628 void CSimpleSoundPlayer::RegisterForAudioLoadingNotification(MAudioLoadingObserver &aLoadingObserver)
       
   629 	{
       
   630 	iMdaPlayer->RegisterForAudioLoadingNotification(aLoadingObserver);
       
   631 	}
       
   632 
       
   633 void CSimpleSoundPlayer::GetAudioLoadingProgressL(TInt& aPercentageProgress)
       
   634 	{
       
   635 	iMdaPlayer->GetAudioLoadingProgressL(aPercentageProgress);
       
   636 	}
       
   637 
       
   638 void CSimpleSoundPlayer::ControllerImplementationInformationL()
       
   639 	{
       
   640 	//int g=0,a;
       
   641 	const CMMFControllerImplementationInformation& x = iMdaPlayer->ControllerImplementationInformationL();
       
   642 	/*const CMMFControllerImplementationInformation* ControllerImplementationInformation;
       
   643 	ControllerImplementationInformation = &(iMdaPlayer->ControllerImplementationInformationL());*/
       
   644 	//g=a;
       
   645 	}
       
   646 
       
   647 TInt CSimpleSoundPlayer::SetPlayWindow(const TTimeIntervalMicroSeconds &aStart, const TTimeIntervalMicroSeconds &aEnd)
       
   648 	{
       
   649 	iLogger.Log(_L("iMdaPlayer->SetPlayWindow() Start[%d] End[%d]"), aStart.Int64(), aEnd.Int64());
       
   650 	return iMdaPlayer->SetPlayWindow(aStart, aEnd);
       
   651 	}
       
   652 
       
   653 TInt CSimpleSoundPlayer::ClearPlayWindow()
       
   654 	{
       
   655 	iLogger.Log(_L("iMdaPlayer->ClearPlayWindow()"));
       
   656 	return iMdaPlayer->ClearPlayWindow();
       
   657 	}
       
   658 
       
   659 void CSimpleSoundPlayer::SetSupervisor(TObjectCountDown *aCounter)
       
   660 	{
       
   661 	iSupervisor = aCounter;
       
   662 	iSupervisor->NotifyCreation();
       
   663 	}
       
   664 
       
   665 void CSimpleSoundPlayer::SetPlayCompleteTarget(MEventTarget *aTarget, CParameters *aParameters)
       
   666 	{
       
   667 	iEventTarget = aTarget;
       
   668 	iParameters = aParameters;
       
   669 	}
       
   670 
       
   671 TInt CSimpleSoundPlayer::GetNumberOfMetaDataEntries(TInt &aNumEntries)
       
   672 	{
       
   673 	TInt ErrorCode = iMdaPlayer->GetNumberOfMetaDataEntries(aNumEntries);
       
   674 	if (ErrorCode)
       
   675 		{
       
   676 		iLogger.Log(_L("Error (%d) getting number of meta data entries") , ErrorCode);
       
   677 		}
       
   678 	else
       
   679 		{
       
   680 		iLogger.Log(_L("Clip has (%d) meta data entries") , aNumEntries);
       
   681 		}
       
   682 	return ErrorCode;
       
   683 	}
       
   684 
       
   685 CMMFMetaDataEntry *CSimpleSoundPlayer::GetMetaDataEntryL(TInt aMetaDataIndex)
       
   686 	{
       
   687 	iLogger.Log(_L("Obtaining meta data with index (%d)") , aMetaDataIndex);
       
   688 	return iMdaPlayer->GetMetaDataEntryL(aMetaDataIndex);
       
   689 	}
       
   690 
       
   691 TInt CSimpleSoundPlayer::ExecuteL(CParameters *aParams)
       
   692 	{
       
   693     TInt newVolume = 2000;
       
   694     TInt balance=0;
       
   695 
       
   696     TInt priority=EMdaPriorityNormal;
       
   697 	TMdaPriorityPreference aPref=EMdaPriorityPreferenceTime;
       
   698 
       
   699     TInt repeatNumberOfTimes=3;
       
   700     TTimeIntervalMicroSeconds SilenceDuration = (TTimeIntervalMicroSeconds ((TInt64)500000));
       
   701 
       
   702 	switch (aParams->iAction)
       
   703 		{
       
   704 		case KPlayerActionPause:
       
   705 		    iLogger.Log(_L("CSimpleSoundPlayer::ExecuteL "));
       
   706 			Pause();
       
   707 			break;
       
   708 		case KPlayerActionPlay:
       
   709 			Play();
       
   710 			break;
       
   711 		case KPlayerActionStopPlayFile:
       
   712 		//	OpenL( (static_cast<CFileNameParameters*>(aParams) )->GetFileName() , ETrue);
       
   713 			Stop();
       
   714 			break;
       
   715 		case KPlayerActionReportPosition:
       
   716 			{
       
   717 			TTimeIntervalMicroSeconds tmpPosition=TTimeIntervalMicroSeconds(0);
       
   718 			GetPosition(tmpPosition);
       
   719 			return ETrue;
       
   720 			}
       
   721 			//break;
       
   722 		case KPlayerActionReportDuration:
       
   723 			GetDuration();
       
   724 			return ETrue;
       
   725 			//break;
       
   726         case KplayerActionMaxVolume:
       
   727             MaxVolume();
       
   728             return ETrue;
       
   729             //break;
       
   730         case KplayerActionSetVolume:
       
   731             SetVolume(newVolume);
       
   732             return ETrue;
       
   733             //break;
       
   734         case KplayerActionSetBalance:
       
   735             SetBalance(balance);
       
   736             return ETrue;
       
   737             //break;
       
   738         case KplayerActionGetBalance:
       
   739             GetBalance(iBalance);
       
   740             return ETrue;
       
   741             //break;
       
   742         case KplayerActionGetBitRate:
       
   743         	TUint bitRate;
       
   744             GetBitRate(bitRate);
       
   745             return ETrue;
       
   746             //break;
       
   747         case KplayerActionSetPriority:
       
   748         	SetPriority(priority, aPref);
       
   749             return ETrue;
       
   750             //break;
       
   751         case KplayerActionSetRepeats:
       
   752             SetRepeats(repeatNumberOfTimes, SilenceDuration);
       
   753             return ETrue;
       
   754             //break;
       
   755         case KPlayerActionGetMetaDataEntry:
       
   756             SetVolume(newVolume);
       
   757             return ETrue;
       
   758             //break;
       
   759         case KPlayerActionGetNumberOfMetaDataEntries:
       
   760             SetVolume(newVolume);
       
   761             return ETrue;
       
   762            // break;
       
   763         case KplayerActionGetAudioLoadingProgress:
       
   764             TInt percentageProgress;
       
   765             GetAudioLoadingProgressL(percentageProgress);
       
   766             return ETrue;
       
   767             //break;
       
   768         case KplayerActionRegisterForAudioLoadingNotification:
       
   769  //       	MAudioLoadingObserver &aLoadingObserver=0;
       
   770  //       	RegisterForAudioLoadingNotification(aLoadingObserver);
       
   771             return ETrue;
       
   772             //break;
       
   773         case KplayerActionControllerImplementationInformation:
       
   774             ControllerImplementationInformationL();
       
   775             return ETrue;
       
   776            // break;
       
   777 		case KPlayerActionStopPlayDes:
       
   778 			OpenDesL( (static_cast<CDes8Parameters *>(aParams) )->GetDes8() , ETrue);
       
   779 			break;
       
   780 		case KPlayerActionReportVolume:
       
   781 			TInt tmpVolume;
       
   782 			GetVolume(tmpVolume);
       
   783 			return ETrue;
       
   784 			//break;
       
   785 		case KPlayerActionStopPlayUrl:
       
   786 		   CUrlParameters *p;
       
   787 			 p = static_cast<CUrlParameters *>(aParams);
       
   788 			 OpenUrlL(p->GetUrl() , p->GetIapId() , p->GetMimeType() );
       
   789 			 break;
       
   790 		case KPlayerActionStopPlayFileHandler:
       
   791 			Stop();
       
   792 		//	OpenFileHandlerL((static_cast<CFileNameParameters*>(aParams) )->GetFileName() , ETrue);
       
   793 		//	OpenFileHandlerL( (static_cast<CFileHandlerParameters*>(aParams) )->GetFileHandler() , ETrue);
       
   794 			break;
       
   795 		case KPlayerActionOpen:
       
   796 			OpenL( (static_cast<CFileNameParameters*>(aParams) )->GetFileName() , ETrue);
       
   797 			break;
       
   798 
       
   799 		case KPlayerActionOpenFileHandler:
       
   800 			OpenFileHandlerL((static_cast<CFileNameParameters*>(aParams) )->GetFileName() , ETrue);
       
   801 			break;
       
   802 		}
       
   803 	if (iIsLoopPlayEnabled)
       
   804 	    return ETrue;
       
   805 	else
       
   806 	    return EFalse;
       
   807 	}