textinput/peninputarc/inc/pensrvcliinc/peninputuilayoutowner.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 21 Jun 2010 16:02:35 +0300
branchRCL_3
changeset 29 857bebeecec0
parent 0 eb1f2e154e89
permissions -rw-r--r--
Revision: 201023 Kit: 2010125

/*
* Copyright (c) 2006-2006 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:  interface for pen input ui layout owner
*
*/



#ifndef M_FEPUILAYOUTOWNER_H
#define M_FEPUILAYOUTOWNER_H

#include <bitdev.h>

#include "peninputuilayoutownerinf.h"

class CPeninputServer;


/**
 * Class MLayoutOwner.
 *
 * Interface for layout owner. 
 * A layout owner is responsible for displaying the layout.
 *
  * @since S60 V4.0
 */
class CPeninputUiLayoutOwner : public CBase,
                               public MLayoutOwner
    {
public:
    /** 
     * Epoc constructor. Leaves the created object on cleanup stack.
     *
     * @since S60 v4.0
     */
    static CPeninputUiLayoutOwner* NewL( CPeninputServer& aServer );    
           
    /**
     * Destructor
     *
     * @since S60 v4.0
     */
    virtual ~CPeninputUiLayoutOwner();
    
protected:
        /**
    * constructor.
    *
    * @since S60 v4.0        
    */
    CPeninputUiLayoutOwner( CPeninputServer& aServer );

    /**
    * 2nd phase constructor.
    *
    * @since S60 v4.0        
    */
    void ConstructL();
 
public: // from MLayoutOwner
    /**
     * Update a rectangle area
     *
     * @since S60 v4.0
     * @param aRect The rectangle area to be updated
     * @param aFullUpdateFlag Full update flag.Update whole area if true.
     * @param aFlag Flag indicates immediately update.
     */
    virtual void UpdateArea(const TRect& aRect,TBool aFullUpdateFlag, TBool aFlag);

    /**
     * Set layout position. This should only be called after layout has change 
     * its position, i.e, the layout top left is the new position.
     *
     * @since S60 v4.0
     * @param aNewPos The new top left position of the layout
     * @return Return the old position of the layout
     */
    virtual TPoint SetPosition(const TPoint& aNewPos);

    /**
     * Get the Bitmap context for drawing.
     *
     * @since S60 v4.0
     * @return bitmap context
     */
    virtual CBitmapContext* BitmapContext ();

    /**
     * Get the bitmap device
     *
     * @since S60 v4.0
     * @return The bitmap device for drawing
     */
    virtual CFbsBitmapDevice* BitmapDevice();

    /**
     * Get the mask bitmap device
     *
     * @since S60 v4.0
     * @return The mask bitmap device for drawing
     */
    virtual CFbsBitmapDevice* MaskBmpDevice();
    
    /**
     * Hide or show the layout
     *
     * @since S60 v4.0     
     * @param aHideFlat Flag to hide or show the layout.Hide layout if it's true.
     */
    virtual void Hide(TBool aHideFlag = ETrue);
    
    /**
     * Signal owner that there is an event
     *
     * @since S60 v4.0     
     * @param aEventType The event type
     * @param aEventData The event data
     */    
    virtual void SignalOwner(TInt aEventType, const TDesC& aEventData);
    
    /**
     * Handle layout size change event
     *
     * @since S60 v4.0     
     * @param aSize The new layout size
     * @return standard symbian error code
     */       
    virtual TInt LayoutSizeChanged(const TSize& aSize, TBool aNeedUpdate = ETrue);
    
    /**
     * Get layout position and it's rect.
     * The position is relative to it's parent window or screen.
     * The size includes all invisible layout area as well as the shadow.
     *
     * @since S60 v4.0     
     * @return layout position.
     */       
    virtual TRect LayoutRect();    
    
    /**
     * Update UI layout immediatelly.
     *
     * @since S60 v5.0     
     * @return None.
     */       
    virtual void FlushUi();    
private:
    CPeninputServer& iServer;
    };

#endif //M_FEPUILAYOUTOWNER_H