classicui_pub/misc_controls_api/inc/eikcapca.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 15 Jul 2010 18:56:19 +0300
branchRCL_3
changeset 17 a1caeb42b3a3
parent 0 2f259fa3e83a
permissions -rw-r--r--
Revision: 201025 Kit: 2010127

/*
* Copyright (c) 1997-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:
*
*/


#if !defined(__EIKCAPCA_H__)
#define __EIKCAPCA_H__

#include <e32base.h>

class CEikCaptionedControl;
class CCoeControl;
class CEikCapCArrayExtension;

class CEikCapCArray : public CArrayPtrFlat<CEikCaptionedControl>
	{
public:
	/** Constructor
     *
     * Creates CEikCapCArray with a granilarity.
     *
     * @param aGranularity how many items will be allocated each time allocation happens
	 */
	IMPORT_C CEikCapCArray(TInt aGranularity);
    
    /** Destructor
     *
     * Destroys CEikCapCArray
     */
	IMPORT_C ~CEikCapCArray();

	/** MinimumSize() returns minimum size for the array
     *
     * MinimumSize calculates minimum possible size for
     * the captioned control array. 
     *
     * @return size in pixels
	 */
	IMPORT_C TSize MinimumSize();
 
    /** SetRect() sets the rectangle of the captionedcontrolarray
     *
     * SetRect layouts the captionedcontrolarray. Captioned
     * control rectangles are calculated based on provided rectangle
     * and sizes of the captioned controls.
     *
     * @param aRect Rectangle for the whole array
     */
	IMPORT_C void SetRect(const TRect& aRect);
	
	/** ResetMinimumSizes() clears size information
     *
     * ResetMinimumSizes goes through all captionedcontrols
     * and resets the minimum size information of the
     * captionedcontrols
	 */
	IMPORT_C void ResetMinimumSizes();

    /** LineIndexFromId() provides line index in array based on id number
     *
     * Every captionedcontrol has iId and based on the id,
     * LineIndexFromId goes through the captionedcontrolarray
     * and finds the captionedcontrol's position in the array
     * based on the id provided
     *
     * @param aControlId captionedcontrol's iId.
     */
	IMPORT_C TInt LineIndexFromId(TInt aControlId) const;

    /** FindLineIndex() finds line index based on control
     * 
     * Every captionedcontrol has iControl CCoeControl which
     * implements the control for the DLG_LINE. FindLineIndex
     * goes through all captionedcontrols and finds the one
     * which has aControl as it's control.
     *
     * @param aControl control to be found
     */
	IMPORT_C TInt FindLineIndex(const CCoeControl* aControl) const;

    /** DeleteLine() removes line from captionedcontrolarray
     *
     * Elements from CaptionedControlArray can be removed
     * by calling DeleteLine method.
     *
     * @param aIndex index of the line to be removed
     */
	IMPORT_C void DeleteLine(TInt aIndex);

	/** AdjustAllIds() modified iId fields of the captionedcontrols
     * 
     * @param aControlIdDelta how much to increase or decrease control id's
     */
	IMPORT_C void AdjustAllIds(TInt aControlIdDelta);

	/** SetDensePacking() sets dense packing flag
     *
     * @param aDensePacking whether dense packing flag is on
  	 */
	IMPORT_C void SetDensePacking(TBool aDensePacking);
	TBool CalcItemIndexes(TInt &aTopItemIndex, TInt &aMiddleItems, TInt &aBottomItemIndex, TSize aAreaSize);
	TRect Rect() const;
	void SetRect(const TRect& aRect, TInt aTop, TInt aMiddle, TInt aBottom);
	void CreateExtensionL();
	CEikCapCArrayExtension *ExtensionOrNull() const;
	
	/**
     * Return the index of the line at aYPos.
     */
	TInt YPositionToLineIndex( TInt aYPos ) const;
	
	/**
     * Returns line's top y coordinate.
     */
	TInt LineIndexToYPosition( TInt aLine, TInt aTopY ) const;
	
	/**
     * Moves aLine to the visible screen area or out of it.
     */
	void MoveLineToScreen( TInt aLine, TInt aTopY, TBool aVisible );
	
    /**
     * Calculates the line that should be focused when a navigation key is
     * pressed while in form view mode.
     *
     * @since S60 5.2
     * @param aCurrentLine Current line's index.
     * @param aTopY View's top y coordinate.
     * @return Line that should be focused.
     */
    TInt FocusableLine( TInt aCurrentLine, TInt aTopY );
	
private:
    /**
    * Positions controls in real locations.
    */
    void SetRealRect( const TRect& aRect, TInt aTop, TInt aBottom );
	
private:
	CEikCapCArrayExtension *iExtension;
	TBool iDensePacking;
	};

#endif