epoc32/include/videoplayer.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
parent 2 2fe1408b6811
permissions -rw-r--r--
Current Symbian^3 public API header files (from PDK 3.0.h) This is the epoc32/include tree with the "platform" subtrees removed, and all but a selected few mbg and rsg files removed.

// Copyright (c) 2002-2009 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:
//

#ifndef __VIDEOPLAYER_H__
#define __VIDEOPLAYER_H__

#include <w32std.h>
#include <fbs.h>
#include <f32file.h>
#include <mmf/common/mmfbase.h>
#include <mmf/common/mmfcontroller.h>
#include <mmf/common/mmfaudio.h>
#include <mmf/common/mmfstandardcustomcommands.h>
#include <mmf/common/mmfdrmcustomcommands.h>
#include <mda/common/base.h>
#include <mmf/common/mmfutilities.h>
#include <mmf/common/mmfcontrollerframeworkbase.h>
#include "mmf/common/mmcaf.h"
#include <mmfclntutility.h>

/**
@publishedAll
@released

An interface to a set of video player callback functions.

The class is a mixin and is intended to be inherited by the client
class which is observing the video playing operation. The functions
encapsulated by this class are called when specific events occur in
the process of initialising and playing an video clip. A reference to
this object is passed as a parameter when constructing an audio player
utility object.

@since 7.0s
*/
class MVideoPlayerUtilityObserver
	{
public:

	/**
	Notification to the client that the opening of the video clip has completed,
	successfully, or otherwise.

	The status of the video sample after opening is given by aError. The following
	values imply same across all the devices.

	- KErrNone: the sample is ready to play;
	- KErrNotSupported: the controller plugin is not recognised or not supported;
	- KErrNotFound: the video sample cannot be found;
	- KErrNoMemory: there is insufficient memory to play this video sample.

	Other values are possible indicating a problem opening the video sample. These values
	are device dependent.

	The client must now call Prepare() on the video player utility before the
	video clip can be played or any of its properties (e.g. duration) can be
	queried.

	@param  aError
	        The status of the video player after initialisation.

	@since  7.0s
	*/
	virtual void MvpuoOpenComplete(TInt aError) = 0;

	/**
	Notification to the client that the opening of the video clip has been prepared
	successfully, or otherwise.  This callback is called in response to a call to
	CVideoPlayerUtility::Prepare().

	The video clip may now be played, or have any of its properties (e.g. duration) queried.

	@param  aError
	        The status of the video player after initialisation.
	        This is either KErrNone if the open has completed successfully,
	        or one of the system wide error codes.
	
	@since  7.0s
	*/
	virtual void MvpuoPrepareComplete(TInt aError) = 0;

	/**
	Notification that the frame requested by a call to GetFrameL is ready

	@param  aFrame
	        The returned frame. The bitmap will contain
	        the requested frame if the the error code is KErrNone (success).
	@param  aError
	        The status of the frame request.
	        This is either KErrNone if the frame request was successful,
	        or one of the system wide error codes.

	@since	7.0s
	*/
	virtual void MvpuoFrameReady(CFbsBitmap& aFrame,TInt aError) = 0;

	/**
	Notification that video playback has completed. This is not called if
	playback is explicitly stopped (such as through the use of the Stop or
	Close commands).

	@param  aError
	        The status of playback.
	        This is either KErrNone if the playback was completed successfully,
	        or one of the system wide error codes.
	@since  7.0s
	*/
	virtual void MvpuoPlayComplete(TInt aError) = 0;
	
	/**
	General event notification from controller. These events are specified by
	the supplier of the controller

	@param  aEvent
	        The event sent by the controller.

	@since  7.0s
	*/
	virtual void MvpuoEvent(const TMMFEvent& aEvent) = 0;
	};
	
/**
@publishedAll
@released

This is a mixin class that allows a client to receive notification of rebuffering
operations occurring in the video player

@since 7.0s
*/
class MVideoLoadingObserver
	{
public:

	/**
	Notification that video clip loading/rebuffering has started

	@since  7.0s
	*/
	virtual void MvloLoadingStarted() = 0;

	/**
	Notification that video clip loading/rebuffering has completed

	@since  7.0s
	*/
	virtual void MvloLoadingComplete() = 0;
	};

class CMMFVideoPlayerCallback;
class CVideoPlayerUtility2;
class TVideoPlayRateCapabilities;

/**
@publishedAll
@released

Plays sampled video data.

The class offers a simple interface to open, play and obtain information from sampled video data. 
The video data can be provided using files, descriptors or URLs.

Note: 
Some video formats also allow the storing of audio data. To accommodate this, this class contains 
audio functions that can manipulate such data.

While this class is abstract, NewL() constructs, initialises and returns pointers to instances of 
concrete classes derived from this abstract class. This concrete class is part of the MMF 
implementation and is private.

@since 7.0s
*/
class CVideoPlayerUtility : public CBase,
							public MMMFClientUtility
	{
public:

	~CVideoPlayerUtility();

	IMPORT_C static CVideoPlayerUtility* NewL(MVideoPlayerUtilityObserver& aObserver,
											  TInt aPriority,
											  TInt aPref,
											  RWsSession& aWs,
											  CWsScreenDevice& aScreenDevice,
											  RWindowBase& aWindow,
											  const TRect& aScreenRect,
											  const TRect& aClipRect);

	IMPORT_C void OpenFileL(const TDesC& aFileName,TUid aControllerUid = KNullUid);
	IMPORT_C void OpenFileL(const RFile& aFileName, TUid aControllerUid = KNullUid);

	IMPORT_C void OpenFileL(const TMMSource& aSource, TUid aControllerUid = KNullUid);

	IMPORT_C void OpenDesL(const TDesC8& aDescriptor,TUid aControllerUid = KNullUid);

	IMPORT_C void OpenUrlL(const TDesC& aUrl, TInt aIapId = KUseDefaultIap, const TDesC8& aMimeType=KNullDesC8, TUid aControllerUid = KNullUid);

	IMPORT_C void Prepare();

	IMPORT_C void Close();

	IMPORT_C void Play();

	IMPORT_C void Play(const TTimeIntervalMicroSeconds& aStartPoint, const TTimeIntervalMicroSeconds& aEndPoint);

	IMPORT_C TInt Stop();

	IMPORT_C void PauseL();

	IMPORT_C void SetPriorityL(TInt aPriority, TInt aPref);

	IMPORT_C void PriorityL(TInt& aPriority, TMdaPriorityPreference& aPref) const;

	IMPORT_C void SetDisplayWindowL(RWsSession& aWs,CWsScreenDevice& aScreenDevice,RWindowBase& aWindow,const TRect& aWindowRect,const TRect& aClipRect);

	IMPORT_C void RegisterForVideoLoadingNotification(MVideoLoadingObserver& aCallback);

	IMPORT_C void GetVideoLoadingProgressL(TInt& aPercentageComplete);

	IMPORT_C void GetFrameL(TDisplayMode aDisplayMode);

	IMPORT_C void GetFrameL(TDisplayMode aDisplayMode, ContentAccess::TIntent aIntent);

	IMPORT_C void RefreshFrameL();

	IMPORT_C TReal32 VideoFrameRateL() const;

	IMPORT_C void SetVideoFrameRateL(TReal32 aFramesPerSecond);

	IMPORT_C void VideoFrameSizeL(TSize& aSize) const;

	IMPORT_C const TDesC8& VideoFormatMimeType() const;

	IMPORT_C TInt VideoBitRateL() const;

	IMPORT_C TInt AudioBitRateL() const;

	IMPORT_C TFourCC AudioTypeL() const;

	IMPORT_C TBool AudioEnabledL() const;

	IMPORT_C void SetPositionL(const TTimeIntervalMicroSeconds& aPosition);

	IMPORT_C TTimeIntervalMicroSeconds PositionL() const;

	IMPORT_C TTimeIntervalMicroSeconds DurationL() const;

	IMPORT_C void SetVolumeL(TInt aVolume);

	IMPORT_C TInt Volume() const;

	IMPORT_C TInt MaxVolume() const;

	IMPORT_C void SetBalanceL(TInt aBalance);

	IMPORT_C TInt Balance()const;

	IMPORT_C void SetRotationL(TVideoRotation aRotation);

	IMPORT_C TVideoRotation RotationL() const;

	IMPORT_C void SetScaleFactorL(TReal32 aWidthPercentage, TReal32 aHeightPercentage, TBool aAntiAliasFiltering);

	IMPORT_C void GetScaleFactorL(TReal32& aWidthPercentage, TReal32& aHeightPercentage, TBool& aAntiAliasFiltering) const;

	IMPORT_C void SetCropRegionL(const TRect& aCropRegion);

	IMPORT_C void GetCropRegionL(TRect& aCropRegion) const;

	IMPORT_C TInt NumberOfMetaDataEntriesL() const;

	IMPORT_C CMMFMetaDataEntry* MetaDataEntryL(TInt aIndex) const;

	IMPORT_C const CMMFControllerImplementationInformation& ControllerImplementationInformationL();

	IMPORT_C TInt CustomCommandSync(const TMMFMessageDestinationPckg& aDestination, TInt aFunction, const TDesC8& aDataTo1, const TDesC8& aDataTo2, TDes8& aDataFrom);

	IMPORT_C TInt CustomCommandSync(const TMMFMessageDestinationPckg& aDestination, TInt aFunction, const TDesC8& aDataTo1, const TDesC8& aDataTo2);

	IMPORT_C void CustomCommandAsync(const TMMFMessageDestinationPckg& aDestination, TInt aFunction, const TDesC8& aDataTo1, const TDesC8& aDataTo2, TDes8& aDataFrom, TRequestStatus& aStatus);

	IMPORT_C void CustomCommandAsync(const TMMFMessageDestinationPckg& aDestination, TInt aFunction, const TDesC8& aDataTo1, const TDesC8& aDataTo2, TRequestStatus& aStatus);

	IMPORT_C MMMFDRMCustomCommand* GetDRMCustomCommand();

	IMPORT_C void StopDirectScreenAccessL();
	
	IMPORT_C void StartDirectScreenAccessL();

	IMPORT_C TInt RegisterAudioResourceNotification(MMMFAudioResourceNotificationCallback& aCallback, TUid aNotificationEventUid, const TDesC8& aNotificationRegistrationData = KNullDesC8);

	IMPORT_C TInt CancelRegisterAudioResourceNotification(TUid aNotificationEventId);
    
	IMPORT_C TInt WillResumePlay();
	
	IMPORT_C TInt SetInitScreenNumber(TInt aScreenNumber);

	IMPORT_C void SetPlayVelocityL(TInt aVelocity);

	IMPORT_C TInt PlayVelocityL() const;

	IMPORT_C void StepFrameL(TInt aStep);
	
	IMPORT_C void GetPlayRateCapabilitiesL(TVideoPlayRateCapabilities& aCapabilities) const;
	
	IMPORT_C void SetVideoEnabledL(TBool aVideoEnabled);

	IMPORT_C TBool VideoEnabledL() const;

	IMPORT_C void SetAudioEnabledL(TBool aAudioEnabled);

	IMPORT_C void SetAutoScaleL(TAutoScaleType aScaleType);

	IMPORT_C void SetAutoScaleL(TAutoScaleType aScaleType, TInt aHorizPos, TInt aVertPos);
	
	IMPORT_C void SetExternalDisplaySwitchingL(TInt aDisplay, TBool aControl);
	
private:
	class CBody;
	
	CBody* iBody;
	
	friend class CBody;
	friend class CVideoPlayerUtility2;	
private:
	enum TMMFVideoPlayerState
		{
		EStopped,
		EOpening,
		EPaused,
		EPlaying		
		};
private:	
	friend class CTestStepUnitMMFVidClient;
#ifdef SYMBIAN_BUILD_GCE
	friend class CMediaClientVideoDisplayBody;
#endif // SYMBIAN_BUILD_GCE
public:
	class CTestView;
	friend class CTestView;
	};


#endif