--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/textinput/peninputvkbkr/src/peninputgenericlafdatamgr.cpp Wed Sep 01 12:23:33 2010 +0100
@@ -0,0 +1,1494 @@
+/*
+* Copyright (c) 2002-2005 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: peninput VKB data manager
+*
+*/
+
+
+// System includes
+#include <peninputdataconverter.h>
+#include <peninputcommonlayoutglobalenum.h>
+#include <AknUtils.h>
+#include <aknlayoutscalable_avkon.cdl.h>
+#include <peninputpluginutils.h>
+
+// User includes
+#include "PeninputVkbKr.hrh"
+#include "peninputgenericvkblafdatamgr.h"
+
+#define LAF_MODIFY 1
+
+const TInt KKeypadLayout[][2] =
+ {
+ { 10, 3 }, // 10x3
+ { 11, 3 }, // 11x3
+ { 11, 4 }, // 11x4
+ { 9, 3 }, // 9x3
+ { 3, 3 }, // 3x3
+ };
+
+const TInt KVkbTopAndBottomParam[] = { 5, 3, 4 };
+typedef TAknWindowComponentLayout (*Pfun)(TInt aVariety, TInt aCol = 0, TInt aRow = 0);
+
+const Pfun cell_pane_func[]=
+ {
+ AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane,
+ AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_cp01,
+ AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_cp02,
+ AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_cp03,
+ AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_cp04,
+ AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_cp05,
+ AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_cp06,
+ AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_cp07,
+ AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_cp08,
+ AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_cp09,
+ AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_cp10
+ };
+// { 0, 34, 68, 102, 136, 170, 204, 238, 272, 305 };
+const TInt KKeypadRectXPoint10x[] =
+ { 0, 34, 68, 102, 136, 170, 204, 238, 272, 305 };
+const TInt KKeypadCellWidth10x[] =
+ { 41, 41, 41, 41, 41, 41, 41, 41, 41, 44 };
+// { 0, 32, 63, 94, 125, 155, 230, 217, 248, 279, 311 };
+const TInt KKeypadRectXPoint11x[] =
+ { 0, 31, 62, 93, 124, 155, 186, 217, 248, 278, 311 };
+const TInt KKeypadCellWidth11x[] =
+ { 36, 36, 36, 36, 36, 36, 36, 36, 36, 39, 39 };
+const TInt KKeypadRectXPoint3x[] =
+ { 0, 97, 194, 291 };
+const TInt KKeypadCellWidth3x[] =
+ { 120, 120, 120, 44 };
+
+// ======== MEMBER FUNCTIONS ========
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::NewL
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+CPeninputGenericVkbLafMgr* CPeninputGenericVkbLafMgr::NewL()
+ {
+ CPeninputGenericVkbLafMgr* self = NewLC();
+ CleanupStack::Pop(self);
+
+ return self;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::NewLC
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+CPeninputGenericVkbLafMgr* CPeninputGenericVkbLafMgr::NewLC()
+ {
+ CPeninputGenericVkbLafMgr* self =
+ new ( ELeave ) CPeninputGenericVkbLafMgr();
+ CleanupStack::PushL( self );
+ self->ConstructL();
+
+ return self;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::CPeninputGenericVkbLafMgr
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+CPeninputGenericVkbLafMgr::CPeninputGenericVkbLafMgr():
+ iInputMode(EPluginInputModeNone)
+ {
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::~CPeninputGenericVkbLafMgr
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+CPeninputGenericVkbLafMgr::~CPeninputGenericVkbLafMgr()
+ {
+ delete iLafData;
+ iLafData = NULL;
+ }
+
+TBool CPeninputGenericVkbLafMgr::IsValid()
+ {
+ if (!iLafData)
+ return EFalse;
+
+ return iLafData->IsValid();
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::ConstructL
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void CPeninputGenericVkbLafMgr::ConstructL()
+ {
+
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::SetInputMode
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void CPeninputGenericVkbLafMgr::SetInputModeL( TPluginInputMode aInputMode)
+ {
+ if (iInputMode == aInputMode)
+ {
+ return;
+ }
+
+
+ if (iLafData)
+ {
+ delete iLafData;
+ iLafData = NULL;
+ }
+
+ if (aInputMode == EPluginInputModeVkb)
+ {
+ iLafData = CPeninputLafDataVKB::NewL(ELayoutNone);
+ }
+ else if (aInputMode == EPluginInputModeFSQ)
+ {
+ iLafData = CPeninputLafDataFSQ::NewL(ELayoutNone);
+ }
+ else
+ {
+ User::Leave(KErrNotSupported);
+ }
+ }
+
+TPluginInputMode CPeninputGenericVkbLafMgr::InputMode() const
+ {
+ return iInputMode;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::SetLayoutType
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void CPeninputGenericVkbLafMgr::SetLayoutType( TPeninputQwtLayoutType aLayoutType )
+ {
+ ASSERT(iLafData);
+ iLafData->SetLayoutType( aLayoutType );
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::SetLafOption
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void CPeninputGenericVkbLafMgr::SetLafOption( TPeninputVkbLafOption aOption )
+ {
+ if( iLafData->LafOption() == aOption )
+ return;
+
+ iLafData->SetLafOption( aOption );
+ TRAP_IGNORE(iLafData->ConstructL());
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::SetLafOption
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+TPeninputVkbLafOption CPeninputGenericVkbLafMgr::OptionType() const
+ {
+ return iLafData->LafOption();
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::GetButtonRect
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void CPeninputGenericVkbLafMgr::GetButtonRect( TPeninputCommonCtrlID aButtonID,
+ TRect& aOutterRect,
+ TRect& aInnerRect )
+ {
+ ASSERT(iLafData);
+ const TPeninputButtonLayoutData& data = iLafData->ButtonLayoutData( aButtonID );
+ aOutterRect = data.iRect;
+ aInnerRect = data.iInnerRect;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::KeyRect
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const TRect& CPeninputGenericVkbLafMgr::KeypadRect() const
+ {
+ ASSERT(iLafData);
+ const TPeninputKeyLayoutData& data = iLafData->KeypadLayoutData();
+ return data.iKaypadRect;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::ICFRect
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const TRect& CPeninputGenericVkbLafMgr::ICFRect() const
+ {
+ ASSERT(iLafData);
+ return iLafData->ICFLayoutData().iRect;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::ICFPromptTextFont
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const CFont* CPeninputGenericVkbLafMgr::ICFPromptTextFont() const
+ {
+ ASSERT(iLafData);
+ return iLafData->ICFLayoutData().iPromptTextFont;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::ICFTextFont
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const CFont* CPeninputGenericVkbLafMgr::ICFTextFont() const
+ {
+ ASSERT(iLafData);
+ return iLafData->ICFLayoutData().iTextFont;
+ }
+
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::KeyTextLayout
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+TAknTextLineLayout CPeninputGenericVkbLafMgr::KeyTextLayout() const
+ {
+ ASSERT(iLafData);
+ return iLafData->KeypadLayoutData().iTextLayout;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::ICFPromptTextFont
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void CPeninputGenericVkbLafMgr::GetICFConfig( TPeninputICFConfig& aICFConfig )
+ {
+ ASSERT(iLafData);
+ const TPeninputEntryLayoutData& icfLayout = iLafData->ICFLayoutData();
+ aICFConfig.iLeftMargin = icfLayout.iPromptTextRect.iTl.iX - icfLayout.iRect.iTl.iX;
+ aICFConfig.iRightMargin = icfLayout.iRect.iBr.iX - icfLayout.iPromptTextRect.iBr.iX;
+ aICFConfig.iTopMargin = icfLayout.iPromptTextRect.iTl.iY - icfLayout.iRect.iTl.iY;
+ aICFConfig.iTextLineHeight = icfLayout.iPromptTextRect.Height();
+ aICFConfig.iLineSpaceMargin = icfLayout.iTextRect.iTl.iY - icfLayout.iPromptTextRect.iBr.iY;
+ }
+
+//
+const TRect& CPeninputGenericVkbLafMgr::EntirePaneRect() const
+ {
+ ASSERT(iLafData);
+ return iLafData->QwtLayoutData().iQwtRect;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::KeyRect
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void CPeninputGenericVkbLafMgr::GetKeyRect( TInt aColume,
+ TInt aRow,
+ TRect& aKeyRect,
+ TRect& aCharRect ) const
+ {
+ ASSERT(iLafData);
+ TInt colNum = 0;
+ TInt index = 0;
+ switch( iLafData->LayoutType() )
+ {
+ case ELayout10x3:
+ {
+ colNum = 10;
+ }
+ break;
+ case ELayout11x3:
+ {
+ colNum = 11;
+ }
+ break;
+ case ELayout11x4:
+ {
+ colNum = 11;
+ }
+ break;
+ case ELayout9x3:
+ {
+ colNum=9;
+ }
+ break;
+ case ELayout3x3:
+ {
+ colNum = 3;
+ }
+ break;
+ }
+ index = aRow * colNum + aColume;
+ aKeyRect = iLafData->KeypadLayoutData().iRects[index];
+ aCharRect = iLafData->KeypadLayoutData().iCharRects[index];
+ }
+
+TPeninputQwtLayoutType CPeninputGenericVkbLafMgr::LayoutTypeFromRowsColumns(const TInt aRows,
+ const TInt aColumns)
+ {
+ TPeninputQwtLayoutType ret;
+
+ if (aRows == 3 && aColumns == 10)
+ {
+ ret = ELayout10x3;
+ }
+ else if (aRows == 3 && aColumns == 11)
+ {
+ ret = ELayout11x3;
+ }
+ else if (aRows == 4 && aColumns == 11)
+ {
+ ret = ELayout11x4;
+ }
+ else if (aRows == 3 && aColumns == 9)
+ {
+ ret = ELayout9x3;
+ }
+ else if (aRows == 3 && aColumns == 3)
+ {
+ ret = ELayout3x3;
+ }
+ else
+ {
+ ret = ELayoutNone;
+ }
+
+ return ret;
+ }
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::KeyTextFont
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const CFont* CPeninputGenericVkbLafMgr::KeyTextFont() const
+ {
+ ASSERT(iLafData);
+ return iLafData->KeypadLayoutData().iFont;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::KeyTextFont
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const TRect& CPeninputGenericVkbLafMgr::RangbarRect() const
+ {
+ ASSERT(iLafData);
+ return iLafData->RangbarLayoutData().iRect;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::KeyTextFont
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const TRect& CPeninputGenericVkbLafMgr::TitlebarRect() const
+ {
+ ASSERT(iLafData);
+ return iLafData->QwtLayoutData().iTitlebarRect;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::ClientRect
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const TRect& CPeninputGenericVkbLafMgr::ClientRect() const
+ {
+ ASSERT(iLafData);
+ return iLafData->QwtLayoutData().iClientRect;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::RangbarCellCount
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+TInt CPeninputGenericVkbLafMgr::RangbarCellCount() const
+ {
+ ASSERT(iLafData);
+ return iLafData->RangbarLayoutData().iCellDataArray.Count();
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::RangbarCellCount
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void CPeninputGenericVkbLafMgr::RangbarCellAt( TInt aIndex,
+ TRect& aOutterRect,
+ TRect& aInnerRect )
+ {
+ ASSERT(iLafData);
+ aOutterRect = iLafData->RangbarLayoutData().iCellDataArray[aIndex].iRect;
+ aInnerRect = iLafData->RangbarLayoutData().iCellDataArray[aIndex].iInnerRect;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputGenericVkbLafMgr::GetSpaceButtonExLayoutInfo
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void CPeninputGenericVkbLafMgr::GetSpaceButtonExLayoutInfo( TRect& aIconsFrameRect,
+ TRect& aMiddleIconRect ) const
+ {
+ ASSERT(iLafData);
+ aIconsFrameRect = iLafData->QwtLayoutData().iSpaceButtonEx.iIconsFrameRect;
+ aMiddleIconRect = iLafData->QwtLayoutData().iSpaceButtonEx.iMiddleIconRect;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputQwtLayoutDataInfo::~CPeninputQwtLayoutDataInfo
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+CPeninputQwtLayoutDataInfo::~CPeninputQwtLayoutDataInfo()
+ {
+ iKeypad.iRects.Close();
+ iKeypad.iCharRects.Close();
+ iRangbar.iCellDataArray.Close();
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataCommon::DestoryDataCommon
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void MPeninputLafDataCommon::DestoryDataCommon()
+ {
+ iLayoutDataInfo.ResetAndDestroy();
+ iLayoutDataInfo.Close();
+ }
+
+MPeninputLafDataCommon::~MPeninputLafDataCommon()
+ {
+
+ }
+// CPeninputLafDataCommon::ButtonLayoutData(TInt aButtonID)
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const TPeninputButtonLayoutData& MPeninputLafDataCommon::ButtonLayoutData( TInt aButtonID ) const
+ {
+ ASSERT( IsValid() );
+ const TPeninputButtonLayoutData* pData = NULL;
+
+ switch( aButtonID )
+ {
+ case EPeninutWindowCtrlIdMoveBtn:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iMoveButton);
+ }
+ break;
+ case EPeninutWindowCtrlIdCloseBtn:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iCloseButton);
+ }
+ break;
+ case EPeninutWindowCtrlIdOptionBtn:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iOptionButton);
+ }
+ break;
+ case EPeninutWindowCtrlIdBackspaceBtn:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iClearButton);
+ }
+ break;
+ case EPeninutWindowCtrlIdEnterBtn:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iEnterButton);
+ }
+ break;
+ case EPeninutWindowCtrlIdSwitchToHwrBtn:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iSwitchButton);
+ }
+ break;
+ case EPeninutWindowCtrlIdSpaceBtn:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iSpaceButton);
+ }
+ break;
+ case EPeninutWindowCtrlIdShiftBtn:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iShiftButton);
+ }
+ break;
+ case EPeninupWindowCtrlIdArrowLeftBtn:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iLeftButton);
+ }
+ break;
+ case EPeninupWindowCtrlIdArrowRightBtn:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iRightButton);
+ }
+ break;
+ case EPeninutVkbCtrlIdSymbolTableUp:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iTableUpButton);
+ }
+ break;
+ case EPeninutVkbCtrlIdSymbolTableDown:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iTableDownButton);
+ }
+ break;
+ case EPeninutVkbCtrlIdSymbolTablePageLabel:
+ {
+ pData = &(iLayoutDataInfo[iLayoutType]->iTablePageLabel);
+ }
+ break;
+ default:
+ ASSERT(EFalse);
+ break;
+ }
+ ASSERT(pData);
+ return *pData;
+ }
+// ---------------------------------------------------------------------------
+// CPeninputLafDataCommon::ICFLayoutData()
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const TPeninputEntryLayoutData& MPeninputLafDataCommon::ICFLayoutData() const
+ {
+ ASSERT( IsValid() );
+ return iLayoutDataInfo[iLayoutType]->iICF;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataCommon::KeypadLayoutData()
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const TPeninputKeyLayoutData& MPeninputLafDataCommon::KeypadLayoutData() const
+ {
+ ASSERT( IsValid() );
+ return iLayoutDataInfo[iLayoutType]->iKeypad;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataCommon::RangbarLayoutData(TInt aRangbarID)
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const TPeninputRangeBarLayoutData& MPeninputLafDataCommon::RangbarLayoutData() const
+ {
+ ASSERT( IsValid() );
+ return iLayoutDataInfo[iLayoutType]->iRangbar;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataCommon::RangbarLayoutData(TInt aRangbarID)
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const CPeninputQwtLayoutDataInfo& MPeninputLafDataCommon::QwtLayoutData() const
+ {
+ ASSERT( IsValid() );
+ return *iLayoutDataInfo[iLayoutType];
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataCommon::ConstructL()
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void MPeninputLafDataCommon::ConstructL()
+ {
+ ReadLafInfoL();
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataCommon::ConstructL()
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+TBool MPeninputLafDataCommon::IsValid() const
+ {
+ return ( iLayoutDataInfo.Count() && iLayoutType != ELayoutNone ) ? ETrue : EFalse;
+ }
+
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataCommon::GetTopAndBottomPaneInfo
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void MPeninputLafDataCommon::GetTopAndBottomPaneInfo( const TRect& aParentWndRect,
+ TInt aLayoutType,
+ TInt aLayoutParam,
+ CPeninputQwtLayoutDataInfo& aDataInfo )
+ {
+ const TInt endFSQType = 2;
+
+
+
+ // judge which case
+ TBool isVKB = aLayoutParam > endFSQType ? ETrue : EFalse;
+
+ TAknWindowLineLayout toppane, bottompane, bottomgrid;
+ TAknWindowLineLayout topleftpane, topentrypane, toprightpane;
+ TAknWindowLineLayout cellBtn, cellBtnInner;
+
+ TAknLayoutRect toppaneRect, bottompaneRect, bottomgridRect;
+ TAknLayoutRect topleftpaneRect, topentrypaneRect, toprightpaneRect;
+ TAknLayoutRect cellBtnRect, cellBtnInnerRect;
+ TAknTextLineLayout cellText;
+ TAknLayoutText txt;
+ TRect keypadRect;
+ TRect innerRect;
+ // top pane
+ if( isVKB )
+ {
+ toppane = AknLayoutScalable_Avkon::
+ vkb2_area_top_pane(KVkbTopAndBottomParam[aLayoutType]).LayoutLine();
+ }
+ else
+ {
+ toppane = AknLayoutScalable_Avkon::vkb2_area_top_pane(aLayoutParam).LayoutLine();
+ }
+ toppaneRect.LayoutRect(aParentWndRect, toppane);
+ aDataInfo.iTitlebarRect = toppaneRect.Rect();
+
+
+ topleftpane = AknLayoutScalable_Avkon::vkb2_top_grid_left_pane(aLayoutParam).LayoutLine();
+ topleftpaneRect.LayoutRect(toppaneRect.Rect(), topleftpane);
+
+ // close button
+ cellBtn = AknLayoutScalable_Avkon::vkb2_top_cell_left_pane(aLayoutParam, 0 ,0).LayoutLine();
+ cellBtnRect.LayoutRect(topleftpaneRect.Rect(), cellBtn);
+ AknPenImageUtils::CalculateGraphicRect( cellBtnRect.Rect(), innerRect );
+ aDataInfo.iCloseButton.iRect = cellBtnRect.Rect();
+ aDataInfo.iCloseButton.iInnerRect = innerRect;
+ // option button
+ cellBtn = AknLayoutScalable_Avkon::vkb2_top_cell_left_pane(aLayoutParam, 0 ,1).LayoutLine();
+ cellBtnRect.LayoutRect(topleftpaneRect.Rect(), cellBtn);
+ AknPenImageUtils::CalculateGraphicRect( cellBtnRect.Rect(), innerRect );
+ aDataInfo.iOptionButton.iRect = cellBtnRect.Rect();
+ aDataInfo.iOptionButton.iInnerRect = innerRect;
+ // entry pane
+ topentrypane = AknLayoutScalable_Avkon::vkb2_top_entry_pane(aLayoutParam).LayoutLine();
+ topentrypaneRect.LayoutRect(toppaneRect.Rect(), topentrypane);
+ aDataInfo.iICF.iRect = topentrypaneRect.Rect();
+ cellText = AknLayoutScalable_Avkon::vkb2_top_entry_pane_t1(aLayoutParam).LayoutLine();
+ aDataInfo.iICF.iPromptTextFont = AknLayoutUtils::FontFromId(cellText.iFont, NULL);
+ txt.LayoutText( topentrypaneRect.Rect(), cellText );
+ aDataInfo.iICF.iPromptTextRect = txt.TextRect();
+ cellText = AknLayoutScalable_Avkon::vkb2_top_entry_pane_t2(aLayoutParam).LayoutLine();
+ aDataInfo.iICF.iTextFont = AknLayoutUtils::FontFromId(cellText.iFont, NULL);
+ txt.LayoutText( topentrypaneRect.Rect(), cellText );
+ aDataInfo.iICF.iTextRect = txt.TextRect();
+
+ // ?? need modified later. inner rect is same as outter rect.
+ toprightpane = AknLayoutScalable_Avkon::vkb2_top_grid_right_pane(aLayoutParam).LayoutLine();
+ toprightpaneRect.LayoutRect(toppaneRect.Rect(), toprightpane);
+ if( isVKB )
+ {
+ // clear button
+ cellBtn = AknLayoutScalable_Avkon::
+ vkb2_top_grid_right_pane_g1(aLayoutParam).LayoutLine();
+ cellBtnRect.LayoutRect(toprightpaneRect.Rect(), cellBtn);
+ AknPenImageUtils::CalculateGraphicRect( cellBtnRect.Rect(), innerRect );
+ aDataInfo.iClearButton.iRect = cellBtnRect.Rect();
+ aDataInfo.iClearButton.iInnerRect = innerRect;
+ // move button (VKB)
+ cellBtn = AknLayoutScalable_Avkon::
+ vkb2_top_grid_right_pane_g4(aLayoutParam).LayoutLine();
+ cellBtnRect.LayoutRect(toprightpaneRect.Rect(), cellBtn);
+ AknPenImageUtils::CalculateGraphicRect( cellBtnRect.Rect(), innerRect );
+ aDataInfo.iMoveButton.iRect = cellBtnRect.Rect();
+ aDataInfo.iMoveButton.iInnerRect = innerRect;
+
+ }
+ else
+ {
+ // clear button
+ cellBtn = AknLayoutScalable_Avkon::vkb2_top_grid_right_pane_g1(aLayoutType).LayoutLine();
+ cellBtnRect.LayoutRect(toprightpaneRect.Rect(), cellBtn);
+ AknPenImageUtils::CalculateGraphicRect( cellBtnRect.Rect(), innerRect );
+ aDataInfo.iClearButton.iRect = cellBtnRect.Rect();
+ aDataInfo.iClearButton.iInnerRect = innerRect;
+ // left button (FSQ)
+ cellBtn = AknLayoutScalable_Avkon::vkb2_top_grid_right_pane_g2(aLayoutType).LayoutLine();
+ cellBtnRect.LayoutRect(toprightpaneRect.Rect(), cellBtn);
+ AknPenImageUtils::CalculateGraphicRect( cellBtnRect.Rect(), innerRect );
+ aDataInfo.iLeftButton.iRect = cellBtnRect.Rect();
+ aDataInfo.iLeftButton.iInnerRect = innerRect;
+ // right button (FSQ)
+ cellBtn = AknLayoutScalable_Avkon::vkb2_top_grid_right_pane_g3(aLayoutType).LayoutLine();
+ cellBtnRect.LayoutRect(toprightpaneRect.Rect(), cellBtn);
+ AknPenImageUtils::CalculateGraphicRect( cellBtnRect.Rect(), innerRect );
+ aDataInfo.iRightButton.iRect = cellBtnRect.Rect();
+ aDataInfo.iRightButton.iInnerRect = innerRect;
+ }
+
+
+ // bottom pane
+ const TInt VKBParamBottom2Range[] = { 6, 8, 8 };
+ const TInt FSQParamBottom2Range[] = { 0, 2, 4 };
+ const TInt VKBParamBottom3Range[] = { 7, 9, 9 };
+ const TInt FSQParamBottom3Range[] = { 1, 3, 5 };
+
+
+ if( isVKB )
+ {
+ bottompane = AknLayoutScalable_Avkon::
+ vkb2_area_bottom_pane(KVkbTopAndBottomParam[aLayoutType]).LayoutLine();
+ }
+ else
+ {
+ bottompane = AknLayoutScalable_Avkon::vkb2_area_bottom_pane(aLayoutParam).LayoutLine();
+ }
+ bottompaneRect.LayoutRect(aParentWndRect, bottompane);
+
+ TRect bottomRect = bottompaneRect.Rect();
+
+ // Get keypad rect
+ keypadRect.SetRect( toppaneRect.Rect().iTl.iX,
+ toppaneRect.Rect().iBr.iY,
+ bottomRect.iBr.iX,
+ bottomRect.iTl.iY);
+ aDataInfo.iKeypad.iKaypadRect = keypadRect;
+ aDataInfo.iClientRect.SetRect( toppaneRect.Rect().iTl.iX,
+ toppaneRect.Rect().iBr.iY,
+ bottomRect.iBr.iX,
+ bottomRect.iBr.iY);
+ if( isVKB )
+ {
+ aDataInfo.iQwtRect.SetRect( toppaneRect.Rect().iTl.iX,
+ toppaneRect.Rect().iTl.iY,
+ bottomRect.iBr.iX,
+ bottomRect.iBr.iY );
+ }
+ else
+ {
+ aDataInfo.iQwtRect = aParentWndRect;
+ }
+
+ TInt bottomLayoutType = 0;
+ if( isVKB )
+ {
+ bottomLayoutType = iLafOption & EOption3CellRange ?
+ VKBParamBottom3Range[aLayoutType] : VKBParamBottom2Range[aLayoutType];
+ }
+ else
+ {
+ bottomLayoutType = iLafOption & EOption3CellRange ?
+ FSQParamBottom3Range[aLayoutType] : FSQParamBottom2Range[aLayoutType];
+ }
+
+ bottomgrid = AknLayoutScalable_Avkon::vkb2_area_bottom_grid_pane(bottomLayoutType).LayoutLine();
+ bottomgridRect.LayoutRect(bottomRect, bottomgrid);
+
+ TInt maxParam = iLafOption & EOption3CellRange ? 4 : 3;
+ // shift button
+ cellBtn = AknLayoutScalable_Avkon::vkb2_cell_bottom_grid_pane(aLayoutParam, 0, 0).LayoutLine();
+ cellBtnRect.LayoutRect(bottomgridRect.Rect(), cellBtn);
+ AknPenImageUtils::CalculateGraphicRect( cellBtnRect.Rect(), innerRect );
+ aDataInfo.iShiftButton.iRect = cellBtnRect.Rect();
+ aDataInfo.iShiftButton.iInnerRect = innerRect;
+
+ TPeninputButtonLayoutData btnLayoutData;
+ for( TInt i = 1; i < maxParam; i++ )
+ {
+#ifdef LAF_MODIFY
+ if( i == 3 )
+ {
+ btnLayoutData.iRect = aDataInfo.iRangbar.iCellDataArray[i-2].iRect;
+ btnLayoutData.iRect.Move( btnLayoutData.iRect.Width(), 0 );
+ AknPenImageUtils::CalculateGraphicRect( btnLayoutData.iRect, innerRect );
+ btnLayoutData.iInnerRect = innerRect;
+ aDataInfo.iRangbar.iCellDataArray.Append( btnLayoutData );
+ break;
+ }
+#endif //LAF_MODIFY
+ // range cell
+ cellBtn = AknLayoutScalable_Avkon::vkb2_cell_bottom_grid_pane(aLayoutParam, i, 0).LayoutLine();
+ cellBtnRect.LayoutRect(bottomgridRect.Rect(), cellBtn);
+ AknPenImageUtils::CalculateGraphicRect( cellBtnRect.Rect(), innerRect );
+ btnLayoutData.iRect = cellBtnRect.Rect();
+ btnLayoutData.iInnerRect = innerRect;
+
+ aDataInfo.iRangbar.iCellDataArray.Append( btnLayoutData );
+ }
+
+ TInt count = aDataInfo.iRangbar.iCellDataArray.Count();
+ aDataInfo.iRangbar.iRect = TRect( aDataInfo.iRangbar.iCellDataArray[0].iRect.iTl,
+ aDataInfo.iRangbar.iCellDataArray[count - 1].iRect.iBr );
+
+ // input mode button ?? need modified later. inner rect is same as outter rect
+ cellBtn = AknLayoutScalable_Avkon::vkb2_area_bottom_pane_g1(bottomLayoutType).LayoutLine();
+ cellBtnRect.LayoutRect(bottomRect, cellBtn);
+ AknPenImageUtils::CalculateGraphicRect( cellBtnRect.Rect(), innerRect );
+ aDataInfo.iSwitchButton.iRect = cellBtnRect.Rect();
+ aDataInfo.iSwitchButton.iInnerRect = innerRect;
+ // enter button
+ cellBtn = AknLayoutScalable_Avkon::vkb2_area_bottom_pane_g2(bottomLayoutType).LayoutLine();
+ cellBtnRect.LayoutRect(bottomRect, cellBtn);
+ AknPenImageUtils::CalculateGraphicRect( cellBtnRect.Rect(), innerRect );
+ aDataInfo.iEnterButton.iRect = cellBtnRect.Rect();
+ aDataInfo.iEnterButton.iInnerRect = innerRect;
+ // space button
+ cellBtn = AknLayoutScalable_Avkon::vkb2_area_bottom_pane_g3(bottomLayoutType).LayoutLine();
+ cellBtnRect.LayoutRect(bottomRect, cellBtn);
+ aDataInfo.iSpaceButton.iRect = cellBtnRect.Rect();
+ aDataInfo.iSpaceButton.iRect.iTl = TPoint( aDataInfo.iRangbar.iRect.iBr.iX,
+ aDataInfo.iRangbar.iRect.iTl.iY );
+ aDataInfo.iSpaceButton.iInnerRect = cellBtnRect.Rect();
+ // 3 pieces graphics laf info
+ TRect spaceRect, iconRect, tempRect;
+ cellBtn =
+ AknLayoutScalable_Avkon::vkb2_area_bottom_space_btn_pane(bottomLayoutType).LayoutLine();
+ cellBtnRect.LayoutRect(bottomRect, cellBtn);
+ spaceRect = cellBtnRect.Rect();
+ cellBtn =
+ AknLayoutScalable_Avkon::vkb2_area_bottom_space_btn_pane_g1(bottomLayoutType).LayoutLine();
+ cellBtnRect.LayoutRect(spaceRect, cellBtn);
+ iconRect = cellBtnRect.Rect();
+ TInt nOffsetX = iconRect.iTl.iX - spaceRect.iTl.iX;
+ tempRect = spaceRect;
+ tempRect.Shrink( nOffsetX, 0 );
+ aDataInfo.iSpaceButtonEx.iIconsFrameRect = tempRect;
+ tempRect.Shrink( iconRect.Width(), 0 );
+ aDataInfo.iSpaceButtonEx.iMiddleIconRect = tempRect;
+
+ // preview popup window
+ TAknWindowLineLayout previewWnd, previewWndInner;
+ TAknLayoutRect previewWndRect, previewWndInnerRect;
+ previewWnd = AknLayoutScalable_Avkon::popup_fep_char_preview_window(aLayoutParam).LayoutLine();
+ previewWndRect.LayoutRect( aParentWndRect, previewWnd );
+ previewWndInner = AknLayoutScalable_Avkon::bg_popup_fep_char_preview_window_g9().LayoutLine();
+ previewWndInnerRect.LayoutRect( previewWndRect.Rect(), previewWndInner );
+ aDataInfo.iPreviewWndRect = previewWndRect.Rect();
+ aDataInfo.iPreviewWndInnerRect = previewWndInnerRect.Rect();
+ aDataInfo.iPreviewWndText = AknLayoutScalable_Avkon::popup_fep_char_preview_window_t1(
+ aLayoutParam).LayoutLine();
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataCommon::SetLayoutType( TInt aLayoutType )
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+inline void MPeninputLafDataCommon::SetLayoutType( TInt aLayoutType )
+ {
+ iLayoutType = aLayoutType;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataCommon::LayoutType
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+inline TInt MPeninputLafDataCommon::LayoutType() const
+ {
+ return iLayoutType;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataCommon::SetLafOption
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+inline void MPeninputLafDataCommon::SetLafOption( TPeninputVkbLafOption aLafOption )
+ {
+ iLafOption = aLafOption;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataCommon::SetLafOption
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+inline TPeninputVkbLafOption MPeninputLafDataCommon::LafOption() const
+ {
+ return iLafOption;
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataVKB::NewL( TInt aLayoutType )
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+CPeninputLafDataVKB* CPeninputLafDataVKB::NewL( TInt aLayoutType )
+ {
+ CPeninputLafDataVKB* self = NewLC( aLayoutType );
+ CleanupStack::Pop();
+ return self;
+ }
+// ---------------------------------------------------------------------------
+// CPeninputLafDataVKB::NewL( TInt aLayoutType )
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+CPeninputLafDataVKB* CPeninputLafDataVKB::NewLC( TInt aLayoutType )
+ {
+ CPeninputLafDataVKB* self = new ( ELeave ) CPeninputLafDataVKB( aLayoutType );
+ CleanupStack::PushL( self );
+ self->ConstructL();
+
+ return self;
+ }
+CPeninputLafDataVKB::~CPeninputLafDataVKB()
+ {
+ DestoryDataCommon();
+ }
+
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataVKB::NewL( TInt aLayoutType )
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+CPeninputLafDataVKB::CPeninputLafDataVKB( TInt aLayoutType )
+ {
+ SetLayoutType( aLayoutType );
+ }
+// ---------------------------------------------------------------------------
+// CPeninputLafDataVKB::NewL( TInt aLayoutType )
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void CPeninputLafDataVKB::ReadLafInfoL()
+ {
+ // clean up all the data
+ iLayoutDataInfo.ResetAndDestroy();
+
+ CPeninputQwtLayoutDataInfo* dataInfo = new( ELeave ) CPeninputQwtLayoutDataInfo;
+
+ TAknWindowLineLayout appWnd;
+ TAknWindowLineLayout wndLayout;
+ TAknWindowLineLayout keypad, rowpane, cellpane;
+
+ TAknLayoutRect keypadRect, rowpaneRect, cellpaneRect;
+ TAknLayoutRect wndRect;
+ TAknLayoutText keyTextLayout;
+ TAknTextLineLayout keyText;
+ TRect keyRect, keyCharRect;
+// -----------------------Portray Mode--------------------------
+ appWnd = AknLayoutScalable_Avkon::application_window(0).LayoutLine();
+ //iAppWndRect = appWnd.Rect();
+
+ // ==================10x3====================
+ wndLayout = AknLayoutScalable_Avkon::popup_fep_vkb2_window(3).LayoutLine();
+ wndRect.LayoutRect(appWnd.Rect(), wndLayout);
+ // top pane and bottom pane
+ GetTopAndBottomPaneInfo( wndRect.Rect(), ELayout10x3, 3, *dataInfo );
+ // keypad
+ keyText = AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_t1(0).LayoutLine();
+ dataInfo->iKeypad.iTextLayout = keyText;
+ dataInfo->iKeypad.iFont = AknLayoutUtils::FontFromId(keyText.iFont, NULL);
+ //dataInfo->iKeypad.iTxtRect = keyText.TextRect();
+
+ keypad = AknLayoutScalable_Avkon::
+ vkb2_area_keypad_pane(KVkbTopAndBottomParam[ELayout10x3]).LayoutLine();
+ keypadRect.LayoutRect(wndRect.Rect(), keypad);
+ //iKeypadRect10x3 = keypadRect.Rect();
+ for( TInt i = 0; i < KKeypadLayout[0][1]; i++)
+ {
+ for( TInt j = 0; j < KKeypadLayout[0][0]; j++)
+ {
+ rowpane = AknLayoutScalable_Avkon::vkb2_row_keypad_pane(2, 0, i).LayoutLine();
+ rowpaneRect.LayoutRect(keypadRect.Rect(), rowpane);
+ cellpane = (*cell_pane_func[j])(0).LayoutLine();
+ cellpaneRect.LayoutRect(rowpaneRect.Rect(), cellpane);
+ keyRect = cellpaneRect.Rect();
+ keyRect.Move( -keypadRect.Rect().iTl.iX, -keypadRect.Rect().iTl.iY );
+#ifdef LAF_MODIFY
+ keyRect.iTl.iX = KKeypadRectXPoint10x[j];
+ keyRect.SetWidth( KKeypadCellWidth10x[j] );
+#endif //LAF_MODIFY
+ dataInfo->iKeypad.iRects.AppendL(keyRect);
+ keyTextLayout.LayoutText(keyRect, keyText);
+ dataInfo->iKeypad.iCharRects.AppendL(keyTextLayout.TextRect());
+ }
+ }
+ iLayoutDataInfo.AppendL( dataInfo );
+
+ // ==================11x3====================
+ dataInfo = new( ELeave ) CPeninputQwtLayoutDataInfo;
+ wndLayout = AknLayoutScalable_Avkon::popup_fep_vkb2_window(1).LayoutLine();
+ wndRect.LayoutRect(appWnd.Rect(), wndLayout);
+ // top pane and bottom pane
+ GetTopAndBottomPaneInfo( wndRect.Rect(), ELayout11x3, 4, *dataInfo );
+ // keypad
+ keyText = AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_t1(0).LayoutLine();
+ dataInfo->iKeypad.iTextLayout = keyText;
+ dataInfo->iKeypad.iFont = AknLayoutUtils::FontFromId(keyText.iFont, NULL);
+
+ keypad = AknLayoutScalable_Avkon::
+ vkb2_area_keypad_pane(KVkbTopAndBottomParam[ELayout11x3]).LayoutLine();
+ keypadRect.LayoutRect(wndRect.Rect(), keypad);
+ for( TInt i = 0; i < KKeypadLayout[1][1]; i++)
+ {
+ for( TInt j = 0; j < KKeypadLayout[1][0]; j++)
+ {
+ rowpane = AknLayoutScalable_Avkon::vkb2_row_keypad_pane(0, 0, i).LayoutLine();
+ rowpaneRect.LayoutRect(keypadRect.Rect(), rowpane);
+ cellpane = (*cell_pane_func[j])(1).LayoutLine();
+ cellpaneRect.LayoutRect(rowpaneRect.Rect(), cellpane);
+ keyRect = cellpaneRect.Rect();
+ keyRect.Move( -keypadRect.Rect().iTl.iX, -keypadRect.Rect().iTl.iY );
+#ifdef LAF_MODIFY
+ keyRect.iTl.iX = KKeypadRectXPoint11x[j];
+ keyRect.SetWidth( KKeypadCellWidth11x[j] );
+#endif //LAF_MODIFY
+ dataInfo->iKeypad.iRects.AppendL(keyRect);
+ keyTextLayout.LayoutText(keyRect, keyText);
+ dataInfo->iKeypad.iCharRects.AppendL(keyTextLayout.TextRect());
+ }
+ }
+ iLayoutDataInfo.AppendL( dataInfo );
+
+ // ==================11x4====================
+ dataInfo = new( ELeave ) CPeninputQwtLayoutDataInfo;
+ wndLayout = AknLayoutScalable_Avkon::popup_fep_vkb2_window(2).LayoutLine();
+ wndRect.LayoutRect(appWnd.Rect(), wndLayout);
+ // top pane and bottom pane
+ GetTopAndBottomPaneInfo( wndRect.Rect(), ELayout11x4, 4, *dataInfo );
+ // keypad
+ keyText = AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_t1(0).LayoutLine();
+ dataInfo->iKeypad.iTextLayout = keyText;
+ dataInfo->iKeypad.iFont = AknLayoutUtils::FontFromId(keyText.iFont, NULL);
+
+ keypad = AknLayoutScalable_Avkon::
+ vkb2_area_keypad_pane(KVkbTopAndBottomParam[ELayout11x4]).LayoutLine();
+ keypadRect.LayoutRect(wndRect.Rect(), keypad);
+ for( TInt i = 0; i < KKeypadLayout[2][1]; i++)
+ {
+ for( TInt j = 0; j < KKeypadLayout[2][0]; j++)
+ {
+ rowpane = AknLayoutScalable_Avkon::vkb2_row_keypad_pane(1, 0, i).LayoutLine();
+ rowpaneRect.LayoutRect(keypadRect.Rect(), rowpane);
+ cellpane = (*cell_pane_func[j])(1).LayoutLine();
+ cellpaneRect.LayoutRect(rowpaneRect.Rect(), cellpane);
+ keyRect = cellpaneRect.Rect();
+ keyRect.Move( -keypadRect.Rect().iTl.iX, -keypadRect.Rect().iTl.iY );
+#ifdef LAF_MODIFY
+ keyRect.iTl.iX = KKeypadRectXPoint11x[j];
+ keyRect.SetWidth( KKeypadCellWidth11x[j] );
+#endif //LAF_MODIFY
+ dataInfo->iKeypad.iRects.AppendL(keyRect);
+ keyTextLayout.LayoutText(keyRect, keyText);
+ dataInfo->iKeypad.iCharRects.AppendL(keyTextLayout.TextRect());
+ }
+ }
+ iLayoutDataInfo.AppendL( dataInfo );
+
+ // ==================9x3====================
+ dataInfo = new( ELeave ) CPeninputQwtLayoutDataInfo;
+ wndLayout = AknLayoutScalable_Avkon::popup_fep_vkb2_window(3).LayoutLine();
+ wndRect.LayoutRect(appWnd.Rect(), wndLayout);
+ // top pane and bottom pane
+ GetTopAndBottomPaneInfo( wndRect.Rect(), ELayout10x3, 3, *dataInfo );
+ // keypad
+ keyText = AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_t1(0).LayoutLine();
+ dataInfo->iKeypad.iTextLayout = keyText;
+ dataInfo->iKeypad.iFont = AknLayoutUtils::FontFromId(keyText.iFont, NULL);
+ //dataInfo->iKeypad.iTxtRect = keyText.TextRect();
+
+ keypad = AknLayoutScalable_Avkon::
+ vkb2_area_keypad_pane(KVkbTopAndBottomParam[ELayout10x3]).LayoutLine();
+ keypadRect.LayoutRect(wndRect.Rect(), keypad);
+ //iKeypadRect10x3 = keypadRect.Rect();
+ for( TInt i = 0; i < KKeypadLayout[3][1]; i++)
+ {
+ for( TInt j = 0; j < KKeypadLayout[3][0]; j++)
+ {
+ rowpane = AknLayoutScalable_Avkon::vkb2_row_keypad_pane(2, 0, i).LayoutLine();
+ rowpaneRect.LayoutRect(keypadRect.Rect(), rowpane);
+ cellpane = (*cell_pane_func[j])(0).LayoutLine();
+ cellpaneRect.LayoutRect(rowpaneRect.Rect(), cellpane);
+ keyRect = cellpaneRect.Rect();
+ keyRect.Move( -keypadRect.Rect().iTl.iX, -keypadRect.Rect().iTl.iY );
+#ifdef LAF_MODIFY
+ keyRect.iTl.iX = KKeypadRectXPoint10x[j];
+ keyRect.SetWidth( KKeypadCellWidth10x[j] );
+#endif //LAF_MODIFY
+ dataInfo->iKeypad.iRects.AppendL(keyRect);
+ keyTextLayout.LayoutText(keyRect, keyText);
+ dataInfo->iKeypad.iCharRects.AppendL(keyTextLayout.TextRect());
+ }
+ }
+
+ // for table up & down keys
+ rowpane = AknLayoutScalable_Avkon::vkb2_row_keypad_pane(2, 0, 0).LayoutLine();
+ rowpaneRect.LayoutRect(keypadRect.Rect(), rowpane);
+ cellpane = (*cell_pane_func[9])(0).LayoutLine();
+ cellpaneRect.LayoutRect(rowpaneRect.Rect(), cellpane);
+ keyRect = cellpaneRect.Rect();
+ keyRect.Move( -keypadRect.Rect().iTl.iX, -keypadRect.Rect().iTl.iY );
+#ifdef LAF_MODIFY
+ keyRect.iTl.iX = KKeypadRectXPoint10x[9];
+ keyRect.SetWidth( KKeypadCellWidth10x[9] );
+#endif //LAF_MODIFY
+ keyRect = cellpaneRect.Rect();
+ TInt keyHeight=keyRect.Height();
+ TInt keyWidth=37;
+ keyRect.iTl.iX = keypadRect.Rect().iBr.iX - keyWidth;
+ keyRect.iTl.iY = keypadRect.Rect().iTl.iY;
+ keyRect.SetHeight(keyHeight);
+ keyRect.SetWidth(keyWidth);
+ TRect rectTableUp=keyRect;
+ TRect rectTableDown=keyRect;
+ TRect rectTablePage=keyRect;
+
+ rectTablePage.Move(0,keyHeight);
+ rectTableDown.Move(0,keyHeight*2);
+
+ dataInfo->iTableUpButton.iRect=rectTableUp;
+ dataInfo->iTableUpButton.iInnerRect=rectTableUp;
+ dataInfo->iTableUpButton.iInnerRect.Shrink(5,5);
+ dataInfo->iTableDownButton.iRect=rectTableDown;
+ dataInfo->iTableDownButton.iInnerRect=rectTableDown;
+ dataInfo->iTableDownButton.iInnerRect.Shrink(5,5);
+ dataInfo->iTablePageLabel.iRect=rectTablePage;
+ dataInfo->iTablePageLabel.iInnerRect=rectTablePage;
+ dataInfo->iTablePageLabel.iInnerRect.Shrink(5,5);
+
+ dataInfo->iKeypad.iKaypadRect.iBr.iX-=keyWidth;
+
+ iLayoutDataInfo.AppendL( dataInfo );
+
+ // ==================3x3====================
+ dataInfo = new( ELeave ) CPeninputQwtLayoutDataInfo;
+ wndLayout = AknLayoutScalable_Avkon::popup_fep_vkb2_window(3).LayoutLine();
+ wndRect.LayoutRect(appWnd.Rect(), wndLayout);
+ // top pane and bottom pane
+ GetTopAndBottomPaneInfo( wndRect.Rect(), ELayout10x3, 3, *dataInfo );
+ // keypad
+ keyText = AknLayoutScalable_Avkon::vkb2_cell_t_keypad_pane_t1(0).LayoutLine();
+ dataInfo->iKeypad.iTextLayout = keyText;
+ // TODO:
+ //dataInfo->iKeypad.iFont = AknLayoutUtils::FontFromId(keyText.iFont, NULL);
+ dataInfo->iKeypad.iFont = AknLayoutUtils::FontFromId(0x82800000, NULL);
+
+ keypad = AknLayoutScalable_Avkon::
+ vkb2_area_keypad_pane(KVkbTopAndBottomParam[ELayout10x3]).LayoutLine();
+ keypadRect.LayoutRect(wndRect.Rect(), keypad);
+ //iKeypadRect10x3 = keypadRect.Rect();
+ for( TInt i = 0; i < KKeypadLayout[4][1]; i++)
+ {
+ for( TInt j = 0; j < KKeypadLayout[4][0]; j++)
+ {
+ rowpane = AknLayoutScalable_Avkon::vkb2_row_keypad_pane(2, 0, i).LayoutLine();
+ rowpaneRect.LayoutRect(keypadRect.Rect(), rowpane);
+ cellpane = (*cell_pane_func[j])(0).LayoutLine();
+ cellpaneRect.LayoutRect(rowpaneRect.Rect(), cellpane);
+ keyRect = cellpaneRect.Rect();
+ keyRect.Move( -keypadRect.Rect().iTl.iX, -keypadRect.Rect().iTl.iY );
+#ifdef LAF_MODIFY
+ keyRect.iTl.iX = KKeypadRectXPoint3x[j];
+ keyRect.SetWidth( KKeypadCellWidth3x[j] );
+#endif //LAF_MODIFY
+ dataInfo->iKeypad.iRects.AppendL(keyRect);
+ keyTextLayout.LayoutText(keyRect, keyText);
+ dataInfo->iKeypad.iCharRects.AppendL(keyTextLayout.TextRect());
+ }
+ }
+
+ dataInfo->iTableUpButton.iRect=rectTableUp;
+ dataInfo->iTableUpButton.iInnerRect=rectTableUp;
+ dataInfo->iTableUpButton.iInnerRect.Shrink(5,5);
+ dataInfo->iTableDownButton.iRect=rectTableDown;
+ dataInfo->iTableDownButton.iInnerRect=rectTableDown;
+ dataInfo->iTableDownButton.iInnerRect.Shrink(5,5);
+ dataInfo->iTablePageLabel.iRect=rectTablePage;
+ dataInfo->iTablePageLabel.iInnerRect=rectTablePage;
+ dataInfo->iTablePageLabel.iInnerRect.Shrink(5,5);
+
+ dataInfo->iKeypad.iKaypadRect.iBr.iX-=keyWidth;
+
+ iLayoutDataInfo.AppendL( dataInfo );
+
+ }
+// ---------------------------------------------------------------------------
+// CPeninputLafDataFSQ::NewL( TInt aLayoutType )
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+CPeninputLafDataFSQ* CPeninputLafDataFSQ::NewL( TInt aLayoutType )
+ {
+ CPeninputLafDataFSQ* self = NewLC( aLayoutType );
+ CleanupStack::Pop();
+ return self;
+ }
+// ---------------------------------------------------------------------------
+// CPeninputLafDataFSQ::NewLC( TInt aLayoutType )
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+CPeninputLafDataFSQ* CPeninputLafDataFSQ::NewLC( TInt aLayoutType )
+ {
+ CPeninputLafDataFSQ* self = new ( ELeave ) CPeninputLafDataFSQ( aLayoutType );
+ CleanupStack::PushL( self );
+ self->ConstructL();
+
+ return self;
+
+ }
+
+CPeninputLafDataFSQ::~CPeninputLafDataFSQ()
+ {
+ DestoryDataCommon();
+ }
+
+// ---------------------------------------------------------------------------
+// CPeninputLafDataFSQ::CPeninputLafDataFSQ( TInt aLayoutType )
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+CPeninputLafDataFSQ::CPeninputLafDataFSQ( TInt aLayoutType )
+ {
+ SetLayoutType( aLayoutType );
+ }
+// ---------------------------------------------------------------------------
+// CPeninputLafDataFSQ::ReadLafInfo()
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+void CPeninputLafDataFSQ::ReadLafInfoL()
+ {
+ // clean up all the data
+ iLayoutDataInfo.ResetAndDestroy();
+
+ CPeninputQwtLayoutDataInfo* dataInfo = new( ELeave ) CPeninputQwtLayoutDataInfo;
+ TAknWindowLineLayout appWnd;
+ TAknWindowLineLayout wndLayout;
+ TAknWindowLineLayout keypad, cellpane;
+
+ TAknLayoutRect keypadRect, cellpaneRect;
+ TAknLayoutRect wndRect;
+ TAknLayoutText keyTextLayout;
+ TAknTextLineLayout keyText;
+ TRect keyRect;
+
+ // -----------------------Landscape Mode--------------------------
+ appWnd = AknLayoutScalable_Avkon::application_window(0).LayoutLine();
+ wndLayout = AknLayoutScalable_Avkon::popup_fep_vkb2_window(0).LayoutLine();
+ wndRect.LayoutRect(appWnd.Rect(), wndLayout);
+ // ==================10x3====================
+ // top pane and bottom pane
+ GetTopAndBottomPaneInfo( wndRect.Rect(), ELayout10x3, 0, *dataInfo );
+ // keypad
+ keyText = AknLayoutScalable_Avkon::vkb2_cell_keypad_pane_t1(0).LayoutLine();
+ dataInfo->iKeypad.iTextLayout = keyText;
+ dataInfo->iKeypad.iFont = AknLayoutUtils::FontFromId(keyText.iFont, NULL);
+ //dataInfo->iKeypad.iTxtRect = keyText.TextRect();
+
+ keypad = AknLayoutScalable_Avkon::vkb2_area_keypad_pane(0).LayoutLine();
+ keypadRect.LayoutRect(wndRect.Rect(), keypad);
+ //iKeypadRect10x3 = keypadRect.Rect();
+ for( TInt i = 0; i < KKeypadLayout[0][1]; i++)
+ {
+ for( TInt j = 0; j < KKeypadLayout[0][0]; j++)
+ {
+ cellpane = AknLayoutScalable_Avkon::vkb2_cell_keypad_pane(0, j, i).LayoutLine();
+ cellpaneRect.LayoutRect(keypadRect.Rect(), cellpane);
+ keyRect = cellpaneRect.Rect();
+ keyRect.Move( -keypadRect.Rect().iTl.iX, -keypadRect.Rect().iTl.iY );
+ dataInfo->iKeypad.iRects.AppendL(keyRect);
+ keyTextLayout.LayoutText(keyRect, keyText);
+ dataInfo->iKeypad.iCharRects.AppendL(keyTextLayout.TextRect());
+ }
+ }
+ keyText = AknLayoutScalable_Avkon::vkb2_cell_keypad_pane_t1(0).LayoutLine();
+ dataInfo->iKeypad.iFont = AknLayoutUtils::FontFromId(keyText.iFont, NULL);
+ //dataInfo->iKeypad.iTxtRect = keyText.TextRect();
+ iLayoutDataInfo.AppendL( dataInfo );
+
+ // ==================11x3====================
+ dataInfo = new( ELeave ) CPeninputQwtLayoutDataInfo;
+ wndLayout = AknLayoutScalable_Avkon::popup_fep_vkb2_window(0).LayoutLine();
+ wndRect.LayoutRect(appWnd.Rect(), wndLayout);
+ // top pane and bottom pane
+ GetTopAndBottomPaneInfo( wndRect.Rect(), ELayout11x3, 1, *dataInfo );
+ // keypad
+ keypad = AknLayoutScalable_Avkon::vkb2_area_keypad_pane(1).LayoutLine();
+ keypadRect.LayoutRect(wndRect.Rect(), keypad);
+ for( TInt i = 0; i < KKeypadLayout[1][1]; i++)
+ {
+ for( TInt j = 0; j < KKeypadLayout[1][0]; j++)
+ {
+ cellpane = AknLayoutScalable_Avkon::vkb2_cell_keypad_pane(1, j, i).LayoutLine();
+ cellpaneRect.LayoutRect(keypadRect.Rect(), cellpane);
+ keyRect = cellpaneRect.Rect();
+ keyRect.Move( -keypadRect.Rect().iTl.iX, -keypadRect.Rect().iTl.iY );
+ dataInfo->iKeypad.iRects.AppendL(keyRect);
+ keyTextLayout.LayoutText(keyRect, keyText);
+ dataInfo->iKeypad.iCharRects.AppendL(keyTextLayout.TextRect());
+ }
+ }
+ keyText = AknLayoutScalable_Avkon::vkb2_cell_keypad_pane_t1(1).LayoutLine();
+ dataInfo->iKeypad.iTextLayout = keyText;
+ dataInfo->iKeypad.iFont = AknLayoutUtils::FontFromId(keyText.iFont, NULL);
+ //dataInfo->iKeypad.iTxtRect = keyText.TextRect();
+ iLayoutDataInfo.AppendL( dataInfo );
+
+ // ==================11x4====================
+ dataInfo = new( ELeave ) CPeninputQwtLayoutDataInfo;
+ wndLayout = AknLayoutScalable_Avkon::popup_fep_vkb2_window(0).LayoutLine();
+ wndRect.LayoutRect(appWnd.Rect(), wndLayout);
+ // top pane and bottom pane
+ GetTopAndBottomPaneInfo( wndRect.Rect(), ELayout11x4, 2, *dataInfo );
+ // keypad
+ keypad = AknLayoutScalable_Avkon::vkb2_area_keypad_pane(2).LayoutLine();
+ keypadRect.LayoutRect(wndRect.Rect(), keypad);
+ for( TInt i = 0; i < KKeypadLayout[2][1]; i++)
+ {
+ for( TInt j = 0; j < KKeypadLayout[2][0]; j++)
+ {
+ cellpane = AknLayoutScalable_Avkon::vkb2_cell_keypad_pane(2, j, i).LayoutLine();
+ cellpaneRect.LayoutRect(keypadRect.Rect(), cellpane);
+ keyRect = cellpaneRect.Rect();
+ keyRect.Move( -keypadRect.Rect().iTl.iX, -keypadRect.Rect().iTl.iY );
+ dataInfo->iKeypad.iRects.AppendL(keyRect);
+ keyTextLayout.LayoutText(keyRect, keyText);
+ dataInfo->iKeypad.iCharRects.AppendL(keyTextLayout.TextRect());
+ }
+ }
+ keyText = AknLayoutScalable_Avkon::vkb2_cell_keypad_pane_t1(2).LayoutLine();
+ dataInfo->iKeypad.iTextLayout = keyText;
+ dataInfo->iKeypad.iFont = AknLayoutUtils::FontFromId(keyText.iFont, NULL);
+ //dataInfo->iKeypad.iTxtRect = keyText.TextRect();
+ iLayoutDataInfo.AppendL( dataInfo );
+
+ // ==================10x3====================
+ dataInfo = new( ELeave ) CPeninputQwtLayoutDataInfo;
+ wndLayout = AknLayoutScalable_Avkon::popup_fep_vkb2_window(0).LayoutLine();
+ wndRect.LayoutRect(appWnd.Rect(), wndLayout);
+ // top pane and bottom pane
+ GetTopAndBottomPaneInfo( wndRect.Rect(), ELayout10x3, 0, *dataInfo );
+ // keypad
+ keypad = AknLayoutScalable_Avkon::vkb2_area_keypad_pane(0).LayoutLine();
+ keypadRect.LayoutRect(wndRect.Rect(), keypad);
+ for( TInt i = 0; i < KKeypadLayout[3][1]; i++)
+ {
+ for( TInt j = 0; j < KKeypadLayout[3][0]; j++)
+ {
+ cellpane = AknLayoutScalable_Avkon::vkb2_cell_keypad_pane(0, j, i).LayoutLine();
+ cellpaneRect.LayoutRect(keypadRect.Rect(), cellpane);
+ keyRect = cellpaneRect.Rect();
+ keyRect.Move( -keypadRect.Rect().iTl.iX, -keypadRect.Rect().iTl.iY );
+ dataInfo->iKeypad.iRects.AppendL(keyRect);
+ keyTextLayout.LayoutText(keyRect, keyText);
+ dataInfo->iKeypad.iCharRects.AppendL(keyTextLayout.TextRect());
+ }
+ }
+ keyText = AknLayoutScalable_Avkon::vkb2_cell_keypad_pane_t1(0).LayoutLine();
+ dataInfo->iKeypad.iTextLayout = keyText;
+ dataInfo->iKeypad.iFont = AknLayoutUtils::FontFromId(keyText.iFont, NULL);
+
+ // for table up & down
+ TRect rectTableUp;
+ TRect rectTableDown;
+ TRect rectTablePage;
+ TRect refRect;
+ TRect refInnerRect;
+
+ refRect=dataInfo->iSwitchButton.iRect;
+ refInnerRect=dataInfo->iSwitchButton.iInnerRect;
+
+ rectTableUp=refRect;
+ rectTableUp.Move(0,-refRect.Height()*3);
+ rectTablePage=refRect;
+ rectTablePage.Move(0,-refRect.Height()*2);
+ rectTableDown=refRect;
+ rectTableDown.Move(0,-refRect.Height());
+
+ dataInfo->iTableUpButton.iRect=rectTableUp;
+ dataInfo->iTableUpButton.iInnerRect=rectTableUp;
+ dataInfo->iTableUpButton.iInnerRect.Shrink(5,5);
+ dataInfo->iTableDownButton.iRect=rectTableDown;
+ dataInfo->iTableDownButton.iInnerRect=rectTableDown;
+ dataInfo->iTableDownButton.iInnerRect.Shrink(5,5);
+ dataInfo->iTablePageLabel.iRect=rectTablePage;
+ dataInfo->iTablePageLabel.iInnerRect=rectTablePage;
+ dataInfo->iTablePageLabel.iInnerRect.Shrink(5,5);
+
+ // for shrinking whole keypad rect
+ dataInfo->iKeypad.iKaypadRect.iBr.iX-=dataInfo->iSwitchButton.iRect.Width();
+
+ //dataInfo->iKeypad.iTxtRect = keyText.TextRect();
+ iLayoutDataInfo.AppendL( dataInfo );
+
+ // ==================3x3====================
+ dataInfo = new( ELeave ) CPeninputQwtLayoutDataInfo;
+ wndLayout = AknLayoutScalable_Avkon::popup_fep_vkb2_window(0).LayoutLine();
+ wndRect.LayoutRect(appWnd.Rect(), wndLayout);
+ // top pane and bottom pane
+ GetTopAndBottomPaneInfo( wndRect.Rect(), ELayout10x3, 0, *dataInfo );
+ //dataInfo->iKeypad.iKaypadRect.iBr.iX-=dataInfo->iSwitchButton.iRect.Width();
+ // keypad
+ keypad = AknLayoutScalable_Avkon::vkb2_area_keypad_pane(0).LayoutLine();
+ keypadRect.LayoutRect(wndRect.Rect(), keypad);
+ for( TInt i = 0; i < KKeypadLayout[4][1]; i++)
+ {
+ for( TInt j = 0; j < KKeypadLayout[4][0]; j++)
+ {
+ cellpane = AknLayoutScalable_Avkon::vkb2_cell_keypad_pane(0, j*3, i).LayoutLine();
+ //cellpane.il*=3;
+ cellpane.iW*=3;
+ cellpaneRect.LayoutRect(keypadRect.Rect(), cellpane);
+ keyRect = cellpaneRect.Rect();
+ keyRect.Move( -keypadRect.Rect().iTl.iX, -keypadRect.Rect().iTl.iY );
+ dataInfo->iKeypad.iRects.AppendL(keyRect);
+ keyTextLayout.LayoutText(keyRect, keyText);
+ dataInfo->iKeypad.iCharRects.AppendL(keyTextLayout.TextRect());
+ }
+ }
+ keyText = AknLayoutScalable_Avkon::vkb2_cell_keypad_pane_t1(0).LayoutLine();
+ dataInfo->iKeypad.iTextLayout = keyText;
+ dataInfo->iKeypad.iFont = AknLayoutUtils::FontFromId(keyText.iFont, NULL);
+ //dataInfo->iKeypad.iTxtRect = keyText.TextRect();
+
+ // for table up & down
+ dataInfo->iTableUpButton.iRect=rectTableUp;
+ dataInfo->iTableUpButton.iInnerRect=rectTableUp;
+ dataInfo->iTableUpButton.iInnerRect.Shrink(5,5);
+ dataInfo->iTableDownButton.iRect=rectTableDown;
+ dataInfo->iTableDownButton.iInnerRect=rectTableDown;
+ dataInfo->iTableDownButton.iInnerRect.Shrink(5,5);
+ dataInfo->iTablePageLabel.iRect=rectTablePage;
+ dataInfo->iTablePageLabel.iInnerRect=rectTablePage;
+ dataInfo->iTablePageLabel.iInnerRect.Shrink(5,5);
+
+ // for shrinking whole keypad rect
+ dataInfo->iKeypad.iKaypadRect.iBr.iX-=dataInfo->iSwitchButton.iRect.Width();
+
+ iLayoutDataInfo.AppendL( dataInfo );
+
+ }