#include "mmfcontroller.h"
class CMMFController : public CBase |
Public Member Functions | |
---|---|
virtual | ~CMMFController() |
virtual IMPORT_C void | HandleRequestL(TMMFMessage &) |
CMMFController * | NewL(TUid, MAsyncEventHandler &, TThreadId) |
Base class for controller plugins.
A controller plugin for the multimedia framework must derive from this class and implement all the pure virtual functions.
Controller plugins control the flow of multimedia data from one or more sources to one or more sinks. For example, an audio controller plugin might take data from a file source and output it to a speaker sink, or take data from a microphone source and save it to a file sink. A controller plugin typically supports one or more multimedia formats, for example WAV or MPEG4.
IMPORT_C void | AddCustomCommandParserL | ( | CMMFCustomCommandParserBase & | aParser | ) | [protected] |
Adds a custom command parser to the controller framework.
If the controller framework receives a request it does not understand, it will search through its list of custom command parsers before passing the request on to the controller plugin as a custom command.
By using the custom command parsers, the controller plugin can implement a concrete API rather than having to decode the common custom commands itself.
Parameter | Description |
---|---|
aParser | The parser to be added to the controller framework. The controller framework takes ownership of the parser if the call does not leave. |
void | AddDataSinkL | ( | MDataSink & | aDataSink | ) | [protected, pure virtual] |
Adds a data sink to the controller plugin.
NOTE: The data sink is owned by the controller framework, NOT by the controller plugin. Under no circumstances should the controller plugin delete the data sink.
Parameter | Description |
---|---|
aDataSink | A reference to the data sink to be added. The controller plugin may call aDatasink.DatasinkType() to find out exactly what type of sink it is. |
void | AddDataSourceL | ( | MDataSource & | aDataSource | ) | [protected, pure virtual] |
Add a data source to the controller plugin.
NOTE: The data source is owned by the controller framework, NOT by the controller plugin. Under no circumstances should the controller plugin delete the data source.
Parameter | Description |
---|---|
aDataSource | A reference to the data source to be added. The controller plugin may call aDataSource.DataSourceType() to find out exactly what type of source it is. |
IMPORT_C TThreadId | ClientThreadIdL | ( | ) | [protected] |
Retrieves the client thread Id of this controller.
Returns: Thread Id of the controller's client
void | CustomCommand | ( | TMMFMessage & | aMessage | ) | [protected, inline, virtual] |
Handles a custom command.
Custom commands allow a controller plugin to define its own API. If the controller framework does not understand a message from the client, it is assumed this is a custom command for the plugin and passed into this interface.
The more common custom commands can be handled by Custom Command Parsers on behalf of the controller plugin. This allows the controller plugin to implement a concrete interface (defined by mixin classes) rather than having to decode the command itself. For more information, see CMMFCustomCommandParserBase.
The controller plugin must always complete the message passed into this method, even if it does not support the interface required by the message.
See also: CMMFCustomCommandParserBase.
Parameter | Description |
---|---|
aMessage | The message to be handled by the controller plugin. |
TTimeIntervalMicroSeconds | DurationL | ( | ) | const [protected, pure virtual] |
Gets the duration of the clip.
The controller plugin should calculate the clip duration in microseconds.
Returns: The clips duration in microseconds.
CMMFMetaDataEntry * | GetMetaDataEntryL | ( | TInt | aIndex | ) | [protected, pure virtual] |
Retrieves a meta data entry from the clip.
Parameter | Description |
---|---|
aIndex | The index of the meta data entry to retrieve. |
Returns: A pointer to a newly created CMMFMetaDataEntry object containing the meta information. The controller framework will take ownership of the object when this method returns.
void | GetNumberOfMetaDataEntriesL | ( | TInt & | aNumberOfEntries | ) | [protected, pure virtual] |
RetrieveS the number of meta data entries in the clip.
Parameter | Description |
---|---|
aNumberOfEntries | The controller plugin must set this to the number of meta data entries in the clip. |
IMPORT_C void | HandleRequestL | ( | TMMFMessage & | aMessage | ) | [virtual] |
Handles a message from the client.
Decodes the message and calls one of the private DoXxx methods to unpackaged the parameters.
Parameter | Description |
---|---|
aMessage | The message to be handled. |
IMPORT_C TBool | IsSecureDrmModeL | ( | ) | [protected] |
Check the Secure DRM Mode of current controller object
Returns: ETrue if the controller is running under Secure DRM mode; otherwise EFalse.
IMPORT_C CMMFObjectContainer & | MMFObjectContainerL | ( | ) | [protected] |
Gets a reference to the multimedia framework object container.
The controller plugin may add CMMFObject-derived objects to the container to allow them to receive messages directly from the client.
Returns: A reference to the MMFObjectContainer.
CMMFController * | NewL | ( | TUid | aControllerUid, |
MAsyncEventHandler & | aEventHandler, | |||
TThreadId | aClientTid | |||
) | [static] |
Allocates and constructs a new controller plugin.
Uses ECOM to instantiate a new controller plugin. Can leave with any of the system-wide error codes.
Parameter | Description |
---|---|
aControllerUid | The unique ID of the controller to be instantiated from ECOM. |
aEventHandler | A reference to an event handling object that can be used by the controller to send events back to the client. |
aClientTid | The thread Id of the client thread |
Returns: A pointer to the new controller plugin.
void | PauseL | ( | ) | [protected, pure virtual] |
Pauses the controller plugin.
The controller must now cease transferring data from its source(s) to its sink(s). This moves the controller from the PLAYING back to the PRIMED state.
A subsequent call to Play() will cause the controller plugin to resume playback from the point it was paused (unless there has been a call to SetPosition() in the meantime.
void | PlayL | ( | ) | [protected, pure virtual] |
Commences playback.
The controller must now begin transferring data from its source(s) to its sink(s). This moves the controller from the PRIMED to the PLAYING state.
Note: This method must return once playing has commenced, and not wait until playing is complete.
TTimeIntervalMicroSeconds | PositionL | ( | ) | const [protected, pure virtual] |
Gets the current position.
The controller plugin should calculate the current position in microseconds.
Returns: The current position in microseconds.
void | PrimeL | ( | ) | [protected, pure virtual] |
Primes the controller plugin.
The controller must prepare to start playing, by initialising its sources, sinks and buffers. This moves the controller from the STOPPED to the PRIMED state.
void | RemoveDataSinkL | ( | MDataSink & | aDataSink | ) | [protected, pure virtual] |
Removes a data sink from the controller plugin.
Note: The data sink is owned by the controller framework, NOT by the controller plugin. Under no circumstances should the controller plugin delete the data sink.
Parameter | Description |
---|---|
aDataSink | A reference to the data sink to be removed. |
void | RemoveDataSourceL | ( | MDataSource & | aDataSource | ) | [protected, pure virtual] |
Removes a data source from the controller plugin.
Note: The data source is owned by the controller framework, NOT by the controller plugin. Under no circumstances should the controller plugin delete the data source.
Parameter | Description |
---|---|
aDataSource | A reference to the data source to be removed. |
void | ResetL | ( | ) | [protected, pure virtual] |
Resets the controller plugin.
The controller should revert back to its newly constructed state. If the Reset is successful (i.e. it doesn't leave), the controller framework will delete all objects added to the MMFObjectManager including any sources and sinks.
void | SetPositionL | ( | const TTimeIntervalMicroSeconds & | aPosition | ) | [protected, pure virtual] |
Sets the current position.
The controller plugin should reposition itself to the position provided.
Parameter | Description |
---|---|
aPosition | The desired position in microseconds. |
void | SetPrioritySettings | ( | const TMMFPrioritySettings & | aPrioritySettings | ) | [protected, pure virtual] |
Sets the priority settings.
The new priority settings must be applied to any resource being used by the controller plugin that requires priority settings (for example the sound device).
Parameter | Description |
---|---|
aPrioritySettings | The new priority settings |
void | StopL | ( | ) | [protected, pure virtual] |
Stops the controller plugin.
The controller must now undo anything that occurred during the call to Prime(). This moves the controller from the PRIMED back to the STOPPED state.