fmradio/fmradio/inc/fmradiologo.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 02 Feb 2010 00:17:10 +0200
changeset 0 f3d95d9c00ab
permissions -rw-r--r--
Revision: 201003 Kit: 201005

/*
* Copyright (c) 2009 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:  Definition of the class CFMRadioLogo.
*
*/


#ifndef FMRADIOALFLOGO_H
#define FMRADIOALFLOGO_H

// INCLUDES

#include <alf/alfcontrol.h>

#include "fmradioidlecontrolinterface.h"
// FORWARD DECLARATIONS

class CAlfImageVisual;
class MFMRadioLogoObserver;
class CAlfAnchorLayout;

// CLASS DEFINITION

/**
* Class for handling the radio icon
* 
*/ 
class CFMRadioLogo : public CAlfControl,
                        public MFMRadioIdleControlInterface
    {
    public:    // Constructors and destructor
        /**
        * Epoc two-phased constructor.
        * @param aEnv Reference to the Alf environment instance.
        * @return Pointer to this Indicator component.
        */
        static CFMRadioLogo* NewL( CAlfEnv& aEnv );
        
        /**
        * Destructor
        */
        virtual ~CFMRadioLogo();

    public:    // New functions
        /**
        * Sets the indicator opacity in visible state.
        * @param aOpacity The indicator opacity
        */
        void SetOpacityInVisibleState( const TReal aOpacity );
        
        /**
        * Sets the indicator opacity in hidden state.
        * @param aOpacity The indicator opacity
        */
        void SetOpacityInHiddenState( const TReal aOpacity );
        
        /** 
        * Sets the indicator rectangle
        * @param aRect Rectangle to the indicator
        */
        void SetRect( const TRect& aRect );
        
        /** 
        * Sets the Observer
        * @param aObserver The object to observe the control
        */
        void SetObserver( MFMRadioLogoObserver* aObserver );
        
        /** 
        * Removes the observer
        */
        void RemoveObserver( MFMRadioLogoObserver* aObserver );
        
        /** 
        * Switch to landscape image.
        * @param aShow. ETrue for landscape, EFalse for portrait 
        */        
        void SwitchToLandscapeImage( TBool aShow );
        
    private:
        /**
        * C++ default constructor
        */
        CFMRadioLogo ();
        
        /**
        * EPOC second phase constructor.
        * @param aEnv Reference to the Hitchcock environment instance.
        */
        void ConstructL( CAlfEnv& aEnv );
        
    private: // Functions from base classes
        /**
        * from MFMRadioIdleControlInterface
        */
        void Show();
        
        /**
        * from MFMRadioIdleControlInterface
        */
        void Hide();
        
        /**
        * from MFMRadioIdleControlInterface
        */        
        void Deactivate();

        /**
        * from CAlfControl
        */
        TBool OfferEventL( const TAlfEvent& aEvent );
        
    private:    // New functions
        /**
        * Sets the fading animation to the CAlfVisual object.
        * @param aVisual a pointer to the visual object
        * @param aFadingTime Time duration after the visual object has been faded. Fading duration in milliseconds. 
        * @param aOpacity Target opacity value
        */
        void Fade( CAlfVisual* aVisual, TInt aFadingTime, TReal aOpacity );
        
        /**
        * Sets absolute rect of the anchor by top left and bottom right points.
        * @param aAnchor Anchor layout for setting placement
        * @param aOrdinal Index of visual element
        * @param aTopLeftPosition Top left point of the rect
        * @param aBottomRightPosition Bottom right point of the rect
        */
        void SetAbsoluteCornerAnchors( CAlfAnchorLayout* aAnchor,
                                       TInt aOrdinal,
                                       const TPoint& aTopLeftPosition,
                                       const TPoint& aBottomRightPosition );
        /**
        * Creates the needed drawing layers and visual objects
        * for the logo.
        */
        void CreateImageVisualsL();
        
    private:
        /**
         * Alf custom events for the logo fade effects.
         * Logo stays visible couple of seconds after the
         * fade in event. 
         */
        enum TFadeCustomEvent
            {
            EFadeInCompleted,               // Fade in completed.
            ELogoDisplayTimerCompleted      // Visibility time ended.
            };

    private:// Data
        /** Anchor layout for the logo. Not owned */
        CAlfAnchorLayout* iLogoAnchor;
        /** logo opacity in visible state */
        TReal iOpacityInVisibleState;
        /** logo opacity in hidden state */
        TReal iOpacityInHiddenState;
        /** logo rectangle */
        TRect iRect;
        /** Array of observers. */
        RPointerArray<MFMRadioLogoObserver> iObservers;
        // visual containing the default radio icon. Not owned
        CAlfImageVisual* iImageVisual;
        // default radio icon in portrait mode
        TAlfImage iPortraitImage;
        // default radio icon in landscape mode
        TAlfImage iLandscapeImage;
        /** File name for the background bitmap. Owned. */
        HBufC* iBackgroundBitmapFileName;
        // flag for visibility status
        TBool iIsVisible;
    };

#endif //FMRADIOALFLOGO_H