idlehomescreen/inc/xncomponent.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 19 Feb 2010 22:42:37 +0200
branchRCL_3
changeset 9 f966699dea19
parent 0 f72a12da539e
permissions -rw-r--r--
Revision: 201003 Kit: 201007

/*
* Copyright (c) 2002-2004 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:
* Xuikon component base class
*
*/

#ifndef XNCOMPONENT_H
#define XNCOMPONENT_H

// System includes
#include <e32base.h>

// Forward declarations
class CXnControlAdapter;
class CXnNodePluginIf;
namespace XnComponentInterface
    {
    class MXnComponentInterface;
    }

// Class declaration
/**
 *  Xuikon component base class.
 *
 *  @ingroup group_xnlayoutengine
 *  @lib xnlayoutengine.lib
 *  @since Series 60 3.1
 */
class CXnComponent : public CBase
    {
public: // Constructors and destructor
    /**
     * Two-phased constructor.
     * @param aType Type.
     */
    IMPORT_C static CXnComponent* NewL();

    /**
     * Destructor.
     */
    IMPORT_C virtual ~CXnComponent();

public:
    // New functions

    /**
     * Sets a control adapter.
     *
     * @since Series 60 3.1
     * @param aAdapter Adapter.
     */
    IMPORT_C void SetControlAdapter( CXnControlAdapter* aAdapter );

    /**
     * Returns the control adapter.
     *
     * @since Series 60 3.1
     * @return Control adapter.
     */
    IMPORT_C CXnControlAdapter* ControlAdapter();

    /**
     * Returns component's node.
     *
     * @since Series 60 3.1
     * @return Node.
     */
    IMPORT_C CXnNodePluginIf* Node();

    /**
     * Sets the component's node.
     *
     * @since Series 60 3.1
     * @param aNode Node
     */
    IMPORT_C void SetNode( CXnNodePluginIf& aNode );

    /**
     * Enter power save mode. This is done when application goes to background
     * or lights go off.
     * Derived classes should override this function and stop animations,
     * timers etc. when the function is called.
     */
    IMPORT_C virtual void EnterPowerSaveModeL();

    /**
     * Exit power save mode. This is done when application comes to foreground
     * or lights go on.
     * Derived classes should override this function and restart animations,
     * timers etc. when the function is called.
     */
     IMPORT_C virtual void ExitPowerSaveModeL();

    /**
     * Create a component interface according to the given type.
     * @param aType Type of the interface to create
     * @return Created interface or NULL if the provided type is not supported.
     */
    IMPORT_C virtual XnComponentInterface::MXnComponentInterface* MakeInterfaceL(
        const TDesC8& aType );

protected:
    /**
     * C++ default constructor.
     */
    IMPORT_C CXnComponent();

    /**
     * Two-phased constructor.
     */
    IMPORT_C void ConstructL();
    
public:
    
    /**
     * Routes the data stream for the external rendering plugin.
     *
     * @since Series 60 5.2
     * @param aData Data stream.
     * @param aType Type of the stream.
     * @param aIndex Index of the data.
     */
    IMPORT_C void SetDataL( const TDesC8& aData, const TDesC& aType, TInt aIndex );

private:
    // Data

    /**
     * Pointer to control adapter.
     * Own.
     */
    CXnControlAdapter* iAdapter;

    /**
     * Component's node.
     * Not own.
     */
    CXnNodePluginIf* iNode;
    };

#endif