uifw/ganes/inc/HgMarquee.h
author William Roberts <williamr@symbian.org>
Wed, 10 Nov 2010 12:08:34 +0000
branchRCL_3
changeset 76 5c9f0ba5102a
parent 0 2f259fa3e83a
permissions -rw-r--r--
Improve debug tracing of AknGlobalNote::StartL - Bug 2673

/*
* Copyright (c) 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:       Text scrolling functionality.
*
*/


#ifndef __HGMARQUEE_H__
#define __HGMARQUEE_H__

#include <coecntrl.h>
#include <coemain.h>
#include <babitflags.h>

// FORWARD DECLARATIONS
class TAknTextComponentLayout;
class TAknLayoutText;


/**
* Marquee control for AVKON
*
*/
NONSHARABLE_CLASS(CHgMarquee) : public CBase
    {
    public:
	
        /**
        * Two-phased constructor.
        * @param aLoops Max number of loops to be executed
        * @param aScrollAmount The amount of pixels scrolled per iteration
        * @param aScrollDelay The interval between iterations
        */
        static CHgMarquee* NewL(const TInt aLoops = 1, 
                        const TInt aScrollAmount = 6, const TInt aScrollDelay = 1000000);

        /**
        * Two-phased constructor.
        * @param aLoops Max number of loops to be executed
        * @param aScrollAmount The amount of pixels scrolled per iteration
        * @param aScrollDelay The interval between iterations
        */
        static CHgMarquee* NewLC(const TInt aLoops = 1, 
                        const TInt aScrollAmount = 6, const TInt aScrollDelay = 1000000);
        
        /** 
        * set redraw event callback
        *
        */
        void SetRedrawCallBack( TCallBack& aRedrawEventCallback );

        /** 
        * Draws text in the current position. 
        * After the marquee object is created calling this should be enough.
        * @since S60 3.1
        * @param aGc Graphics context.
        * @param aRect Parent rectangle for the text layout.
        * @param aTextLayout Text layout that is used to draw the text.
        * @param aText Text to marquee.
        * @param aFont Font used in drawing. If this is NULL then the font is
        * taken from the aTextLayout.
        * @param aColor Color of the text        
        * @return ETrue = All the loops have been executed, EFalse = There are loops to be executed.
        */
        TBool DrawText( CWindowGc& aGc,
                                 const TRect& aRect,
                                 const TAknTextComponentLayout& aTextLayout,
                                 const TDesC& aText,
                                 const TRgb& aColor );

    	/**
    	* Enable or disable logical to visual reordering in text drawing.
        * By default, it is enabled. This has any effect only when bidirectional text
        * is rendered.
        *
        * If the text is converted to visual order prior to passing it to DrawText methods
        * of this class, then the conversion should be disabled by calling this method.
        *
    	* @since 3.1
    	* @param aUseConversion Enable or disable conversion.
    	*/
	    void UseLogicalToVisualConversion( TBool aUseConversion );
       
        /** 
        * Starts scrolling the text.
        *
        */
        void Start();

        /** 
        * Stops scrolling the text.
        *
        */
        void Stop();

        /** 
        * Resets the animation data.
        * 
        */
        void Reset();
	
	    /** 
        * Is marquee on?
        *
        */
    #ifdef __WINS__
        const TBool IsMarqueeOn();
    #else
    	TBool IsMarqueeOn();
    #endif // __WINS__
        
        /** 
        * Sets the amount of pixels the text moves per animation loop
        *
        */
	    void SetSpeedInPixels(TInt aSpeed);
	    
        /** 
        * Sets the delay between loops.
        *
        */
        void SetDelay(TInt aDelay); 
        
        /** 
        * Sets the animation interval (=frames/second)
        *
        */
	    void SetInterval(TInt aInterval);
        
        /** 
        * Sets the maximum number of loops to be executed.
        *
        */
        void SetLoops(TInt aLoops);    
        
        /** 
        * Enables / disables marquee feature but does NOT start it yet.
        * 
        */
        void EnableMarquee(TBool aEnable); // ETrue = ON, EFalse = OFF

        /** 
        * Destructor
        *
        */
        virtual ~CHgMarquee();


        // from CCoeControl
    protected:

    private:
    
    enum TMarqueeFlags
        {
        // Is marquee enabled or not
        EFlagIsOn,
        // RTL when the first directional character is LTR character
        EFlagIsWestern,
        // If true, there needs to be a delay before the scrolling starts
        EFlagIsBeginningOfLoop,
        // Is conversion needed
        EFlagUseVisualToLogicalConversion,
        // In case of two-lined lists etc, this flag is turned on
        // when the text has been scrolled all the way to the left/right.
        EFlagIsWaitingForCallBack
        };
        
        /** 
        * Default constructor
        *
        */
        CHgMarquee(const TInt aLoops, const TInt aScrollAmount, const TInt aScrollDelay);

        /**
        * By default Symbian 2nd phase constructor is private.
        */
        void ConstructL();

	    /**
        * advance text and issue a callback to parent
        */
        void DoScroll();

	    /**
        * static callback for periodic timer
        */
        static TInt ScrollEvent(TAny * aPtr);

        void DrawWestern( CWindowGc& aGc,
                                 const TRect& aRect,
                                 const TRect& aMarqueeRect,
                                 const TAknTextComponentLayout& aTextLayout,
                                 TAknLayoutText aLayout,
                                 const TDesC& aText,
                                 TInt aTextWidth,
                                 const TRgb& aColor );

        void DrawNonWestern( CWindowGc& aGc,
                                 const TRect& aRect,
                                 const TRect& aMarqueeRect,
                                 const TAknTextComponentLayout& aTextLayout,
                                 TAknLayoutText aLayout,
                                 const TDesC& aText,
                                 TInt aTextWidth,
                                 const TRgb& aColor );


private:    // Data
    
    CPeriodic* iPeriodicTimer;        // creates scrolling events
    TInt       iDelta;                // The difference between the old and new position in pixels
    TInt       iDelay;                // Delay between loops in microseconds
    TInt       iSpeed;                // Amount of pixels the text moves in a frame
    TInt       iInterval;             // The interval between frame updates (= "frames/second")
    TCallBack  iCallBack;             // Callback to parent
    TInt       iLoops;                // Amount of loops executed
    TInt       iMaxLoops;             // Amount of loops *to be executed*
    TBitFlags  iFlags;
    TBool      iLastCharacter;        // It is ETrue if last character has appeared, otherwise.
    };

#endif // __HGMARQUEE_H__