dlnasrv_plat/upnp_command_api/inc/upnpshowcommand.h
author hgs
Tue, 21 Sep 2010 11:21:11 +0300
changeset 33 6ac064bb53eb
parent 0 7f85d04be362
permissions -rw-r--r--
201037

/** @file
* Copyright (c) 2007 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:  Helper class to ease the use of the Upnp Framework's
*                UpnpCommand API when showing images and videos via Upnp.
*
*/


#ifndef UPNP_SHOW_COMMAND_H
#define UPNP_SHOW_COMMAND_H

// INCLUDES
#include <e32base.h>                // CBase

// FORWARD DECLARATIONS
class CUpnpCommand;
class MUpnpCommandObserver;
class CUpnpCommandCallbackAdapter;


// CLASS DEFINITION
class CUpnpShowCommand: public CBase
    {

    public: // Construction/destruction methods

        /**
         * Creates a new UpnpCommand for image and video showing purposes.
         * Does not instantiate Upnp Framework services yet at this point.
         *
         * Leaves with KErrNotReady if Upnp dedicated IAP is not set, or with
         * using standard e32err.h error code if construction fails.
         *
         * @since S60 3.2
         * @return a new CUpnpShowCommand object
         */
        IMPORT_C static CUpnpShowCommand* NewL();

        /**
         * Creates a new UpnpCommand for image and video showing purposes.
         * Does not instantiate Upnp Framework services yet at this point.
         *
         * Leaves if the given observer instance is not valid.
         *
         * @since S60 3.2
         * @param aObserver (MUpnpCommandObserver*) The observer instance
         * @return a new CUpnpShowCommand object
         */
        IMPORT_C static CUpnpShowCommand* NewL(
            MUpnpCommandObserver* aObserver );

        /**
         * Destructor.
         *
         * @since S60 3.2
         */
        virtual ~CUpnpShowCommand();

    public: // Business logic methods

        /**
         * Returns the availability information of the command.
         *
         * @since S60 3.2
         * @return TBool (ETrue if available)
         */
        IMPORT_C static TBool IsAvailableL();

        /**
         * Starts showing. Allocates Upnp Framework resources. The target
         * rendering device will be queried from the user using an UI
         * component. Local Media Server sharing will be activated (if not
         * yet activated).
         *
         * Leaves if the Upnp Framework resource allocation fails. Standard
         * system wide (e32err.h) error codes will be used.
         *
         * @since S60 3.2
         */
        IMPORT_C void StartShowingL();

        /**
         * Stops showing. Releases all Upnp Framework resources. Local Media
         * Server sharing state will be returned to it's original state.
         *
         * Leaves if the operation fails. Standard system wide (e32err.h)
         * error codes will be used.
         *
         * @since S60 3.2
         */
        IMPORT_C void StopShowingL();

        /**
         * Shows the given images on a remote Upnp Media Rendering device.
         * The method is asynchronous. Upnp Framework resources will be 
         * allocated, if not yet allocated (by calling StartShowingL). 
         *
         * MUpnpCommandObserver::CommandComplete callback method is used to
         * delived the return the return code of the operation.
         *
         * Leaves if the operation fails, or if the user cancels the
         * operations. Standard system wide (e32err.h) error codes will be
         * used.
         *
         * @since S60 3.2
         * @param aFilename (const TDesC&) filename (including path)
         */
        IMPORT_C void ShowImageL( const TDesC& aFilename );

        /**
         * Shows the given video on a remote Upnp Media Rendering device. The
         * method is asynchronous. Upnp Framework resources will be allocated,
         * if not yet allocated (by calling StartShowingL). 
         *
         * MUpnpCommandObserver::CommandComplete callback method is used to
         * delived the return the return code of the operation.
         *
         * Leaves if the operation fails, or if the user cancels the
         * operations. Standard system wide (e32err.h) error codes will be
         * used.
         *
         * @since S60 3.2
         * @param aFilename (const TDesC&) filename (including path)
         */
        IMPORT_C void ShowVideoL( const TDesC& aFilename );

    private: // Private construction methods

        /**
         * Constructor
         *
         * @since S60 3.2
         * @param aObserver (MUpnpCommandObserver*) The observer instance
         *        can be NULL
         */
        CUpnpShowCommand( MUpnpCommandObserver* aObserver );

        /**
         * Second phase constructor
         *
         * @since S60 3.2
         */
        void ConstructL();

    private: // Data members

        /*
         * UpnpCommand instance. Owned.
         */
        CUpnpCommand*               iCommand;

        /*
         * Observer instance. Not owned.
         */
        MUpnpCommandObserver*       iObserver;

        /*
         * Callback adapter. Owned.
         */
        CUpnpCommandCallbackAdapter* iAdapter;

    };

#endif // UPNP_SHOW_COMMAND_H

// End of File