javauis/mmapi_qt/baseline/inc/cmmammfplayerfactory.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 31 Aug 2010 15:09:22 +0300
branchRCL_3
changeset 65 ae942d28ec0e
permissions -rw-r--r--
Revision: v2.2.11 Kit: 201035

/*
* Copyright (c) 2002 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:  This class is used for creating MMF-based players.
*
*/


#ifndef CMMAMMFPLAYERFACTORY_H
#define CMMAMMFPLAYERFACTORY_H

//  INCLUDES
#include <mmf/common/mmfcontrollerpluginresolver.h>
#include "mmmaplayerfactory.h"

class CMMAMMFResolver;

//  CLASS DECLARATION
/**
*   This class is used for creating MMF-based players.
*
*
*/
class CMMAMMFPlayerFactory: public CBase, public MMMAPlayerFactory
{
public: // Constructor and destructor
    IMPORT_C CMMAMMFPlayerFactory();
    IMPORT_C ~CMMAMMFPlayerFactory();

public: // From MMMAPlayerFactory
    CMMAPlayer* CreatePlayerL(const TDesC& aContentType);

    CMMAPlayer* CreatePlayerL(const TDesC& aProtocol,
                              const TDesC& aMiddlePart,
                              const TDesC& aParameters);

    CMMAPlayer* CreatePlayerL(const TDesC8& aHeaderData);

    void GetSupportedContentTypesL(const TDesC& aProtocol,
                                   CDesC16Array& aMimeTypeArray);

    void GetSupportedProtocolsL(const TDesC& aContentType,
                                CDesC16Array& aProtocolArray);

protected:

    /**
     * Creates new CMMAPlayer instance with given resolver.
     * @param aResolver Resolver that contains needed mmf controller infos
     * for creating player.
     */
    virtual CMMAPlayer* CreatePlayerL(CMMAMMFResolver* aResolver) = 0;

    /**
     * Returns list of allowed media IDs
     */
    virtual void MediaIdsL(RArray<TUid>& aMediaIds) = 0;

    /**
     * Returns Match type for media IDs.
     * CMMFPluginSelectionParameters::EAllowOnlySuppliedMediaIds is the default.
     */
    virtual CMMFPluginSelectionParameters::TMediaIdMatchType
    MediaIdMatchType();

    /**
     * This method is called before mmf controller implementation array
     * is created. With this the actual factories can e.g. select either
     * set required play or record format support. Play format support is
     * the default.
     */
    IMPORT_C virtual void PreparePluginSelectionParametersL(
        CMMAMMFResolver* aResolver,
        CMMFFormatSelectionParameters* aFormatSelection);

    /**
     * Creates CMMAPlayer with given format selection parameters
     */
    IMPORT_C virtual CMMAPlayer* CreatePlayerL(CMMFFormatSelectionParameters* aFormatSelect,
            const TDesC* aFileName = NULL);

    /**
     * Checks that is this protocol supported by this factory
     */
    TBool IsSupportedProtocolL(const TDesC& aProtocol);

    /**
     * Checks that is this content-type supported by this factory
     */
    TBool IsSupportedContentTypeL(const TDesC& aContentType);
private:
    /**
     * File version of creating player from content type
     */

    CMMAPlayer* CreatePlayerL(const TDesC& aContentType,
                              const TDesC* aFileName);
#ifndef RD_JAVA_OMA_DRM_V2
    /**
     * Tries to open DRM file
     */
    CMMAPlayer* TryOpenDRMFileL(const TDesC& aFileName);
#endif // RD_JAVA_OMA_DRM_V2

};

#endif // CMMAMMFPLAYERFACTORY_H