Binary file fep/aknfep/conf/aknfep.confml has changed
Binary file fep/aknfep/conf/aknfep_101F876D.crml has changed
--- a/fep/aknfep/inc/AknFepUiInputStateEntryQwertyWesternPredictive.h Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/inc/AknFepUiInputStateEntryQwertyWesternPredictive.h Fri Sep 17 17:26:50 2010 +0100
@@ -93,6 +93,24 @@
* @param aLength The key press length.
*/
TBool HandleNaviKeysL(TInt aKey, TKeyPressLength aLength);
+private:
+
+ /**
+ * Get scancode from given character and textcase
+ * @param aChar The character to be checked against to gain the scancode
+ * @param aCase The textcase info
+ */
+ TInt ScanCodeForCharacter( TUint aChar, TPtiTextCase& aCase );
+
+ /**
+ * Check whether the character mapped on given key
+ * @param aKey The scancode of the key to be checked.
+ * @param aMode The InputMode regarding ptiengine
+ * @param aAgainst The character to be checked.
+ * @param aCase Text case.
+ * @Return ETrue : yes it is on the key; EFalse : No it is not on the Key
+ */
+ TBool MapAgainst(TInt aKey, TInt aMode, TInt16 aAgainst, TInt aCase) const;
};
#endif //__AKN_FEP_UI_INPUT_STATE_ENTRY_QWERTY_WESTERN_PREDICTIVE_H__
--- a/fep/aknfep/inc/AknFepUiInputStateInitialChineseGenericQwerty.h Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/inc/AknFepUiInputStateInitialChineseGenericQwerty.h Fri Sep 17 17:26:50 2010 +0100
@@ -43,6 +43,7 @@
TBool IsSCTKey(TInt aKey);
TBool IsCharacter(TInt aKey);
TBool HandleKeyByShiftOrCharPressed(TInt aKey, TKeyPressLength aLength);
+ TInt ToneMark(TInt aKey, TDes& aResult);
};
#endif //__AKN_FEP_UI_INPUT_STATE_INIT_CHIN_GEN_QWERTY_H__
--- a/fep/aknfep/inc/AknFepUiManagerBase.h Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/inc/AknFepUiManagerBase.h Fri Sep 17 17:26:50 2010 +0100
@@ -442,6 +442,16 @@
* @since 3.2
*/
virtual TBool RollbackPreviousCharL();
+
+ /**
+ * Check whether the character mapped on given key
+ * @param aKey The scancode of the key to be checked.
+ * @param aMode The InputMode regarding ptiengine
+ * @param aAgainst The character to be checked.
+ * @param aCase Text case.
+ * @Return ETrue : yes it is on the key; EFalse : No it is not on the Key
+ */
+ TBool MapAgainst(TInt aKey, TInt aMode, TInt16 aAgainst, TInt aCase) const;
#endif //RD_INTELLIGENT_TEXT_INPUT
#endif // __ITI_LONGPRESS_NUM_SHIFT_COPYPASTE__
--- a/fep/aknfep/inc/AknFepUiManagerChinese.h Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/inc/AknFepUiManagerChinese.h Fri Sep 17 17:26:50 2010 +0100
@@ -275,6 +275,16 @@
*/
void ConstructL(TLanguage aLanguage);
+ /**
+ * Tell whether this key mapped valid zhuyin, pinyin, or cangjie symbol
+ */
+ TBool IsValidChineseInputSymbol(TInt aKey, TPtiEngineInputMode aMode) const;
+
+ /**
+ * Tell whether this key mapped valid chinese tone mark
+ */
+ TBool IsValidChineseToneMarkKey(TInt aKey, TPtiEngineInputMode aMode) const;
+
private: // Data
TAknFepInputStateChineseBase iFepUiState;
MAknFepUICtrlContainerChinese* iContainerPane;
--- a/fep/aknfep/inc/aknfepuiinputminiqwertypinyinphrasebase.h Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/inc/aknfepuiinputminiqwertypinyinphrasebase.h Fri Sep 17 17:26:50 2010 +0100
@@ -534,7 +534,15 @@
* @return None.
*/
void DoActionAfterCommitL();
+ /**
+ * Get real pinyin symbol from scancode.
+ *
+ * @since S60 v3.2.3
+ * @param aKey
+ * @return None.
+ */
+ void MapKey(TInt& aKey);
};
#endif //T_AKNFEPUIINPUTMINIQWERTYPINYINPHRASEBASE_H
--- a/fep/aknfep/src/AknFepManager.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/src/AknFepManager.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -6305,7 +6305,8 @@
TBool isCangJieSupported = EFalse;
#ifdef RD_INTELLIGENT_TEXT_INPUT
- if ( EPtiKeyboardQwerty3x11 == KeyboardLayout() )
+ if ( EPtiKeyboardQwerty3x11 == KeyboardLayout() ||
+ EPtiKeyboardQwerty4x10 == KeyboardLayout())
{
isCangJieSupported = ETrue;
}
@@ -12295,31 +12296,30 @@
}
if (!iLanguageCapabilities.iLocalInputLanguageInUse)
- {
- switch (iSharedDataInterface->InputTextLanguage())
- {
- case ELangPrcChinese:
- {
- iSharedDataInterface->SetInputMode(EPinyin);
- SetFlag(EFlagNewSharedDataInputMode);
- break;
- }
+ {
+ switch (iSharedDataInterface->InputTextLanguage())
+ {
+ case ELangPrcChinese:
+ {
+ iSharedDataInterface->SetInputMode(EPinyin);
+ SetFlag(EFlagNewSharedDataInputMode);
+ break;
+ }
case ELangTaiwanChinese:
- {
- iSharedDataInterface->SetInputMode(EZhuyin);
- SetFlag(EFlagNewSharedDataInputMode);
- break;
- }
- case ELangHongKongChinese:
- {
- iSharedDataInterface->SetInputMode(EStroke);
- iSharedDataInterface->SetCangJieMode(ECangJieNormal);
- SetFlag(EFlagNewSharedDataInputMode);
- break;
- }
- default:
- break;
- }
+ {
+ iSharedDataInterface->SetInputMode(EZhuyin);
+ SetFlag(EFlagNewSharedDataInputMode);
+ break;
+ }
+ case ELangHongKongChinese:
+ {
+ iSharedDataInterface->SetInputMode(EStroke);
+ SetFlag(EFlagNewSharedDataInputMode);
+ break;
+ }
+ default:
+ break;
+ }
}
SetHashKeyStyle();
--- a/fep/aknfep/src/AknFepPluginManager.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/src/AknFepPluginManager.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -153,6 +153,17 @@
return ETrue;
return EFalse;
}
+
+// -----------------------------------------------------------------------------
+// Check if the app specified by aUid is avkon notify server
+// -----------------------------------------------------------------------------
+//
+TBool IsAknNotifyServerApp( const TUid& aUid )
+ {
+ const TInt KAknNotifySrvUid = 0x10281EF2;
+ return aUid.iUid == KAknNotifySrvUid;
+ }
+
#ifdef RD_SCALABLE_UI_V2
inline TBool IsAbleTouseCallBubble()
{
@@ -305,7 +316,10 @@
if( !iPenInputSvrConnected || !iPenInputServer.IsVisible() || iPenInputServer.IsDimmed() )
{
if( iFepMan.FepAwareTextEditor() )
- {
+ {
+ // Enable transition effect when close pen ui
+ // by pressing close button.
+ iPenInputServer.EnableGfxTransEffect( ETrue );
iPreferredUiMode = ETrue;
TryChangePluginInputModeByModeL((TPluginInputMode)(iSharedData.PluginInputMode()),
EPenInputOpenManually,
@@ -563,6 +577,8 @@
}
break;
case ESignalLayoutClosed:
+ // Enable transition effect when close pen ui by pressing close button.
+ iPenInputServer.EnableGfxTransEffect( ETrue );
if(iPluginInputMode == EPluginInputModeItut)
{
iFepMan.PtiEngine()->CancelTimerActivity();
@@ -1013,9 +1029,24 @@
break;
case EPluginResourceChanged:
{
- iOrientationChangedfromUI = ETrue;
- OnResourceChangedL( aEventData );
- iOrientationChangedfromUI = EFalse;
+ iOrientationChangedfromUI = ETrue;
+
+ TUid uid = GetCurAppUid();
+ if ( IsAknNotifyServerApp( uid ) )
+ {
+ //turn off AutoForeground feature of global query temporarily during layout switching
+ //if not, global query may be shown on top of virtual input by unexpected tap events.
+ CCoeEnv::Static()->RootWin().AutoForeground( EFalse );
+ TRAPD( err, OnResourceChangedL( aEventData ) );
+ CCoeEnv::Static()->RootWin().AutoForeground( ETrue );
+ User::LeaveIfError( err );
+ }
+ else
+ {
+ OnResourceChangedL( aEventData );
+ }
+
+ iOrientationChangedfromUI = EFalse;
}
break;
case EPluginFaseSwap:
@@ -2824,7 +2855,11 @@
{
iCurrentPluginInputFepUI->HandleCommandL
(ECmdPenInputSendEditorTextAndCurPos, reinterpret_cast<TInt>(&icfData));
- iFepMan.TryPopExactWordInICFL();
+ if ( icfData.iMidPos >= 0 )
+ {
+ // icfData.iMidPos >= 0 means the text which will be sent to ICF is inline text.
+ iFepMan.TryPopExactWordInICFL();
+ }
}
if ( secretEditor )
@@ -5949,7 +5984,8 @@
}
TInt flags = editorState->Flags();
- return ( flags & EEikEdwinAvkonDisableCursor ) == EEikEdwinAvkonDisableCursor;
+ return ( flags & EAknEditorFlagAvkonSecretEditor ) == EAknEditorFlagAvkonSecretEditor;
+
}
// ---------------------------------------------------------------------------
@@ -6102,6 +6138,16 @@
TPtiTextCase caseCalculated = EPtiCaseLower;
TBuf<KDefaulCoreMaximumWordLength> mappedCharacters;
TBool isMappingFound = EFalse;
+ TPtiEngineInputMode oldInputMode = iFepMan.PtiEngine()->InputMode();
+ if ( oldInputMode != EPtiEngineQwertyPredictive )
+ {
+ // if current input mode isn't EPtiEngineQwertyPredictive,
+ // change it to EPtiEngineQwertyPredictive temporarily,
+ // so that during the process of searching in qwerty keymapping afterward,
+ // qwerty keymapping can be gained.
+ iFepMan.PtiEngine()->SetInputMode( EPtiEngineQwertyPredictive );
+ }
+
TPtiKey key = iFepMan.PtiEngine()->CharacterToKey( aCharacter );
//It loops through all the key mappings to find the character in the key mappings and
@@ -6124,6 +6170,15 @@
break;
}
}
+
+ if ( oldInputMode != EPtiEngineQwertyPredictive )
+ {
+ // if current input mode isn't EPtiEngineQwertyPredictive,
+ // current input mode has been set to EPtiEngineQwertyPredictive temporarily before,
+ // now we need to restore it,
+ // because state machine is responsible for changing it practically.
+ iFepMan.PtiEngine()->SetInputMode( oldInputMode );
+ }
//Now if there is no key mapping found for the character, then use the default TChar
//APIs to find the case of the character.
if( !isMappingFound )
--- a/fep/aknfep/src/AknFepUiInputStateEntryMiniQwertyZhuyinPhrase.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/src/AknFepUiInputStateEntryMiniQwertyZhuyinPhrase.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -515,8 +515,7 @@
TBool ret = ETrue;
- if ( (aKey == EPtiKeyQwertyE || aKey == EPtiKeyQwertyR ||
- aKey == EPtiKeyQwertyY || aKey == EPtiKeyQwertyU || aKey == EStdKeySpace)
+ if ( (iOwner->IsQwertyZhuyinToneMarkKey(aKey)|| aKey == EStdKeySpace)
&& (aLength == EShortKeyPress) )
{
if ( keystrokeLength == 0 )
--- a/fep/aknfep/src/AknFepUiInputStateEntryQwertyWesternPredictive.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/src/AknFepUiInputStateEntryQwertyWesternPredictive.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -42,10 +42,12 @@
#include <featmgr.h> //FeatureManager
#include <e32keys.h>
#include <aknfep.rsg>
+#include <PtiKeyMappings.h>
static const TInt KKeyMappingsLength = 63;
+
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//
TAknFepInputStateEntryQwertyWesternPredictive::
@@ -604,6 +606,72 @@
// Framework will handle the key event.
return EFalse;
}
+
+
+// use ptiengine's api to tell whether a character mapped on a given key.
+TBool TAknFepInputStateEntryQwertyWesternPredictive::MapAgainst(TInt aKey, TInt aMode, TInt16 aAgainst, TInt aCase) const
+ {
+ CPtiEngine* ptiengine = iOwner->PtiEngine();
+ if(ptiengine)
+ {
+ ptiengine->SetInputMode((TPtiEngineInputMode)aMode);
+ TBuf<KMaxName> data;
+ ptiengine->MappingDataForKey((TPtiKey)aKey, data, (TPtiTextCase)aCase);
+ if(data.Length() > 0)
+ {
+ return (data[0] == aAgainst);
+ }
+ }
+ return EFalse;
+ }
+
+
+// Get Scancode from a given character and tell the case at the same time.
+TInt TAknFepInputStateEntryQwertyWesternPredictive::ScanCodeForCharacter( TUint aChar, TPtiTextCase& aCase )
+ {
+ MAknFepManagerUIInterface* fepMan = iOwner->FepMan();
+ CPtiEngine* ptiengine = iOwner->PtiEngine();
+#ifdef RD_INTELLIGENT_TEXT_INPUT
+ CPtiCoreLanguage *lang = static_cast<CPtiCoreLanguage*>( ptiengine->CurrentLanguage() );
+ MPtiKeyMappings* keymapping = lang->GetQwertyKeymappings();
+ if ( keymapping )
+ {
+ TPtiEngineInputMode oldInputMode = ptiengine->InputMode();
+ ptiengine->SetInputMode( EPtiEngineQwertyPredictive );
+ TInt retKey = keymapping->KeyForCharacter( (TUint16)aChar );
+ if(MapAgainst(retKey, EPtiEngineQwertyPredictive, aChar, EPtiCaseLower))
+ {
+ aCase = EPtiCaseLower;
+ }
+ else if(MapAgainst(retKey, EPtiEngineQwertyPredictive, aChar, EPtiCaseUpper))
+ {
+ aCase = EPtiCaseUpper;
+ }
+ else if(MapAgainst(retKey, EPtiEngineQwertyPredictive, aChar, EPtiCaseFnLower))
+ {
+ aCase = EPtiCaseFnLower;
+ }
+ else if(MapAgainst(retKey, EPtiEngineQwertyPredictive, aChar, EPtiCaseFnUpper))
+ {
+ aCase = EPtiCaseFnUpper;
+ }
+ else
+ {
+ }
+ ptiengine->SetInputMode( oldInputMode );
+#if defined(__WINS__)
+ if (retKey == EPtiKeyQwertyPlus)
+ {
+ retKey = EStdKeyNkpPlus;
+ }
+#endif
+ return retKey;
+ }
+ return EPtiKeyNone;
+#else
+ return EPtiKeyNone;
+#endif // RD_INTELLIGENT_TEXT_INPUT
+ }
////////////////////////////////////////////////////////////////////////////////////////////////////////////
--- a/fep/aknfep/src/AknFepUiInputStateInitialChineseGenericQwerty.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/src/AknFepUiInputStateInitialChineseGenericQwerty.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -91,6 +91,33 @@
#endif
}
+TInt TAknFepInputStateInitialChineseGenericQwerty::ToneMark(TInt aKey, TDes& aResult)
+ {
+ CPtiEngine* ptiengine = iOwner->PtiEngine();
+ TInt number = 0;
+ aResult.Zero();
+ if(ptiengine)
+ {
+ TBuf<KMaxName> data;
+ ptiengine->MappingDataForKey((TPtiKey)aKey, data, EPtiCaseLower);
+ if(data.Length() > 0)
+ {
+ for(TInt i = 0; i < data.Length(); i++)
+ {
+ if(data[i] == KZhuyinTone2 || data[i] == KZhuyinTone3 || data[i] == KZhuyinTone4 || data[i] == KZhuyinTone5)
+ {
+ if(aResult.MaxLength() > i)
+ {
+ aResult.Append(data[i]);
+ number++;
+ }
+ }
+ }
+ }
+ }
+ return number;
+ }
+
TBool TAknFepInputStateInitialChineseGenericQwerty::HandleKeyL(TInt aKey, TKeyPressLength aLength)
{
CPtiEngine* ptiengine = iOwner->PtiEngine();
@@ -124,58 +151,14 @@
&& !fepMan->IsFlagSet(CAknFepManager::EFlagQwertyChrKeyDepressed))
{
TBuf<1> ToneMarkBuf;
-#ifdef RD_INTELLIGENT_TEXT_INPUT
- if( keyboardType == EPtiKeyboardQwerty4x12)
- {
-#endif
- switch(aKey)
- {
- case EPtiKeyQwerty3:
- ToneMarkBuf.Append(KZhuyinTone3);
- break;
+ if(ToneMark(aKey, ToneMarkBuf) > 0)
- case EPtiKeyQwerty4:
- ToneMarkBuf.Append(KZhuyinTone4);
- break;
- case EPtiKeyQwerty6:
- ToneMarkBuf.Append(KZhuyinTone2);
- break;
- case EPtiKeyQwerty7:
- ToneMarkBuf.Append(KZhuyinTone5);
- break;
- default:
- break;
- }
-#ifdef RD_INTELLIGENT_TEXT_INPUT
- }
- else
- if (keyboardType == EPtiKeyboardQwerty4x10 || keyboardType
- == EPtiKeyboardQwerty3x11)
{
- switch (aKey)
- {
- case EPtiKeyQwertyE:
- ToneMarkBuf.Append(KZhuyinTone3);
- break;
- case EPtiKeyQwertyR:
- ToneMarkBuf.Append(KZhuyinTone4);
- break;
- case EPtiKeyQwertyY:
- ToneMarkBuf.Append(KZhuyinTone2);
- break;
- case EPtiKeyQwertyU:
- ToneMarkBuf.Append(KZhuyinTone5);
- break;
- default:
- break;
- }
- }
-#endif
MAknFepManagerUIInterface* fepMan = iOwner->FepMan();
fepMan->NewCharacterL(ToneMarkBuf);
@@ -186,6 +169,7 @@
iOwner->FepMan()->TryCloseUiL();
}
ret = ETrue;
+ }
}
else if(iOwner->IsValidChineseInputKeyQwerty(aKey) &&
!fepMan->IsFlagSet(CAknFepManager::EFlagQwertyChrKeyDepressed) &&
@@ -336,10 +320,29 @@
return response;
}
+//--------------------------------------------------------------------------
+// The gate to decide whether it is a character is whether it has valid mapping
+// If return ETrue, the key will pass to ptiengine.
+//--------------------------------------------------------------------------
+//
TBool TAknFepInputStateInitialChineseGenericQwerty::IsCharacter(TInt aKey)
{
TBool response = EFalse;
- if (aKey >= EPtiKeyQwertyA && aKey <= EPtiKeyQwertyZ)
+ CPtiEngine* ptiengine = iOwner->PtiEngine();
+ MAknFepManagerUIInterface* fepMan = iOwner->FepMan();
+ TPtiTextCase textCase = EPtiCaseLower;
+ if (ptiengine && fepMan)
+ {
+ TBuf<KMaxName> data;
+ ptiengine->MappingDataForKey((TPtiKey)aKey, data, textCase);
+ if (data.Length() > 0)
+ {
+ response = ETrue;
+ }
+ }
+
+ // exception Z might has no mapping but need to put into ptiengine.
+ if(!response && aKey == EPtiKeyQwertyZ)
{
response = ETrue;
}
--- a/fep/aknfep/src/AknFepUiManagerBase.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/src/AknFepUiManagerBase.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -1023,4 +1023,18 @@
return iFepMan->ZhuyinAnalyser();
}
+TBool CAknFepUIManagerBase::MapAgainst(TInt aKey, TInt aMode, TInt16 aAgainst, TInt aCase) const
+ {
+ if(iPtiEngine)
+ {
+ iPtiEngine->SetInputMode((TPtiEngineInputMode)aMode);
+ TBuf<KMaxName> data;
+ iPtiEngine->MappingDataForKey((TPtiKey)aKey, data, (TPtiTextCase)aCase);
+ if(data.Length() > 0)
+ {
+ return (data[0] == aAgainst);
+ }
+ }
+ return EFalse;
+ }
// End of file
--- a/fep/aknfep/src/AknFepUiManagerChinese.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/src/AknFepUiManagerChinese.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -132,6 +132,14 @@
const TInt16 KStrokeQuestionValue = 0x003f;
const TInt16 KStrokeUnicode = 0x2461;
const TInt16 KZhuyinIndicator = 0x2462;
+const TInt16 KPinyinIndicator = 0x2460;
+//const TInt16 KStrokeIndicator = 0x2461;
+const TInt16 KCanjieIndicator = 0x2463;
+const TInt16 KChineseTone1 = 0x02c9;
+const TInt16 KChineseTone2 = 0x02ca;
+const TInt16 KChineseTone3 = 0x02c7;
+const TInt16 KChineseTone4 = 0x02cb;
+const TInt16 KChineseTone0 = 0x02d9;
/**
* CAknFepUIManagerChinese class.
*
@@ -475,6 +483,48 @@
return EFalse;
}
#endif
+TBool CAknFepUIManagerChinese::IsValidChineseInputSymbol(TInt aKey, TPtiEngineInputMode aMode) const
+ {
+ if( aMode == EPtiEnginePinyinPhraseQwerty)
+ {
+ return MapAgainst(aKey, aMode, KPinyinIndicator, EPtiCaseLower);
+ }
+ else if( aMode == EPtiEngineZhuyinPhraseQwerty)
+ {
+ return MapAgainst(aKey, aMode, KZhuyinIndicator, EPtiCaseLower);
+ }
+ else if( aMode == EPtiEngineNormalCangjieQwerty ||
+ aMode == EPtiEngineEasyCangjieQwerty ||
+ aMode == EPtiEngineAdvCangjieQwerty)
+ {
+ return MapAgainst(aKey, aMode, KCanjieIndicator, EPtiCaseLower);
+ }
+ return EFalse;
+ }
+TBool CAknFepUIManagerChinese::IsValidChineseToneMarkKey(TInt aKey, TPtiEngineInputMode aMode) const
+ {
+ if( MapAgainst(aKey, aMode, KChineseTone1, EPtiCaseLower))
+ {
+ return ETrue;
+ }
+ else if( MapAgainst(aKey, aMode, KChineseTone2, EPtiCaseLower))
+ {
+ return ETrue;
+ }
+ else if( MapAgainst(aKey, aMode, KChineseTone3, EPtiCaseLower))
+ {
+ return ETrue;
+ }
+ else if( MapAgainst(aKey, aMode, KChineseTone4, EPtiCaseLower))
+ {
+ return ETrue;
+ }
+ else if( MapAgainst(aKey, aMode, KChineseTone0, EPtiCaseLower))
+ {
+ return ETrue;
+ }
+ return EFalse;
+ }
// ---------------------------------------------------------------------------
// CAknFepUIManagerChinese::IsValidChineseInputKeyQwerty
//
@@ -495,8 +545,7 @@
if(iMode == EPinyin)
{
- if( (aKey >= EPtiKeyQwertyA && aKey <= EPtiKeyQwertyZ) ||
- (aKey >= EPtiKeyQwerty1 && aKey <= EPtiKeyQwerty9) ||
+ if( IsValidChineseInputSymbol(aKey, EPtiEnginePinyinPhraseQwerty) ||
(IsFlagSet(ESupportPinyinPhrase) && aKey == EPtiKeyQwertyApostrophe
&& State() != EInitial))
{
@@ -602,37 +651,14 @@
if(iMode == ECangJie)
{
- if (aKey >= EPtiKeyQwertyA && aKey <= EPtiKeyQwertyZ)
- {
- response = ETrue;
- }
+ response = IsValidChineseInputSymbol(aKey, (TPtiEngineInputMode)iFepMan->CangJieMode());
}
if(iMode == EZhuyin || iMode == EZhuyinFind)
{
#ifdef RD_INTELLIGENT_TEXT_INPUT
- if(EPtiKeyboardQwerty4x10 == keyboardType ||
- EPtiKeyboardQwerty3x11 == keyboardType )
- {
- TBuf<KMaxName> lowerdata;
- iPtiEngine->MappingDataForKey((TPtiKey)aKey, lowerdata, EPtiCaseLower);
// TInt ZhuyinUnicodeCur =0;
- for(TInt i=0;i<lowerdata.Length();i++)
- {
- if(lowerdata[i]==KZhuyinIndicator)
- {
- response = ETrue;
- }
- }
- }
- else if( EPtiKeyboardCustomQwerty == keyboardType)
- {
- if((aKey >= EPtiKeyQwertyA && aKey <= EPtiKeyQwertyZ))
- {
- response = ETrue;
- }
- }
- else if ( EPtiKeyboardHalfQwerty == keyboardType )
+ if ( EPtiKeyboardHalfQwerty == keyboardType )
{
if((aKey >= EPtiKeyQwertyA && aKey <= EPtiKeyQwertyZ) ||
(aKey >= EPtiKey0 && aKey <= EPtiKey9) ||
@@ -644,13 +670,7 @@
else
{
#endif
- if((aKey >= EPtiKeyQwertyA && aKey <= EPtiKeyQwertyZ) ||
- (aKey >= EPtiKeyQwerty0 && aKey <= EPtiKeyQwerty9)||
- (aKey == EPtiKeyQwertySemicolon) ||
- (aKey == EPtiKeyQwertyApostrophe) ||
- (aKey == EPtiKeyQwertyComma) ||
- (aKey == EPtiKeyQwertyFullstop) ||
- (aKey == EPtiKeyQwertySlash))
+ if(IsValidChineseInputSymbol(aKey, (TPtiEngineInputMode)EPtiEngineZhuyinPhraseQwerty))
{
response = ETrue;
}
@@ -697,37 +717,13 @@
if(iQwertyMode && (iMode == EZhuyin) && supportSCTToneMarks)
{
#ifdef RD_INTELLIGENT_TEXT_INPUT
- if( keyboardType == EPtiKeyboardQwerty4x12)
- {
-#endif
- if(aKey == EPtiKeyQwerty3 || aKey == EPtiKeyQwerty4 || aKey == EPtiKeyQwerty6 || aKey == EPtiKeyQwerty7)
- {
- return ETrue;
- }
- else
- {
- return EFalse;
- }
-#ifdef RD_INTELLIGENT_TEXT_INPUT
- }
- else if( keyboardType == EPtiKeyboardQwerty4x10 || keyboardType == EPtiKeyboardQwerty3x11)
- {
- if(aKey == EPtiKeyQwertyE || aKey == EPtiKeyQwertyR || aKey == EPtiKeyQwertyY || aKey == EPtiKeyQwertyU)
- {
- return ETrue;
- }
- else
- {
- return EFalse;
- }
- }
+ return IsValidChineseToneMarkKey(aKey, EPtiEngineZhuyinPhraseQwerty);
#endif
}
else
{
return EFalse;
}
- return EFalse;
}
// ---------------------------------------------------------------------------
--- a/fep/aknfep/src/aknfepuiinputminiqwertypinyinphrasebase.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/src/aknfepuiinputminiqwertypinyinphrasebase.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -1307,6 +1307,26 @@
}
}
+//-------------------------------------------------------------------------------
+// Purpose: to adjust the scancode to make pinyin works
+// Pinyin symbol inheritantly accepts A-Z, any input out of this range will make it crash.
+// Add this function to turn some alienated scancode to A-Z.
+//
+//---------------------------------------------------------------------------
+//
+void TAknFepInputMiniQwertyPinyinPhraseBase::MapKey(TInt& aKey)
+ {
+ if(iOwner && iOwner->PtiEngine())
+ {
+ iOwner->PtiEngine()->SetInputMode(EPtiEnginePinyinPhraseQwerty);
+ TBuf<KMaxName> upperdata;
+ iOwner->PtiEngine()->MappingDataForKey((TPtiKey)aKey, upperdata, EPtiCaseUpper);
+ if(upperdata.Length() > 0)
+ {
+ aKey = upperdata[0];
+ }
+ }
+ }
// ---------------------------------------------------------------------------
// TAknFepInputMiniQwertyPinyinPhraseBase::GetShowKeystroke
//Handle horizontal navigation.
@@ -1315,10 +1335,12 @@
void TAknFepInputMiniQwertyPinyinPhraseBase::GetShowKeystroke(TInt aKey,
TDes& aKeystroke)
{
+ TInt key = aKey;
+ MapKey(key);
TInt count = sizeof(StrokeMap )/sizeof(StrokeMap[0] );
for (TInt i = 0; i < count; i++)
{
- if (aKey == StrokeMap[i].iKeyCode)
+ if (key == StrokeMap[i].iKeyCode)
{
aKeystroke.Append(StrokeMap[i].iValue);
break;
@@ -1679,6 +1701,12 @@
}
GetShowKeystroke(aKey, keystroke);
+
+ //Add this condition to avoid crash in case keystroke is empty.
+ if(keystroke.Length() == 0)
+ {
+ return EFalse;
+ }
if ( index >= keystrokeArray->Count() )
{
keystrokeArray->AppendL(keystroke);
--- a/fep/aknfep/src/aknfepuiinputstateminiqwertyzhuyinphrase.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/fep/aknfep/src/aknfepuiinputstateminiqwertyzhuyinphrase.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -513,8 +513,7 @@
fepMan->NewTextL( currentText );
fepMan->CommitInlineEditL();
}
- UIContainer()->EditPaneWindow()->ResetAllArray();
- UIContainer()->EditPaneWindow()->SetPhraseCreationFlag( EFalse );
+
if ( fepMan->IsFlagSet( CAknFepManager::EFlagEditorFull ) )
{
fepMan->ClearFlag( CAknFepManager::EFlagEditorFull );
@@ -539,6 +538,8 @@
}
AddPhraseToDB( phraseCreatedWithZhuYin );
}
+ UIContainer()->EditPaneWindow()->ResetAllArray();
+ UIContainer()->EditPaneWindow()->SetPhraseCreationFlag( EFalse );
fepMan->TryCloseUiL();
}
--- a/inputmethods_plat/aknfep_settings_api/inc/AknFepInternalCRKeys.h Thu Sep 02 15:52:50 2010 +0100
+++ b/inputmethods_plat/aknfep_settings_api/inc/AknFepInternalCRKeys.h Fri Sep 17 17:26:50 2010 +0100
@@ -381,6 +381,46 @@
*/
const TUint32 KAknFepLastUsedPortraitInput = 0x00000026;
+/**
+ * following keys are used for tap accuracy enhancement, default input mode
+ */
+const TUint32 KAknFepTapAccuracyDefaultButtonExtMargins = 0x27;
+const TUint32 KAknFepTapAccuracyDefaultKeyCtrlExtMargins = 0x28;
+const TUint32 KAknFepTapAccuracyDefaultPointerMoveMaxMovement = 0x29;
+const TUint32 KAknFepTapAccuracyDefaultPointerMoveTimeout = 0x2a;
+const TUint32 KAknFepTapAccuracyDefaultPointerUpMaxMovement = 0x2b;
+const TUint32 KAknFepTapAccuracyDefaultPointerUpTimeout = 0x2c;
+
+/**
+ * following keys are used for tap accuracy enhancement, FSQ
+ */
+const TUint32 KAknFepTapAccuracyFsqButtonExtMargins = 0x2d;
+const TUint32 KAknFepTapAccuracyFsqKeyCtrlExtMargins = 0x2e;
+const TUint32 KAknFepTapAccuracyFsqPointerMoveMaxMovement = 0x2f;
+const TUint32 KAknFepTapAccuracyFsqPointerMoveTimeout = 0x30;
+const TUint32 KAknFepTapAccuracyFsqPointerUpMaxMovement = 0x31;
+const TUint32 KAknFepTapAccuracyFsqPointerUpTimeout = 0x32;
+
+/**
+ * following keys are used for tap accuracy enhancement, Portrait FSQ
+ */
+const TUint32 KAknFepTapAccuracyPFsqButtonExtMargins = 0x33;
+const TUint32 KAknFepTapAccuracyPFsqKeyCtrlExtMargins = 0x34;
+const TUint32 KAknFepTapAccuracyPFsqPointerMoveMaxMovement = 0x35;
+const TUint32 KAknFepTapAccuracyPFsqPointerMoveTimeout = 0x36;
+const TUint32 KAknFepTapAccuracyPFsqPointerUpMaxMovement = 0x37;
+const TUint32 KAknFepTapAccuracyPFsqPointerUpTimeout = 0x38;
+
+/**
+ * following keys are used for tap accuracy enhancement, Finger HWR
+ */
+const TUint32 KAknFepTapAccuracyFhwrButtonExtMargins = 0x39;
+const TUint32 KAknFepTapAccuracyFhwrKeyCtrlExtMargins = 0x3a;
+const TUint32 KAknFepTapAccuracyFhwrPointerMoveMaxMovement = 0x3b;
+const TUint32 KAknFepTapAccuracyFhwrPointerMoveTimeout = 0x3c;
+const TUint32 KAknFepTapAccuracyFhwrPointerUpMaxMovement = 0x3d;
+const TUint32 KAknFepTapAccuracyFhwrPointerUpTimeout = 0x3e;
+
#endif
// End of file
--- a/inputmethods_plat/pen_input_server_api/inc/peninputclient.h Thu Sep 02 15:52:50 2010 +0100
+++ b/inputmethods_plat/pen_input_server_api/inc/peninputclient.h Fri Sep 17 17:26:50 2010 +0100
@@ -428,6 +428,7 @@
IMPORT_C TInt ConnectAsyc(TRequestStatus& aStatus);
IMPORT_C void SetDataQueryPopped(TBool aFlag);
IMPORT_C void EnablePriorityChangeOnOriChange(TBool aEnabled);
+ IMPORT_C void EnableGfxTransEffect( TBool aEnable );
private: // Data
/**
* The singleton client to the input server
--- a/inputmethods_plat/pen_input_server_api/inc/peninputcmd.h Thu Sep 02 15:52:50 2010 +0100
+++ b/inputmethods_plat/pen_input_server_api/inc/peninputcmd.h Fri Sep 17 17:26:50 2010 +0100
@@ -75,6 +75,7 @@
EPeninputOpLastCommand ,
EPeninputOpRequestDSAState,
EPeninputOpChangeFeedbackType,
+ EPeninputOpUpdatePointerSuppressor,
EPeninputUserCmdBase = 1000
};
@@ -112,6 +113,7 @@
ESignalDisableUpdating,
ESignalDrawBackground,
ESignalEnableLayoutRedrawWhenActive,
+ ESignalUpdatePointerSuppressor,
ESignalFepEventBase = 1500, //Event base for Fep. All fep event
//is re-directed to Fep.
ESignalKeyEvent = 1501, //hwr recongition selection event.
--- a/textinput/peninputarc/bwins/peninputClientU.DEF Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/bwins/peninputClientU.DEF Fri Sep 17 17:26:50 2010 +0100
@@ -64,4 +64,5 @@
?ConnectAsyc@RPeninputServer@@QAEHAAVTRequestStatus@@@Z @ 63 NONAME ; int RPeninputServer::ConnectAsyc(class TRequestStatus &)
?SetDataQueryPopped@RPeninputServer@@QAEXH@Z @ 64 NONAME ; void RPeninputServer::SetDataQueryPopped(int)
?EnablePriorityChangeOnOriChange@RPeninputServer@@QAEXH@Z @ 65 NONAME ; void RPeninputServer::EnablePriorityChangeOnOriChange(int)
+ ?EnableGfxTransEffect@RPeninputServer@@QAEXH@Z @ 66 NONAME ; void RPeninputServer::EnableGfxTransEffect(int)
--- a/textinput/peninputarc/eabi/peninputClientU.DEF Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/eabi/peninputClientU.DEF Fri Sep 17 17:26:50 2010 +0100
@@ -73,4 +73,5 @@
_ZN15RPeninputServer11ConnectAsycER14TRequestStatus @ 72 NONAME
_ZN15RPeninputServer18SetDataQueryPoppedEi @ 73 NONAME
_ZN15RPeninputServer31EnablePriorityChangeOnOriChangeEi @ 74 NONAME
+ _ZN15RPeninputServer20EnableGfxTransEffectEi @ 75 NONAME
--- a/textinput/peninputarc/inc/peninputlayoutcontrolinc/peninputlayout.h Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/inc/peninputlayoutcontrolinc/peninputlayout.h Fri Sep 17 17:26:50 2010 +0100
@@ -564,6 +564,22 @@
*/
inline MTouchFeedback* TouchFeedbackInstance();
+ /**
+ * Get extra response area of virtual key controls.
+ *
+ * @since Symbian^3
+ * @param aMargins output the margins around the original response area.
+ */
+ void GetKeyExtResponseArea( TMargins& aMargins );
+
+ /**
+ * Get extra response area of button controls.
+ *
+ * @since Symbian^3
+ * @param aMargins output the margins around the original response area.
+ */
+ void GetButtonExtResponseArea( TMargins& aMargins );
+
protected:
/**
* Constructor
@@ -631,6 +647,14 @@
void SendEditorTextAndCursorPosL(TUint8* aData);
void SetSelfBmpDeviceFlag(TBool aFlag);
+ /**
+ * Load tap accuracy enhancement settings according to the specified input mode.
+ *
+ * @since Symbian^3
+ * @param alayoutType specifies the input mode(refer to TPluginInputMode) of this layout.
+ */
+ void LoadTapAccuracySettingsL( TInt alayoutType );
+
private:
NONSHARABLE_CLASS( CFepUiLayoutExt) : public CBase
{
@@ -648,7 +672,39 @@
MTouchFeedback* iTouchFeedbackInstance;
TBool iSelfBmpDeviceFlag;
- TBool iDisableDrawing;
+ TBool iDisableDrawing;
+
+ /**
+ * PointerMove event suppressor parameter: max movement(in pixel)
+ */
+ TSize iPointerMoveSuppressMaxMovement;
+
+ /**
+ * PointerMove event suppressor parameter: timeout(in microsecond)
+ */
+ TInt iPointerMoveSuppressTimeout;
+
+ /**
+ * PointerUp event suppressor parameter: max movement(in pixel)
+ */
+ TSize iPointerUpSuppressMaxMovement;
+
+ /**
+ * PointerUp event suppressor parameter: timeout(in microsecond)
+ */
+ TInt iPointerUpSuppressTimeout;
+
+ /**
+ * extra response area of virtual key controls
+ */
+ TMargins iKeyExtResponseMargins;
+
+ /**
+ * extra response area of virtual button controls
+ */
+ TMargins iButtonExtResponseMargins;
+
+
};
private:
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/textinput/peninputarc/inc/peninputlayoutcontrolinc/peninputtapsettingmanager.h Fri Sep 17 17:26:50 2010 +0100
@@ -0,0 +1,203 @@
+/*
+* Copyright (c) 2010 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: header file of peninput ui layout
+*
+*/
+
+
+#ifndef PENINPUTTAPSETTINGMANAGER_H
+#define PENINPUTTAPSETTINGMANAGER_H
+
+#include <e32cmn.h>
+#include <e32base.h>
+#include <gdi.h>
+
+NONSHARABLE_CLASS(CPeninputTapSettingManager) : public CBase
+ {
+public: //constructors
+ /**
+ * Symbian constructor.
+ *
+ * @since Symbian^3
+ * @return Pointer to created object
+ */
+ static CPeninputTapSettingManager* NewL();
+
+ /**
+ * Symbian constructor.
+ *
+ * @since Symbian^3
+ * @return Pointer to created object
+ */
+ static CPeninputTapSettingManager* NewLC();
+
+ /*
+ * Standard c++ destructor.
+ * @since Symbian^3
+ */
+ virtual ~CPeninputTapSettingManager();
+
+public:
+ /**
+ * Load all parameters of tap accuracy enhancement for specified layout.
+ *
+ * @since Symbian^3
+ * @param aLayoutType layout type, refer to TPluginInputMode
+ * @return none
+ */
+ void Load( TInt aLayoutType );
+
+ /**
+ * Load all parameters of tap accuracy enhancement for specified layout.
+ *
+ * @since Symbian^3
+ * @param aLayoutType layout type, refer to TPluginInputMode
+ * @param aFileName path name of configuration file
+ * @return none
+ */
+ void Load( TInt aLayoutType, const TDesC& aFileName );
+
+ /**
+ * Get configuration of PointerMove event suppressor.
+ *
+ * @since Symbian^3
+ * @param aMaxMovement output max movement of PointerMove event
+ * @param aTimeout output timeout(in microsecond) of PointerMove event
+ * @return none
+ */
+ void GetPointerMoveSuppressor( TSize& aMaxMovement, TInt& aTimeout );
+
+ /**
+ * Get configuration of PointerUp event suppressor.
+ *
+ * @since Symbian^3
+ * @param aMaxMovement output max movement of PointerUp event
+ * @param aTimeout output timeout(in microsecond) of PointerUp event
+ * @return none
+ */
+ void GetPointerUpSuppressor( TSize& aMaxMovement, TInt& aTimeout );
+
+ /**
+ * Get extra response area of virtual key controls.
+ *
+ * @since Symbian^3
+ * @param aMargins output the margins around the original response area.
+ * @return none
+ */
+ void GetKeyExtResponseArea( TMargins& aMargins );
+
+ /**
+ * Get extra response area of button controls.
+ *
+ * @since Symbian^3
+ * @param aMargins output the margins around the original response area.
+ * @return none
+ */
+ void GetButtonExtResponseArea( TMargins& aMargins );
+
+private:
+ /**
+ * C++ constructor
+ *
+ * @since Symbian^3
+ * @return None
+ */
+ CPeninputTapSettingManager();
+
+ /**
+ * Symbian second-phase constructor
+ *
+ * @since Symbian^3
+ * @return None
+ */
+ void ConstructL();
+private:
+ /**
+ * Load all parameters of tap accuracy enhancement for specified layout.
+ *
+ * @since Symbian^3
+ * @param aLayoutType layout type, refer to TPluginInputMode
+ * @return none
+ */
+ void LoadFromRepositoryL( TInt aLayoutType );
+
+ /**
+ * Load all parameters of tap accuracy enhancement for specified layout
+ *
+ * @since Symbian^3
+ * @param aLayoutType layout type, refer to TPluginInputMode
+ * @param aFileName path name of configuration file
+ * @return none
+ */
+ void LoadFromFileL( TInt aLayoutType, const TDesC& aFileName );
+
+ /**
+ * Load default parameters
+ *
+ * @since Symbian^3
+ * @return none
+ */
+ void LoadDefault();
+
+ /**
+ * parse a TPoint from a comma separated values string.
+ *
+ * @since Symbian^3
+ * @return number of values in aText
+ */
+ TInt ParsePoints( TPoint& aPoint, const TDesC& aText );
+
+ /**
+ * parse a TMargins from a comma separated values string.
+ *
+ * @since Symbian^3
+ * @param aMargins output parse result
+ * @param aText source string
+ * @return number of values in aText
+ */
+ TInt ParseMargins( TMargins& aMargins, const TDesC& aText );
+
+private:
+ /**
+ * max movement of PointerMove event
+ */
+ TSize iPointerMoveMaxMovement;
+
+ /**
+ * timeout of PointerMove event, microsecond
+ */
+ TInt iPointerMoveTimeout;
+
+ /**
+ * max movement of PointerUp event
+ */
+ TSize iPointerUpMaxMovement;
+
+ /**
+ * timeout of PointerUp event, microsecond
+ */
+ TInt iPointerUpTimeout;
+
+ /**
+ * extra response area of virtual key controls
+ */
+ TMargins iKeyMargins;
+
+ /**
+ * extra response area of button controls
+ */
+ TMargins iButtonMargins;
+ };
+
+#endif // PENINPUTTAPSETTINGMANAGER_H
--- a/textinput/peninputarc/inc/pensrvcliinc/peninputanimclientobj.h Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/inc/pensrvcliinc/peninputanimclientobj.h Fri Sep 17 17:26:50 2010 +0100
@@ -231,6 +231,16 @@
* @return ETrue if command added successfully.
*/
TBool SetDiscreetPopArea(const TRect& aArea);
+
+ /**
+ * Update parameters of pointer event suppressor.
+ *
+ * @since Symbian^3
+ * @param aParameters parameters of pointer event suppressor
+ * @return none
+ */
+ void UpdatePointerEventSuppressor( const TPointerEventSuppressorParameters& aParameters );
+
private:
/**
* Default constructor.
--- a/textinput/peninputarc/inc/pensrvcliinc/peninputanimcommand.h Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/inc/pensrvcliinc/peninputanimcommand.h Fri Sep 17 17:26:50 2010 +0100
@@ -494,6 +494,37 @@
private:
TRect iArea;
};
+
+//class TAnimUpdatePointerEventSuppressorCmd
+/**
+ * Class for handling pointer event suppressor command
+ *
+ *
+ * @since Symbian^3
+ */
+class TAnimUpdatePointerEventSuppressorCmd : public TAnimCmd
+ {
+public:
+ /**
+ * Default constructor
+ * @param aAnim The animation cliet which executes the command
+ * @param aParameters parameters of pointer event suppressor
+ */
+ TAnimUpdatePointerEventSuppressorCmd( RPeninputAnim& aAnim,
+ const TPointerEventSuppressorParameters& aParameters );
+
+ /**
+ * Execute the command
+ *
+ * @since Symbian^3
+ * @return ETrue if command has been executed successfully.
+ */
+ virtual TBool ExecuteAnimCommand() const;
+
+private:
+ TPointerEventSuppressorParameters iParameters;
+ };
+
#include "peninputanimcommand.inl"
#endif //C_CPENINPUTANIM_CMD_H
--- a/textinput/peninputarc/inc/pensrvcliinc/peninputclientimpl.h Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/inc/pensrvcliinc/peninputclientimpl.h Fri Sep 17 17:26:50 2010 +0100
@@ -468,6 +468,15 @@
TBool ServerReady();
void OnServerStarted(TInt aErr);
+ /**
+ * Enable or disable transition effect.
+ *
+ * @since Symbian^3
+ * @param aEnable, ETrue: enable transition effect
+ * EFalse: disable transition effect.
+ */
+ void EnableGfxTransEffect( TBool aEnable );
+
private:
/**
* Constructor
--- a/textinput/peninputarc/inc/pensrvcliinc/peninputclientserver.h Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/inc/pensrvcliinc/peninputclientserver.h Fri Sep 17 17:26:50 2010 +0100
@@ -89,7 +89,8 @@
EPeninputRequestDimResChangeLayout,
EPeninputRequestSupportInputMode,
EPeninputRequestSetInputLanguage,
- EPeninputEnablePriorityChangeOnOriChange
+ EPeninputEnablePriorityChangeOnOriChange,
+ EPeninputRequestEnableGfxTransEffect
};
//server error code
--- a/textinput/peninputarc/inc/pensrvcliinc/peninputcmdparamext.h Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/inc/pensrvcliinc/peninputcmdparamext.h Fri Sep 17 17:26:50 2010 +0100
@@ -45,4 +45,19 @@
// see MAnimSpriteFunctions::UpdateMember
TBool iFullUpdateFlag;
};
+
+/**
+ * parameters for pointer event suppressor
+ */
+struct TPointerEventSuppressorParameters
+ {
+ TBool iMoveEventSuppressEnabled;
+ TSize iMoveEventMaxMovement;
+ TInt iMoveEventTimeout;
+
+ TBool iUpEventSuppressEnabled;
+ TSize iUpEventMaxMovement;
+ TInt iUpEventTimeout;
+ };
+
#endif //_PENINPUTPARAM_EXT_H
--- a/textinput/peninputarc/inc/pensrvcliinc/peninputserver.h Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/inc/pensrvcliinc/peninputserver.h Fri Sep 17 17:26:50 2010 +0100
@@ -693,6 +693,15 @@
void CheckSessionValidL(CPeninputServerSession* aSession1,
CPeninputServerSession* aSession2) const;
+ /**
+ * Update parameters of pointer event suppressor.
+ *
+ * @since Symbian^3
+ * @param aData parameters of pointer event suppressor
+ * @return none
+ */
+ void UpdatePointerEventSuppressor( const TDesC& aData );
+
public:
TInt DisabledByDSA();
TInt DisabledByDSAFromAnim();
--- a/textinput/peninputarc/inc/pensrvcliinc/penpointereventsuppressor.h Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/inc/pensrvcliinc/penpointereventsuppressor.h Fri Sep 17 17:26:50 2010 +0100
@@ -85,7 +85,9 @@
* @param aPointerEvent the pointer event which may need to be suppressed.
* @return ETrue if the pointer event should be suppressed, or EFalse if it should be handled.
*/
- TBool SuppressPointerEvent(const TPointerEvent& aPointerEvent);
+
+ TBool SuppressPointerEvent( TPointerEvent& aPointerEvent );
+
/**
* Set the maximum time period that drag events should be
* ignored during a pointer interaction.
@@ -109,6 +111,24 @@
*/
void SetMinInterDragInterval(TTimeIntervalMicroSeconds aInterval);
+ /**
+ * Set the maximum pointer movement for up events.
+ * All up events within maximum movement and timeout are moved to the down position.
+ *
+ * @since Symbian^3
+ * @param aMaxDownUpMove maximum movement(in pixel) of up event
+ */
+ void SetMaxDownUpMove( TSize aMaxDownUpMove );
+
+ /**
+ * Set the maximum time between up and down events.
+ * All up events within maximum movement and timeout are moved to the down position.
+ *
+ * @since Symbian^3
+ * @param aDuration time between down and up events.
+ */
+ void SetMaxDownUpDuration( TTimeIntervalMicroSeconds aDuration );
+
private:
CPenPointerEventSuppressor();
@@ -120,6 +140,19 @@
TPoint iDownPos;
TBool iTap;
TTime iLastEventTime;
- };
+
+
+ /**
+ * The maximum pointer movement for up events.
+ * All up events within maximum movement and timeout are moved to the down position.
+ */
+ TSize iMaxDownUpMove;
+
+ /**
+ * The maximum time between up and down events.
+ * All up events within maximum movement and timeout are moved to the down position.
+ */
+ TTimeIntervalMicroSeconds iMaxDownUpDuration;
+ };
#endif
--- a/textinput/peninputarc/inc/pensrvcliinc/penuiwndctrl.h Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/inc/pensrvcliinc/penuiwndctrl.h Fri Sep 17 17:26:50 2010 +0100
@@ -241,6 +241,18 @@
*/
void SetCursorColor();
+ /**
+ * Enable or disable transition effect.
+ *
+ * @since Symbian^3
+ * @param aEnableGfxTransEffect, ETrue: enable transition effect
+ * EFalse: disable transition effect.
+ */
+ inline void EnableGfxTransEffect( TBool aEnableGfxTransEffect )
+ {
+ iEnableGfxTransEffect = aEnableGfxTransEffect;
+ };
+
public: // Functions from base classes.
/**
@@ -385,6 +397,12 @@
*/
TRgb iCursorColor;
+
+ /**
+ * If transition effect is enabled.
+ */
+ TBool iEnableGfxTransEffect;
+
friend class CCursorWindow;
};
class CInternalBkCtrl : public CCoeControl
--- a/textinput/peninputarc/inc/pensrvcliinc/rpeninputanim.h Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/inc/pensrvcliinc/rpeninputanim.h Fri Sep 17 17:26:50 2010 +0100
@@ -186,6 +186,16 @@
void GetDSAState(TBool& aState);
void SetDiscreeptPop(const TRect& aArea);
+
+ /**
+ * Update parameters of pointer event suppressor.
+ *
+ * @since Symbian^3
+ * @param aParameters parameters of pointer event suppressor
+ * @return none
+ */
+ void UpdatePointerEventSuppressor( const TPointerEventSuppressorParameters& aParameters );
+
private:
/**
--- a/textinput/peninputarc/src/peninputanim/peninputanim.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputanim/peninputanim.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -241,6 +241,7 @@
case TRawEvent::EButton1Up:
{
pointerEvent.iType = TPointerEvent::EButton1Up;
+ pointerEvent.iPosition = aRawEvent.Pos();
break;
}
case TRawEvent::EPointerMove:
@@ -259,17 +260,25 @@
return ETrue;
}
+ TRawEvent rawEvent = aRawEvent;
+ if ( aRawEvent.Type() == TRawEvent::EButton1Up
+ && aRawEvent.Pos() != pointerEvent.iPosition )
+ {
+ rawEvent.Set( TRawEvent::EButton1Up,
+ pointerEvent.iPosition.iX,
+ pointerEvent.iPosition.iY );
+ }
switch(aRawEvent.Type())
{
case TRawEvent::EKeyUp:
case TRawEvent::EKeyDown:
{
- return OnRawKeyEvent(aRawEvent);
+ return OnRawKeyEvent( rawEvent );
}
case TRawEvent::EButton1Down:
{
- TBool used = OnRawButton1Down(aRawEvent);
+ TBool used = OnRawButton1Down( rawEvent );
if ( used )
{
@@ -280,19 +289,19 @@
}
case TRawEvent::EButton1Up:
{
- TBool used = OnRawButton1Up(aRawEvent);
+ TBool used = OnRawButton1Up( rawEvent );
StopTimer();
return used;
}
case TRawEvent::EPointerMove:
{
- return OnRawPointerMove(aRawEvent);
+ return OnRawPointerMove( rawEvent );
}
default:
{
return EFalse;
- }
- }
+ }
+ }
}
// ---------------------------------------------------------------------------
@@ -695,6 +704,18 @@
SetDiscreeptPop(area);
}
break;
+ case EPeninputOpUpdatePointerSuppressor:
+ {
+ TPointerEventSuppressorParameters parameters;
+ TPckg<TPointerEventSuppressorParameters> msgData( parameters );
+ msg->ReadL( KMsgSlot1, msgData );
+
+ iPointerEventSuppressor->SetMaxTapMove( parameters.iMoveEventMaxMovement );
+ iPointerEventSuppressor->SetMaxTapDuration( parameters.iMoveEventTimeout );
+ iPointerEventSuppressor->SetMaxDownUpMove( parameters.iUpEventMaxMovement );
+ iPointerEventSuppressor->SetMaxDownUpDuration( parameters.iUpEventTimeout );
+ }
+ break;
default:
// unsupported opcode, panic the client
{
--- a/textinput/peninputarc/src/peninputanim/penpointereventsuppressor.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputanim/penpointereventsuppressor.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -21,6 +21,9 @@
const TInt KPenPointerEventSuppressorDefaultMinInterDragInterval = 0;
const TInt KPenPointerEventSuppressorDefaultMovement = 6;
+const TInt KPenPointerEventSuppressorDefaultMaxDownUpDuration = 400000; // 0.4 seconds
+const TInt KPenPointerEventSuppressorDefaultDownUpMovement = 7;
+
CPenPointerEventSuppressor* CPenPointerEventSuppressor::NewL()
{
return new (ELeave) CPenPointerEventSuppressor;
@@ -32,17 +35,20 @@
}
CPenPointerEventSuppressor::CPenPointerEventSuppressor()
-: iMaxTapDuration(KPenPointerEventSuppressorDefaultMaxTapDuration),
- iMinInterDragInterval(KPenPointerEventSuppressorDefaultMinInterDragInterval),
- iTap(EFalse)
+: iMaxTapDuration( KPenPointerEventSuppressorDefaultMaxTapDuration ),
+ iMinInterDragInterval( KPenPointerEventSuppressorDefaultMinInterDragInterval ),
+ iTap( EFalse ),
+ iMaxDownUpDuration( KPenPointerEventSuppressorDefaultMaxDownUpDuration )
{
// default move limit is 6 units, which seems to be a forgiving value for finger touch
iMaxTapMove.iWidth = KPenPointerEventSuppressorDefaultMovement;
iMaxTapMove.iHeight = KPenPointerEventSuppressorDefaultMovement;
+
+ iMaxDownUpMove.iWidth = KPenPointerEventSuppressorDefaultDownUpMovement;
+ iMaxDownUpMove.iHeight = KPenPointerEventSuppressorDefaultDownUpMovement;
}
-TBool CPenPointerEventSuppressor::SuppressPointerEvent(
- const TPointerEvent& aPointerEvent)
+TBool CPenPointerEventSuppressor::SuppressPointerEvent( TPointerEvent& aPointerEvent )
{
switch ( aPointerEvent.iType )
{
@@ -88,7 +94,17 @@
break;
}
case TPointerEvent::EButton1Up:
- {
+ {
+ TTime now;
+ now.HomeTime();
+ TPoint delta = aPointerEvent.iPosition - iDownPos;
+ if ( now.MicroSecondsFrom( iDownTime ) < iMaxDownUpDuration
+ && Abs( delta.iX ) < iMaxDownUpMove.iWidth
+ && Abs( delta.iY ) < iMaxDownUpMove.iHeight )
+ {
+ //within maximum movement and timeout, so move to position of down
+ aPointerEvent.iPosition = iDownPos;
+ }
iTap = EFalse;
break;
}
@@ -118,3 +134,13 @@
{
iMinInterDragInterval = aInterval;
}
+
+void CPenPointerEventSuppressor::SetMaxDownUpMove( TSize aMaxDownUpMove )
+ {
+ iMaxDownUpMove = aMaxDownUpMove;
+ }
+
+void CPenPointerEventSuppressor::SetMaxDownUpDuration( TTimeIntervalMicroSeconds aDuration )
+ {
+ iMaxDownUpDuration = aDuration;
+ }
--- a/textinput/peninputarc/src/peninputclient/penclientimpl.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputclient/penclientimpl.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -1542,6 +1542,18 @@
User::RequestComplete(iPendingRequest, aErr);
}
+// ---------------------------------------------------------------------------
+// Enable or disable transition effect.
+// ---------------------------------------------------------------------------
+//
+void RPeninputServerImpl::EnableGfxTransEffect( TBool aEnable)
+ {
+ TPckg<TBool> msg( aEnable );
+ TIpcArgs arg;
+ arg.Set( KMsgSlot0, &msg );
+ SendReceive(EPeninputRequestEnableGfxTransEffect, arg );
+ }
+
CWaitingServerAo::CWaitingServerAo(RPeninputServerImpl* aClient)
: CActive(CActive::EPriorityStandard),
iClient(aClient)
--- a/textinput/peninputarc/src/peninputclient/peninputclient.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputclient/peninputclient.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -509,5 +509,18 @@
{
iSingletonServer->EnablePriorityChangeOnOriChange(aEnabled);
}
+
+// ---------------------------------------------------------------------------
+// Enable or disable transition effect.
+// ---------------------------------------------------------------------------
+//
+EXPORT_C void RPeninputServer::EnableGfxTransEffect( TBool aEnable )
+ {
+ if ( iSingletonServer )
+ {
+ iSingletonServer->EnableGfxTransEffect( aEnable );
+ }
+ }
+
//end of class RPeninputServer
// End of File
--- a/textinput/peninputarc/src/peninputlayoutcontrol/peninputlayoutbutton.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputlayoutcontrol/peninputlayoutbutton.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -59,9 +59,13 @@
CFepUiBaseCtrl::BaseConstructL();
//tap accuracy enhancement
- if( FeatureManager::FeatureSupported( KFeatureIdFfCapacitiveDisplay ))
+ if ( FeatureManager::FeatureSupported( KFeatureIdFfCapacitiveDisplay ) )
{
- EnableExtResponseArea( ETrue, TRect(TPoint(10,10),TSize(10,10)) );
+ TMargins margins;
+ UiLayout()->GetButtonExtResponseArea( margins );
+ TPoint topLeftMargin( margins.iLeft, margins.iTop );
+ TSize bottomRightMargin( margins.iRight, margins.iBottom );
+ EnableExtResponseArea( ETrue, TRect( topLeftMargin,bottomRightMargin ) );
}
}
--- a/textinput/peninputarc/src/peninputlayoutcontrol/peninputlayoutcontrol.mmp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputlayoutcontrol/peninputlayoutcontrol.mmp Fri Sep 17 17:26:50 2010 +0100
@@ -58,6 +58,7 @@
SOURCE peninputfloatctrl.cpp
SOURCE peninputfloatbubble.cpp
SOURCE peninputaknvkbpreviewbubblerenderer.cpp
+SOURCE peninputtapsettingmanager.cpp
userinclude ../../inc/peninputlayoutcontrolinc
--- a/textinput/peninputarc/src/peninputlayoutcontrol/peninputlayoutvkbkeyctrl.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputlayoutcontrol/peninputlayoutvkbkeyctrl.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -106,9 +106,13 @@
BaseConstructL();
//tap accuracy enhancement
- if( FeatureManager::FeatureSupported( KFeatureIdFfCapacitiveDisplay ))
+ if ( FeatureManager::FeatureSupported( KFeatureIdFfCapacitiveDisplay ))
{
- EnableExtResponseArea( ETrue, TRect(TPoint(10,10),TSize(10,10)) );
+ TMargins margins;
+ UiLayout()->GetKeyExtResponseArea( margins );
+ TPoint topLeftMargin( margins.iLeft, margins.iTop );
+ TSize bottomRightMargin( margins.iRight, margins.iBottom );
+ EnableExtResponseArea( ETrue, TRect( topLeftMargin,bottomRightMargin ) );
}
}
@@ -155,10 +159,29 @@
else if(iKeyboard->StarIcon() &&
iKeyInfo->KeyUnicodes(TVirtualKeyTextPos(i)) == KKeyStarCharacter )
{
- //CFbsBitGc* gc = static_cast<CFbsBitGc*>(BitGc());
+ // Get the size of the icon
+ TSize starIconSize = iKeyboard->StarIcon()->Bitmap()->SizeInPixels();
+ // Get the rect of draw icon area
+ TRect drawIconRect = textLayout.TextRect();
+ // When the size of icon is different with the size of draw icon area,
+ // because the icon is drew from the left top coordinate of the draw
+ // icon area, so the icon will not be drew in the center. In this case,
+ // we need to adjust the top left coordinate of draw icon rect to
+ // make sure that the icon will be drew in the center of the key
+ if ( starIconSize != drawIconRect.Size())
+ {
+ // Adjust the top left coordinate of draw icon rect to make sure
+ // that the icon will be drew in the center of the key
+ drawIconRect.iTl.iX +=
+ ( drawIconRect.Width() - starIconSize.iWidth ) / 2;
+ drawIconRect.iTl.iY +=
+ ( drawIconRect.Height() - starIconSize.iHeight ) / 2;
+ }
+
+ // Draw the icon
AknPenInputDrawUtils::DrawColorIcon( iKeyboard->StarIcon(),
*aGc,
- textLayout.TextRect() );
+ drawIconRect );
}
else
{
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/textinput/peninputarc/src/peninputlayoutcontrol/peninputtapsettingmanager.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -0,0 +1,385 @@
+/*
+* Copyright (c) 2010 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: Implementation for CFepUiLayout
+*
+*/
+
+
+#include "peninputtapsettingmanager.h"
+
+#include <centralrepository.h>
+#include <AknFepGlobalEnums.h>
+#include <AknFepInternalCRKeys.h>
+
+_LIT( KSeparatorComma, "," );
+
+const TInt KTextBufferLength = 128;
+
+const TInt KDefaultMovement = 5;
+const TInt KDefaultTimeout = 200000;
+const TInt KDefaultMargin = 9;
+
+// ---------------------------------------------------------------------------
+// Symbian Constructor
+// ---------------------------------------------------------------------------
+//
+CPeninputTapSettingManager* CPeninputTapSettingManager::NewL()
+ {
+ CPeninputTapSettingManager* self = CPeninputTapSettingManager::NewLC();
+ CleanupStack::Pop( self );
+ return self;
+ }
+
+// ---------------------------------------------------------------------------
+// Symbian Constructor
+// ---------------------------------------------------------------------------
+//
+CPeninputTapSettingManager* CPeninputTapSettingManager::NewLC()
+ {
+ CPeninputTapSettingManager* self = new ( ELeave ) CPeninputTapSettingManager();
+ CleanupStack::PushL( self );
+ self->ConstructL();
+ return self;
+ }
+
+// ---------------------------------------------------------------------------
+// c++ destructor
+// ---------------------------------------------------------------------------
+//
+CPeninputTapSettingManager::~CPeninputTapSettingManager()
+ {
+
+ }
+
+// ---------------------------------------------------------------------------
+// Load all parameters of tap accuracy enhancement for specified layout
+// ---------------------------------------------------------------------------
+//
+void CPeninputTapSettingManager::Load( TInt aLayoutType )
+ {
+ TRAPD( err, LoadFromRepositoryL( aLayoutType ) );
+ if ( err != KErrNone )
+ {
+ LoadDefault();
+ }
+ }
+
+// ---------------------------------------------------------------------------
+// Load all parameters of tap accuracy enhancement for specified layout
+// ---------------------------------------------------------------------------
+//
+void CPeninputTapSettingManager::Load( TInt aLayoutType, const TDesC& aFileName )
+ {
+ TRAPD( err, LoadFromFileL( aLayoutType, aFileName ) );
+ if ( err != KErrNone )
+ {
+ LoadDefault();
+ }
+ }
+
+// ---------------------------------------------------------------------------
+// Get configuration of PointerMove event suppressor
+// ---------------------------------------------------------------------------
+//
+void CPeninputTapSettingManager::GetPointerMoveSuppressor( TSize& aMaxMovement,
+ TInt& aTimeout )
+ {
+ aMaxMovement = iPointerMoveMaxMovement;
+ aTimeout = iPointerMoveTimeout;
+ }
+
+// ---------------------------------------------------------------------------
+// Get configuration of PointerUp event suppressor
+// ---------------------------------------------------------------------------
+//
+void CPeninputTapSettingManager::GetPointerUpSuppressor( TSize& aMaxMovement,
+ TInt& aTimeout )
+ {
+ aMaxMovement = iPointerUpMaxMovement;
+ aTimeout = iPointerUpTimeout;
+ }
+
+// ---------------------------------------------------------------------------
+// Get extra response area of virtual key controls.
+// ---------------------------------------------------------------------------
+//
+void CPeninputTapSettingManager::GetKeyExtResponseArea( TMargins& aMargins )
+ {
+ aMargins = iKeyMargins;
+ }
+
+// ---------------------------------------------------------------------------
+// Get extra response area of button controls.
+// ---------------------------------------------------------------------------
+//
+void CPeninputTapSettingManager::GetButtonExtResponseArea( TMargins& aMargins )
+ {
+ aMargins = iButtonMargins;
+ }
+
+// ---------------------------------------------------------------------------
+// C++ constructor.
+// ---------------------------------------------------------------------------
+//
+CPeninputTapSettingManager::CPeninputTapSettingManager()
+ {
+
+ }
+
+// ---------------------------------------------------------------------------
+// Symbian second-phase constructor.
+// ---------------------------------------------------------------------------
+//
+void CPeninputTapSettingManager::ConstructL()
+ {
+ }
+
+// ---------------------------------------------------------------------------
+// Load all parameters of tap accuracy enhancement for specified layout.
+// From Repository.
+// ---------------------------------------------------------------------------
+//
+void CPeninputTapSettingManager::LoadFromRepositoryL( TInt aLayoutType )
+ {
+ TUint32 uidButtonExtMargins = 0;
+ TUint32 uidKeyCtrlExtMargins = 0;
+ TUint32 uidPointerMoveMaxMove = 0;
+ TUint32 uidPointerMoveTimeout = 0;
+ TUint32 uidPointerUpMaxMove = 0;
+ TUint32 uidPointerUpTimeout = 0;
+
+ switch( aLayoutType )
+ {
+ case EPluginInputModeFSQ:
+ {
+ uidButtonExtMargins = KAknFepTapAccuracyFsqButtonExtMargins;
+ uidKeyCtrlExtMargins = KAknFepTapAccuracyFsqKeyCtrlExtMargins;
+ uidPointerMoveMaxMove = KAknFepTapAccuracyFsqPointerMoveMaxMovement;
+ uidPointerMoveTimeout = KAknFepTapAccuracyFsqPointerMoveTimeout;
+ uidPointerUpMaxMove = KAknFepTapAccuracyFsqPointerUpMaxMovement;
+ uidPointerUpTimeout = KAknFepTapAccuracyFsqPointerUpTimeout;
+ }
+ break;
+ case EPluginInputModePortraitFSQ:
+ {
+ uidButtonExtMargins = KAknFepTapAccuracyPFsqButtonExtMargins;
+ uidKeyCtrlExtMargins = KAknFepTapAccuracyPFsqKeyCtrlExtMargins;
+ uidPointerMoveMaxMove = KAknFepTapAccuracyPFsqPointerMoveMaxMovement;
+ uidPointerMoveTimeout = KAknFepTapAccuracyPFsqPointerMoveTimeout;
+ uidPointerUpMaxMove = KAknFepTapAccuracyPFsqPointerUpMaxMovement;
+ uidPointerUpTimeout = KAknFepTapAccuracyPFsqPointerUpTimeout;
+ }
+ break;
+ case EPluginInputModeFingerHwr:
+ {
+ uidButtonExtMargins = KAknFepTapAccuracyFhwrButtonExtMargins;
+ uidKeyCtrlExtMargins = KAknFepTapAccuracyFhwrKeyCtrlExtMargins;
+ uidPointerMoveMaxMove = KAknFepTapAccuracyFhwrPointerMoveMaxMovement;
+ uidPointerMoveTimeout = KAknFepTapAccuracyFhwrPointerMoveTimeout;
+ uidPointerUpMaxMove = KAknFepTapAccuracyFhwrPointerUpMaxMovement;
+ uidPointerUpTimeout = KAknFepTapAccuracyFhwrPointerUpTimeout;
+ }
+ break;
+ default:
+ {
+ uidButtonExtMargins = KAknFepTapAccuracyDefaultButtonExtMargins;
+ uidKeyCtrlExtMargins = KAknFepTapAccuracyDefaultKeyCtrlExtMargins;
+ uidPointerMoveMaxMove = KAknFepTapAccuracyDefaultPointerMoveMaxMovement;
+ uidPointerMoveTimeout = KAknFepTapAccuracyDefaultPointerMoveTimeout;
+ uidPointerUpMaxMove = KAknFepTapAccuracyDefaultPointerUpMaxMovement;
+ uidPointerUpTimeout = KAknFepTapAccuracyDefaultPointerUpTimeout;
+ }
+ }
+
+ CRepository* repository = CRepository::NewL( KCRUidAknFep );
+ TBuf<KTextBufferLength> str;
+ TInt num = 0;
+ TPoint point;
+ TMargins margins;
+
+ //pointer move event
+ repository->Get( uidPointerMoveTimeout, num );
+ repository->Get( uidPointerMoveMaxMove, str );
+ ParsePoints( point, str );
+
+ iPointerMoveTimeout = num;
+ iPointerMoveMaxMovement.iWidth = point.iX;
+ iPointerMoveMaxMovement.iHeight = point.iY;
+
+ //pointer up event
+ repository->Get( uidPointerUpTimeout, num );
+ repository->Get( uidPointerUpMaxMove, str );
+ ParsePoints( point, str );
+
+ iPointerUpTimeout = num;
+ iPointerUpMaxMovement.iWidth = point.iX;
+ iPointerUpMaxMovement.iHeight = point.iY;
+
+ //key control
+ repository->Get( uidKeyCtrlExtMargins, str );
+ ParseMargins( margins, str );
+ iKeyMargins = margins;
+
+ //button control
+ repository->Get( uidButtonExtMargins, str );
+ ParseMargins( margins, str );
+ iButtonMargins = margins;
+
+ delete repository;
+ }
+
+// ---------------------------------------------------------------------------
+// Load all parameters of tap accuracy enhancement for specified layout.
+// From file.
+// ---------------------------------------------------------------------------
+//
+void CPeninputTapSettingManager::LoadFromFileL( TInt /*aLayoutType*/,
+ const TDesC& /*aFileName*/ )
+ {
+ //reserved
+ }
+
+// ---------------------------------------------------------------------------
+// Load default parameters.
+// ---------------------------------------------------------------------------
+//
+void CPeninputTapSettingManager::LoadDefault()
+ {
+ iPointerMoveMaxMovement = TSize( KDefaultMovement, KDefaultMovement );
+ iPointerMoveTimeout = KDefaultTimeout;
+
+ iPointerUpMaxMovement = TSize( KDefaultMovement, KDefaultMovement );
+ iPointerUpTimeout = KDefaultTimeout;
+
+ iKeyMargins.iTop = KDefaultMargin;
+ iKeyMargins.iLeft = KDefaultMargin;
+ iKeyMargins.iBottom = KDefaultMargin;
+ iKeyMargins.iRight = KDefaultMargin;
+
+ iButtonMargins.iTop = KDefaultMargin;
+ iButtonMargins.iLeft = KDefaultMargin;
+ iButtonMargins.iBottom = KDefaultMargin;
+ iButtonMargins.iRight = KDefaultMargin;
+ }
+
+// ---------------------------------------------------------------------------
+// parse a TPoint from a comma separated values string.
+// ---------------------------------------------------------------------------
+//
+TInt CPeninputTapSettingManager::ParsePoints( TPoint& aPoint, const TDesC& aText )
+ {
+ TPtrC tokenizer( aText );
+ TInt pos = tokenizer.Find( KSeparatorComma );
+ if ( pos == KErrNotFound )
+ {
+ TInt value = 0;
+ TLex converter( tokenizer );
+ TInt error = converter.Val( value );
+ aPoint.iX = ( KErrNone == error ? value : 0 );
+ aPoint.iY = aPoint.iX;
+ return 0;
+ }
+
+ TInt value = 0;
+
+ TLex converter( tokenizer.Left( pos ) );
+ TInt error = converter.Val( value );
+ aPoint.iX = ( KErrNone == error ? value : 0 );
+
+ converter = TLex( tokenizer.Mid( pos + 1 ) );
+ error = converter.Val( value );
+ aPoint.iY = ( KErrNone == error ? value : 0 );
+
+ return 0;
+ }
+
+// ---------------------------------------------------------------------------
+// parse a TMargins from a comma separated values string.
+// ---------------------------------------------------------------------------
+//
+TInt CPeninputTapSettingManager::ParseMargins( TMargins& aMargins, const TDesC& aText )
+ {
+ RArray<TInt> values;
+
+ TPtrC tokenizer( aText );
+ TInt pos = 0;
+ while ( pos != KErrNotFound )
+ {
+ pos = tokenizer.Find( KSeparatorComma );
+
+ TPtrC substr = ( pos == KErrNotFound ) ? tokenizer : tokenizer.Left( pos );
+ TInt value = 0;
+ TLex converter( substr );
+ TInt error = converter.Val( value );
+ values.Append( KErrNone == error ? value : 0 );
+
+ if ( pos != KErrNotFound )
+ {
+ TPtrC right = tokenizer.Mid( pos + 1 );
+ tokenizer.Set( right );
+ }
+ }
+
+ TInt count = values.Count();
+
+ //one value, applies to all sides
+ if( count == 1 )
+ {
+ aMargins.iTop = values[0];
+ aMargins.iLeft = values[0];
+ aMargins.iBottom = values[0];
+ aMargins.iRight = values[0];
+ }
+
+ //two values, first one specifies margins of top and bottom,
+ //the second specifies left and right.
+ else if( count == 2 )
+ {
+ aMargins.iTop = values[0];
+ aMargins.iLeft = values[1];
+ aMargins.iBottom = values[0];
+ aMargins.iRight = values[1];
+ }
+
+ //three values, first is top, second is the left and right, last is bottom.
+ else if( count == 3 )
+ {
+ aMargins.iTop = values[0];
+ aMargins.iLeft = values[1];
+ aMargins.iBottom = values[1];
+ aMargins.iRight = values[2];
+ }
+
+ //four values, specify top,left,bottom and right respectively
+ else if ( count >= 4 )
+ {
+ aMargins.iTop = values[0];
+ aMargins.iLeft = values[1];
+ aMargins.iBottom = values[2];
+ aMargins.iRight = values[3];
+ }
+
+ else
+ {
+ aMargins.iTop = 0;
+ aMargins.iLeft = 0;
+ aMargins.iBottom = 0;
+ aMargins.iRight = 0;
+ }
+
+ values.Close();
+ return count;
+ }
+
+//end of file
--- a/textinput/peninputarc/src/peninputlayoutcontrol/peninputuilayout.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputlayoutcontrol/peninputuilayout.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -35,6 +35,11 @@
#include <touchfeedback.h>
#include <featmgr.h>
#endif //RD_TACTILE_FEEDBACK
+
+#include <AknFepGlobalEnums.h>
+#include <layoutmetadata.cdl.h>
+#include "peninputtapsettingmanager.h"
+
// ======== MEMBER FUNCTIONS ========
// ---------------------------------------------------------------------------
@@ -85,6 +90,20 @@
iExtension->iSkinInstance = AknsUtils::SkinInstance();
iExtension->iTouchFeedbackInstance = MTouchFeedback::Instance();
iExtension->iDisableDrawing = EFalse;
+
+ TInt inputMode = PenInputType();
+ TBool isPortraitFSQEnabled = FeatureManager::FeatureSupported(
+ KFeatureIdFfVirtualFullscrPortraitQwertyInput );
+
+ //detect real type of two qwerty layout
+ if ( inputMode == EPluginInputModeFSQ && isPortraitFSQEnabled
+ && !Layout_Meta_Data::IsLandscapeOrientation() )
+ {
+ inputMode = EPluginInputModePortraitFSQ;
+ }
+
+ //load settings of tap accuracy enhancement
+ LoadTapAccuracySettingsL( inputMode );
}
// ---------------------------------------------------------------------------
@@ -474,7 +493,22 @@
iRootCtrl->OnActivate();
#ifdef RD_TACTILE_FEEDBACK
iExtension->iTactileSupported = FeatureManager::FeatureSupported( KFeatureIdTactileFeedback );
-#endif // RD_TACTILE_FEEDBACK
+#endif // RD_TACTILE_FEEDBACK
+
+ //update pointer event suppressor
+ if ( FeatureManager::FeatureSupported( KFeatureIdFfCapacitiveDisplay ) )
+ {
+ TPointerEventSuppressorParameters parameters;
+ parameters.iMoveEventMaxMovement = iExtension->iPointerMoveSuppressMaxMovement;
+ parameters.iMoveEventTimeout = iExtension->iPointerMoveSuppressTimeout;
+ parameters.iUpEventMaxMovement = iExtension->iPointerUpSuppressMaxMovement;
+ parameters.iUpEventTimeout = iExtension->iPointerUpSuppressTimeout;
+
+ TPtrC data( reinterpret_cast<TUint16*>(¶meters),
+ sizeof(TPointerEventSuppressorParameters) / 2 );
+
+ SignalOwner( ESignalUpdatePointerSuppressor, data );
+ }
}
// ---------------------------------------------------------------------------
@@ -923,4 +957,43 @@
SignalOwner(ESignalDisableUpdating,ptr);
}
+// ---------------------------------------------------------------------------
+// Get extra response area of key controls.
+// ---------------------------------------------------------------------------
+//
+void CFepUiLayout::GetKeyExtResponseArea( TMargins& aMargins )
+ {
+ aMargins = iExtension->iKeyExtResponseMargins;
+ }
+
+// ---------------------------------------------------------------------------
+// Get extra response area of button controls.
+// ---------------------------------------------------------------------------
+//
+void CFepUiLayout::GetButtonExtResponseArea( TMargins& aMargins )
+ {
+ aMargins = iExtension->iButtonExtResponseMargins;
+ }
+
+// ---------------------------------------------------------------------------
+// Load tap accuracy enhancement settings according to the specified input mode.
+// ---------------------------------------------------------------------------
+//
+void CFepUiLayout::LoadTapAccuracySettingsL( TInt alayoutType )
+ {
+ CPeninputTapSettingManager* manager = CPeninputTapSettingManager::NewL();
+
+ manager->Load( alayoutType );
+ manager->GetPointerMoveSuppressor( iExtension->iPointerMoveSuppressMaxMovement,
+ iExtension->iPointerMoveSuppressTimeout );
+
+ manager->GetPointerUpSuppressor( iExtension->iPointerUpSuppressMaxMovement,
+ iExtension->iPointerUpSuppressTimeout );
+
+ manager->GetKeyExtResponseArea( iExtension->iKeyExtResponseMargins );
+ manager->GetButtonExtResponseArea( iExtension->iButtonExtResponseMargins );
+
+ delete manager;
+ }
+
//end of file
--- a/textinput/peninputarc/src/peninputserverapp/peninputanimclientobj.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputserverapp/peninputanimclientobj.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -503,4 +503,21 @@
AddAnimCommand(cmd);
return ETrue;
}
+
+// ---------------------------------------------------------------------------
+// CPeninputAnimObj::UpdatePointerEventSuppressor()
+// Update parameters of pointer event suppressor.
+// ---------------------------------------------------------------------------
+//
+void CPeninputAnimObj::UpdatePointerEventSuppressor(
+ const TPointerEventSuppressorParameters& aParameters )
+ {
+ TAnimUpdatePointerEventSuppressorCmd* cmd =
+ new TAnimUpdatePointerEventSuppressorCmd( iAnim, aParameters );
+
+ if ( cmd != NULL )
+ {
+ AddAnimCommand( cmd );
+ }
+ }
//end of file
--- a/textinput/peninputarc/src/peninputserverapp/peninputanimcommand.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputserverapp/peninputanimcommand.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -362,3 +362,17 @@
iAnim.SetDiscreeptPop(iArea);
return ETrue;
}
+
+TAnimUpdatePointerEventSuppressorCmd::TAnimUpdatePointerEventSuppressorCmd(
+ RPeninputAnim& aAnim, const TPointerEventSuppressorParameters& aParameters )
+ : TAnimCmd( aAnim ), iParameters( aParameters )
+ {
+
+ }
+
+TBool TAnimUpdatePointerEventSuppressorCmd::ExecuteAnimCommand() const
+ {
+ iAnim.UpdatePointerEventSuppressor( iParameters );
+ return ETrue;
+ }
+
--- a/textinput/peninputarc/src/peninputserverapp/peninputserver.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputserverapp/peninputserver.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -863,7 +863,17 @@
//message requests UI attribute is always handled.
switch(aMessage.Function())
{
-
+ case EPeninputRequestEnableGfxTransEffect:
+ {
+ if( iUseWindowCtrl && iPenUiCtrl )
+ {
+ TBool enable = EFalse;
+ TPckg<TBool> msg( enable );
+ aMessage.ReadL( 0,msg );
+ iPenUiCtrl->EnableGfxTransEffect( enable );
+ }
+ }
+ break;
case EPeninputRequestUiIsVisible:
{
TPckg<TBool> msg(iActive);
@@ -2015,7 +2025,11 @@
iIsLayoutReDrawAllowWhenActive = *retVal;
}
break;
-
+ case ESignalUpdatePointerSuppressor:
+ {
+ UpdatePointerEventSuppressor( aEventData );
+ }
+ break;
default:
if(iUseWindowCtrl)
{
@@ -3031,6 +3045,21 @@
iDiscreetPopArea = iAknUiSrv.GetInUseGlobalDiscreetPopupRect();
iAnimObj->SetDiscreetPopArea(iDiscreetPopArea);
}
+
+// ---------------------------------------------------------------------------
+// CPeninputServer::UpdatePointerEventSuppressor()
+// Update parameters of pointer event suppressor.
+// ---------------------------------------------------------------------------
+//
+void CPeninputServer::UpdatePointerEventSuppressor( const TDesC& aData )
+ {
+ TUint16* buf = const_cast<TUint16* >( aData.Ptr() );
+ TPointerEventSuppressorParameters* parameters =
+ reinterpret_cast<TPointerEventSuppressorParameters*> ( buf );
+
+ iAnimObj->UpdatePointerEventSuppressor( *parameters );
+ }
+
// ======== class CEventQueue========
//
// ---------------------------------------------------------------------------
--- a/textinput/peninputarc/src/peninputserverapp/peninputserversession.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputserverapp/peninputserversession.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -320,6 +320,7 @@
case EPeninputRequestSupportInputMode:
case EPeninputRequestSetInputLanguage:
case EPeninputEnablePriorityChangeOnOriChange:
+ case EPeninputRequestEnableGfxTransEffect:
ret = iPenInputSvr.HandleMessageL(aMessage);
break;
case EPeninputRequestUpdateAppInfo:
--- a/textinput/peninputarc/src/peninputserverapp/penuiwndctrl.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputserverapp/penuiwndctrl.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -419,8 +419,9 @@
#ifdef RD_UI_TRANSITION_EFFECTS_POPUPS
- if ( GfxTransEffect::IsRegistered( this ) && !IsVisible())
+ if ( iEnableGfxTransEffect && GfxTransEffect::IsRegistered( this ) && !IsVisible())
{
+ iEnableGfxTransEffect = EFalse;
this->MakeVisible(EFalse);
GfxTransEffect::NotifyExternalState( ENotifyGlobalAbort );
@@ -463,9 +464,9 @@
return;
}
#ifdef RD_UI_TRANSITION_EFFECTS_POPUPS
- if ( GfxTransEffect::IsRegistered( this ))
+ if ( iEnableGfxTransEffect && GfxTransEffect::IsRegistered( this ) )
{
-
+ iEnableGfxTransEffect = EFalse;
GfxTransEffect::NotifyExternalState( ENotifyGlobalAbort );
//If still visible, do a transition to invisible state.
--- a/textinput/peninputarc/src/peninputserverapp/rpeninputanim.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputarc/src/peninputserverapp/rpeninputanim.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -336,4 +336,19 @@
args.Set(KMsgSlot1,&msgData);
CommandReply(EPeninputOpSetDiscreeptPop,KNullDesC8,args);
}
+
+// ---------------------------------------------------------------------------
+// RPeniputAnim::UpdatePointerEventSuppressor()
+// Update parameters of pointer event suppressor.
+// ---------------------------------------------------------------------------
+//
+void RPeninputAnim::UpdatePointerEventSuppressor(
+ const TPointerEventSuppressorParameters& aParameters )
+ {
+ TIpcArgs args( TIpcArgs::ENothing );
+ TPckg<TPointerEventSuppressorParameters> msgData( aParameters );
+ args.Set(KMsgSlot1, &msgData );
+ CommandReply( EPeninputOpUpdatePointerSuppressor, KNullDesC8, args );
+ }
+
// End of File
--- a/textinput/peninputfingerhwr/src/peninputfingerhwrwnd.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputfingerhwr/src/peninputfingerhwrwnd.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -1223,7 +1223,13 @@
// hide the predictive list
iPredictList->Hide( ETrue );
iPredictList->SetDropdownListImgID( predicDrawInfo );
-
+
+ iPredictList->SizeChanged( iLafManager->CandidateUnitWidth(),
+ iLafManager->CandidateUnitHeight(),
+ iLafManager->CandidateUnitWidth(),
+ iLafManager->PredictiveLTPos(),
+ KPredictiveCountPerRow,
+ KPredictiveRowCount );
#ifndef RD_INTELLIGENT_TEXT_INPUT
TDropdownListDrawInfo candiDrawInfo(
--- a/textinput/peninputgenericitut/src/peninputgenericitutdatamgr.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputgenericitut/src/peninputgenericitutdatamgr.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -494,7 +494,7 @@
TRect cellSpellRect;
cellSpellRect.iTl.iX = middleButtonPaneRect.iTl.iX;
cellSpellRect.iTl.iY = middleButtonPaneRect.iTl.iY +
- itucellrect.Rect().Height() * 5 + 7;
+ itucellrect.Rect().Height() * 5;
cellSpellRect.SetHeight( itucellrect.Rect().Height());
cellSpellRect.SetWidth( itucellrect.Rect().Width());
@@ -907,8 +907,18 @@
iCandsUnitHeight = charpanerect1.Rect().Height() ;
iCandsSpinBtnHeight = listctrlrect.Rect().Height();
+
+ TInt gapValue = ( iScreenSize.iWidth - (
+ iCandsUnitWidth + iCandsHorizontalMargin + KCandsAdjustment ) * 6 ) / 2;
+ if ( gapValue < 0 )
+ {
+ gapValue = 0;
+ }
+
iCandsSpellLTPos = charpanerect1.Rect().iTl;
+ iCandsSpellLTPos.iX = gapValue;
iCandsLTPos = charpanerect3.Rect().iTl;
+ iCandsLTPos.iX = gapValue;
iCandsPuncLTPos = iCandsSpellLTPos;
TAknTextLineLayout candstxtlayout =
--- a/textinput/peninputgenericvkb/src/peninputgenericlafdatamgr.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputgenericvkb/src/peninputgenericlafdatamgr.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -1038,12 +1038,17 @@
aDataInfo.iQwtRect = aParentWndRect;
TInt v1, v2, gridLayoutVariant;
+
+ // Get the variant for Portrait QWERTY
+ TInt cellVariantForPortraitQWERTY;
+
switch ( aLayoutType )
{
case ELayout10x3:
{
v1 = 0;
v2 = 0;
+ cellVariantForPortraitQWERTY = 0;
gridLayoutVariant = 1;
break;
}
@@ -1051,6 +1056,7 @@
{
v1 = 1;
v2 = 2;
+ cellVariantForPortraitQWERTY = 2;
gridLayoutVariant = 1;
break;
}
@@ -1058,6 +1064,7 @@
{
v1 = 1;
v2 = 3;
+ cellVariantForPortraitQWERTY = 3;
gridLayoutVariant = 2;
break;
}
@@ -1065,7 +1072,9 @@
{
v1 = 0;
v2 = 0;
+ cellVariantForPortraitQWERTY = 0;
gridLayoutVariant = 1;
+ break;
}
}
@@ -1164,6 +1173,32 @@
linelayout = AknLayoutScalable_Avkon::grid_vkbss_keypad_pane(v1).LayoutLine();
keypadRect.LayoutRect( rectBottomWin, linelayout );
+ TInt rowNumberOfKeyboard;
+ TInt gapValue;
+ switch ( aLayoutType )
+ {
+ case ELayout10x3:
+ {
+ rowNumberOfKeyboard = 3;
+ break;
+ }
+ case ELayout11x3:
+ {
+ rowNumberOfKeyboard = 3;
+ break;
+ }
+ case ELayout11x4:
+ {
+ rowNumberOfKeyboard = 4;
+ break;
+ }
+ default:
+ {
+ rowNumberOfKeyboard = 3;
+ break;
+ }
+ }
+
if ( !isPortraitFSQEnabled ||
( isPortraitFSQEnabled && Layout_Meta_Data::IsLandscapeOrientation() ) )
{
@@ -1192,7 +1227,10 @@
pic3pRightWidth = layoutrect.Rect().Width();
TRect rectXPane = keypaneRect.Rect();
- rect = keycellRect.Rect();
+
+ // the key rect without gap
+ rect = keypaneRect.Rect();
+
rect.Move( - rectXPane.iTl.iX, - rectXPane.iTl.iY );
TRect rectXBorder = rect;
rect = keylabelRect.Rect();
@@ -1205,11 +1243,14 @@
rect = keypadRect.Rect();
rect.Move( - base.iX, - base.iY );
- TRect rectOfKeypad = rect;
- TRect rectOfButtons = rectOfKeypad;
- rectOfKeypad.iBr.iY -= keypaneRect.Rect().Height();
- rectOfButtons.iTl.iY += rectOfKeypad.Height();
-
+
+ TRect rectOfButtons = rect;
+ // The gap between the top of the first row key and the top of the keyboard
+ gapValue = keypaneRect.Rect().iTl.iY - keypadRect.Rect().iTl.iY;
+ // compute the top left Y coordinate of the function buttons
+ rectOfButtons.iTl.iY = rectOfButtons.iTl.iY +
+ keypaneRect.Rect().Height() * rowNumberOfKeyboard + gapValue;
+
TInt spaceBtnWidth = rectOfButtons.Width() - rectXPane.Width() * 8;
TInt dx = rectOfButtons.iTl.iX;
TInt dy = rectOfButtons.iTl.iY;
@@ -1270,8 +1311,8 @@
linelayout = AknLayoutScalable_Avkon::cell_vkbss_key_pane(15).LayoutLine();
bottomRowRect.LayoutRect( keypadRect.Rect(), linelayout );
- // key cell rect
- linelayout = AknLayoutScalable_Avkon::bg_cell_vkbss_key_g1(8).LayoutLine();
+ // key cell rect with out gap
+ linelayout = AknLayoutScalable_Avkon::cell_vkbss_key_pane(15).LayoutLine();
keycellRect.LayoutRect( bottomRowRect.Rect(), linelayout );
// key label rect
@@ -1289,10 +1330,23 @@
rect = keypadRect.Rect();
rect.Move( - base.iX, - base.iY );
- TRect rectOfKeypad = rect;
- TRect rectOfButtons = rectOfKeypad;
- rectOfKeypad.iBr.iY -= ( bottomRowRect.Rect().Height() );
- rectOfButtons.iTl.iY += rectOfKeypad.Height();
+
+ // Get the height of one key
+ linelayout = AknLayoutScalable_Avkon::cell_vkbss_key_pane(
+ cellVariantForPortraitQWERTY ).LayoutLine();
+ keycellRect.LayoutRect( keypadRect.Rect(), linelayout );
+ TInt theHeightOfTheKey = keycellRect.Rect().Height();
+ // Compute the gap between the top of the first row key and
+ // the top of the keyboard
+ gapValue = keycellRect.Rect().iTl.iY - keypadRect.Rect().iTl.iY;
+ // Get the second row function button's height
+ linelayout = AknLayoutScalable_Avkon::cell_vkbss_key_pane(4).LayoutLine();
+ keycellRect.LayoutRect( keypadRect.Rect(), linelayout );
+
+ TRect rectOfButtons = rect;
+ // compute the top left Y coordinate of the first row function buttons
+ rectOfButtons.iTl.iY += keycellRect.Rect().Height() +
+ theHeightOfTheKey * rowNumberOfKeyboard + gapValue + 1;
TInt dx = rectOfButtons.iTl.iX;
TInt dy = rectOfButtons.iTl.iY;
@@ -1332,8 +1386,8 @@
linelayout = AknLayoutScalable_Avkon::cell_vkbss_key_pane(4).LayoutLine();
shiftRect.LayoutRect( keypadRect.Rect(), linelayout );
- // key cell rect
- linelayout = AknLayoutScalable_Avkon::bg_cell_vkbss_key_g1(4).LayoutLine();
+ // key cell rect without gap
+ linelayout = AknLayoutScalable_Avkon::cell_vkbss_key_pane(4).LayoutLine();
keycellRect.LayoutRect( shiftRect.Rect(), linelayout );
// key label rect
@@ -1351,6 +1405,8 @@
// Update the height to account for the second row
rectOfButtons.iTl.iY -= shiftRect.Rect().Height();
+ // adjust the Y coordinate
+ rectOfButtons.iTl.iY -= 1;
dx = rectOfButtons.iTl.iX;
dy = rectOfButtons.iTl.iY;
@@ -1363,8 +1419,8 @@
linelayout = AknLayoutScalable_Avkon::cell_vkbss_key_pane(8).LayoutLine();
spaceRect.LayoutRect( keypadRect.Rect(), linelayout );
- // key cell rect
- linelayout = AknLayoutScalable_Avkon::bg_cell_vkbss_key_g1(5).LayoutLine();
+ // key cell rect without gap
+ linelayout = AknLayoutScalable_Avkon::cell_vkbss_key_pane(8).LayoutLine();
keycellRect.LayoutRect( spaceRect.Rect(), linelayout );
// key label rect
@@ -1660,6 +1716,8 @@
TAknLayoutText keyTextLayout;
TAknTextLineLayout keyText;
TRect keyRect;
+ // The gap value of keyboard
+ TInt gapValue;
TBool isLandscape = Layout_Meta_Data::IsLandscapeOrientation();
@@ -1733,7 +1791,12 @@
}
rectVkbCtrl = keypadRect.Rect();
- rectVkbCtrl.iBr.iY -= functionKeyRowsHeight;
+ // Compute the gap between first row key's top line and keyboard's top line
+ gapValue = keypaneRect.Rect().iTl.iY - rectVkbCtrl.iTl.iY;
+ // Compute keyboard position
+ rectVkbCtrl.iBr.iY = rectVkbCtrl.iTl.iY + keypaneRect.Rect().Height() * 3 + gapValue;
+ rectVkbCtrl.iTl.iY += gapValue;
+
dataInfo->iKeypad.iKaypadRect = rectVkbCtrl;
linelayout = AknLayoutScalable_Avkon::bg_cell_vkbss_key_g1(0).LayoutLine();
@@ -1742,10 +1805,6 @@
linelayout = AknLayoutScalable_Avkon::cell_vkbss_key_g1(0).LayoutLine();
keylabelRect.LayoutRect( keypaneRect.Rect(), linelayout );
- linelayout = AknLayoutScalable_Avkon::aid_vkbss_key_offset(0).LayoutLine();
- layoutrect.LayoutRect( keypadRect.Rect(), linelayout );
- TInt rowIndentWidth = layoutrect.Rect().Width();
-
TRect rectOfKeypad = RelativeRect( keypadRect.Rect(), base );
rectOfKeypad.iBr.iY -= keypaneRect.Rect().Height();
@@ -1759,18 +1818,15 @@
for( TInt i = 0; i < KKeypadLayout[0][1]; i++)
{
- TInt indent = ( i % 2 == 1 ) ? rowIndentWidth : 0;
for( TInt j = 0; j < KKeypadLayout[0][0]; j++)
{
TRect bound = rectXPane;
bound.Move( j * rectXPane.Width(), i * rectXPane.Height() );
- bound.Move( indent, 0 );
dataInfo->iKeypad.iRects.AppendL( bound );
TRect inner = rectXPane;
inner.Move( j * rectXPane.Width(), i * rectXPane.Height() );
- inner.Move( indent, 0 );
TAknLayoutText keyTextLayout;
keyTextLayout.LayoutText( inner, keyText );
@@ -1888,7 +1944,13 @@
}
rectVkbCtrl = keypadRect.Rect();
- rectVkbCtrl.iBr.iY -= functionKeyRowsHeight;
+
+ // Compute the gap between first row key's top line and keyboard's top line
+ gapValue = keypaneRect.Rect().iTl.iY - rectVkbCtrl.iTl.iY;
+ // Compute keyboard position
+ rectVkbCtrl.iBr.iY = rectVkbCtrl.iTl.iY + keypaneRect.Rect().Height() * 3 + gapValue;
+ rectVkbCtrl.iTl.iY += gapValue;
+
dataInfo->iKeypad.iKaypadRect = rectVkbCtrl;
linelayout = AknLayoutScalable_Avkon::bg_cell_vkbss_key_g1(2).LayoutLine();
@@ -1897,10 +1959,6 @@
linelayout = AknLayoutScalable_Avkon::cell_vkbss_key_g1(2).LayoutLine();
keylabelRect.LayoutRect( keypaneRect.Rect(), linelayout );
- linelayout = AknLayoutScalable_Avkon::aid_vkbss_key_offset(1).LayoutLine();
- layoutrect.LayoutRect( keypadRect.Rect(), linelayout );
- rowIndentWidth = layoutrect.Rect().Width();
-
rectOfKeypad = RelativeRect( keypadRect.Rect(), base );
rectOfKeypad.iBr.iY -= keypaneRect.Rect().Height();
@@ -1914,18 +1972,15 @@
for( TInt i = 0; i < KKeypadLayout[1][1]; i++)
{
- TInt indent = ( i % 2 == 1 ) ? rowIndentWidth : 0;
for( TInt j = 0; j < KKeypadLayout[1][0]; j++)
{
TRect bound = rectXPane;
bound.Move( j * rectXPane.Width(), i * rectXPane.Height() );
- bound.Move( indent, 0 );
dataInfo->iKeypad.iRects.AppendL( bound );
TRect inner = rectXPane;
inner.Move( j * rectXPane.Width(), i * rectXPane.Height() );
- inner.Move( indent, 0 );
TAknLayoutText keyTextLayout;
keyTextLayout.LayoutText( inner, keyText );
@@ -2031,8 +2086,14 @@
keypaneRect.LayoutRect( keypadRect.Rect(), linelayout );
}
- rectVkbCtrl = keypadRect.Rect();
- rectVkbCtrl.iBr.iY -= functionKeyRowsHeight;
+ rectVkbCtrl = keypadRect.Rect();
+
+ // Compute the gap between first row key's top line and keyboard's top line
+ gapValue = keypaneRect.Rect().iTl.iY - rectVkbCtrl.iTl.iY;
+ // Compute keyboard position
+ rectVkbCtrl.iBr.iY = rectVkbCtrl.iTl.iY + keypaneRect.Rect().Height() * 4 + gapValue;
+ rectVkbCtrl.iTl.iY += gapValue;
+
dataInfo->iKeypad.iKaypadRect = rectVkbCtrl;
linelayout = AknLayoutScalable_Avkon::bg_cell_vkbss_key_g1(3).LayoutLine();
@@ -2041,10 +2102,6 @@
linelayout = AknLayoutScalable_Avkon::cell_vkbss_key_g1(3).LayoutLine();
keylabelRect.LayoutRect( keypaneRect.Rect(), linelayout );
- linelayout = AknLayoutScalable_Avkon::aid_vkbss_key_offset(1).LayoutLine();
- layoutrect.LayoutRect( keypadRect.Rect(), linelayout );
- rowIndentWidth = layoutrect.Rect().Width();
-
rectOfKeypad = RelativeRect( keypadRect.Rect(), base );
rectOfKeypad.iBr.iY -= keypaneRect.Rect().Height();
@@ -2058,18 +2115,15 @@
for( TInt i = 0; i < KKeypadLayout[2][1]; i++)
{
- TInt indent = ( i % 2 == 1 ) ? rowIndentWidth : 0;
for( TInt j = 0; j < KKeypadLayout[2][0]; j++)
{
TRect bound = rectXPane;
bound.Move( j * rectXPane.Width(), i * rectXPane.Height() );
- bound.Move( indent, 0 );
dataInfo->iKeypad.iRects.AppendL( bound );
TRect inner = rectXPane;
inner.Move( j * rectXPane.Width(), i * rectXPane.Height() );
- inner.Move( indent, 0 );
TAknLayoutText keyTextLayout;
keyTextLayout.LayoutText( inner, keyText );
--- a/textinput/peninputsplititut/src/peninputsplititutdatamgr.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputsplititut/src/peninputsplititutdatamgr.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -359,7 +359,7 @@
TRect cellSpellRect;
cellSpellRect.iTl.iX = middleButtonPaneRect.iTl.iX;
cellSpellRect.iTl.iY = middleButtonPaneRect.iTl.iY +
- itucellrect.Rect().Height() * 5 + 7;
+ itucellrect.Rect().Height() * 5;
cellSpellRect.SetHeight( itucellrect.Rect().Height());
cellSpellRect.SetWidth( itucellrect.Rect().Width());
--- a/textinput/peninputsplitqwerty/src/peninputsplitqwertylafdatamgr.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputsplitqwerty/src/peninputsplitqwertylafdatamgr.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -345,10 +345,6 @@
layoutrect.LayoutRect( pic3paneRect.Rect(), linelayout );
pic3pRightWidth = layoutrect.Rect().Width();
- linelayout = AknLayoutScalable_Avkon::aid_vkbss_key_offset(v1).LayoutLine();
- layoutrect.LayoutRect( keypadRect.Rect(), linelayout );
- TInt rowIndentWidth = layoutrect.Rect().Width();
-
base = rectMainWin.iTl;
data->iClientRect = RelativeRect( rectMainWin, base );
@@ -356,8 +352,43 @@
TRect rectOfKeypad = RelativeRect( keypadRect.Rect(), base );
TRect rectOfButtons = rectOfKeypad;
- rectOfKeypad.iBr.iY -= keypaneRect.Rect().Height();
- rectOfButtons.iTl.iY += rectOfKeypad.Height();
+
+ TInt rowNumberOfKeyboard;
+ TInt gapValue;
+ switch ( aLayoutType )
+ {
+ case ELayout10x3:
+ {
+ rowNumberOfKeyboard = 3;
+ break;
+ }
+ case ELayout11x3:
+ {
+ rowNumberOfKeyboard = 3;
+ break;
+ }
+ case ELayout11x4:
+ {
+ rowNumberOfKeyboard = 4;
+ break;
+ }
+ default:
+ {
+ rowNumberOfKeyboard = 3;
+ break;
+ }
+ }
+
+ // Compute the gap between first row key's top line and keyboard's top line
+ gapValue = keypaneRect.Rect().iTl.iY - keypadRect.Rect().iTl.iY;
+ // Compute function button's top left Y coordinate
+ rectOfButtons.iTl.iY = rectOfButtons.iTl.iY +
+ keypaneRect.Rect().Height() * rowNumberOfKeyboard + gapValue;
+
+ // Compute keyboard position
+ rectOfKeypad.iBr.iY = rectOfKeypad.iTl.iY +
+ keypaneRect.Rect().Height() * rowNumberOfKeyboard + gapValue;
+ rectOfKeypad.iTl.iY += gapValue;
//keypad
data->iKeypad.iKaypadRect = rectOfKeypad;
@@ -375,18 +406,15 @@
for ( TInt i = 0; i < aRows; i++ )
{
- TInt indent = ( i % 2 == 1 ) ? rowIndentWidth : 0;
for ( TInt j = 0; j < aCols; j++ )
{
TRect bound = rectXPane;
bound.Move( j * rectXPane.Width(), i * rectXPane.Height() );
- bound.Move( indent, 0 );
data->iKeypad.iRects.AppendL( bound );
TRect inner = rectXPane;
inner.Move( j * rectXPane.Width(), i * rectXPane.Height() );
- inner.Move( indent, 0 );
TAknLayoutText keyTextLayout;
keyTextLayout.LayoutText( inner, keyText );
@@ -398,7 +426,10 @@
//all template rects are relative to TL of buttons row
rectXPane = keypaneRect.Rect();
- rectXBorder = RelativeRect( keycellRect.Rect(), rectXPane.iTl );
+
+ // The key rect without gap
+ rectXBorder = RelativeRect( keypaneRect.Rect(), rectXPane.iTl );
+
rectXInner = RelativeRect( keylabelRect.Rect(), rectXPane.iTl );
TRect rect3PicPane = RelativeRect( pic3paneRect.Rect(), rectXPane.iTl );
rectXPane.Move( - rectXPane.iTl );
--- a/textinput/peninputvkbcn/ctrlsrc/peninputvkbclientarea.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputvkbcn/ctrlsrc/peninputvkbclientarea.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -952,6 +952,10 @@
TRect compositionRect;
TRect innerRect;
+ // Get composition area rect from laf
+ TRect compositionAreaFromLaf = iLafMgr->compositionLayoutData();
+ TInt GapValue = compositionAreaFromLaf.iTl.iX;
+
if (range == ERangeNative)
{
if ( layoutType == EAknFepVkbImCnZhuyin )
@@ -1004,13 +1008,17 @@
}
compositionRect.iTl = TPoint(optionRect.iBr.iX, optionRect.iTl.iY);
- compositionRect.SetSize(TSize(btnWidth * 3 + iCellAidGap, candidateHeight));
+ compositionRect.SetSize(TSize(btnWidth * 3 + iCellAidGap - GapValue,
+ candidateHeight));
}
- else
- {
- compositionRect.iTl = Rect().iTl;
- compositionRect.SetSize(TSize(btnWidth * 3 + iCellAidGap, candidateHeight));
- }
+ else
+ {
+ compositionRect.iTl = Rect().iTl;
+ // move the composition area rect with gap
+ compositionRect.iTl.iX += GapValue;
+ compositionRect.SetSize(
+ TSize( btnWidth * 3 + iCellAidGap - GapValue * 2, candidateHeight ));
+ }
iCompositionField->SetReady(ETrue);
iCompositionField->Hide(EFalse);
iCompositionField->SizeChanged(compositionRect);
@@ -1049,6 +1057,8 @@
}
else
{
+ // move the gap
+ compositionRect.iTl.iX -= GapValue;
iVkbBoardLeftTop = TPoint(compositionRect.iTl.iX, compositionRect.iBr.iY);
}
}
@@ -1070,19 +1080,22 @@
vkbCtrl->SetTextFormat( iLafMgr->KeyTextLayout() ); //Read laf
TInt tempHeightForFSQ = btnHeight;
- if (UiLayout()->PenInputType() == EPluginInputModeFSQ )
- {
- tempHeightForFSQ = btnHeight + 3;
- }
+ // Modify begin
+ //if (UiLayout()->PenInputType() == EPluginInputModeFSQ )
+ // {
+ // tempHeightForFSQ = btnHeight + 3;
+ // }
TPoint rangeBarRefPoint = TPoint(vkbRect.iTl.iX, vkbRect.iBr.iY);
- rangeBarRefPoint.iY += yAxisOffset;
+ // Modify begin
+ //rangeBarRefPoint.iY += yAxisOffset;
if (range != ERangeNative)
{
TRect shiftRect;
shiftRect.iTl = TPoint(Rect().iTl.iX, vkbRect.iBr.iY);
- shiftRect.iTl.iY += yAxisOffset;
+ // Modify begin
+ //shiftRect.iTl.iY += yAxisOffset;
shiftRect.SetSize(TSize(btnWidth, tempHeightForFSQ));
AknPenImageUtils::CalculateGraphicRect( shiftRect, innerRect );
ControlById( EAknFepVkbCtrlIdShiftBtn)->SetReady(ETrue);
--- a/textinput/peninputvkbcn/inc/peninputvkbcnlafdatamgr.h Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputvkbcn/inc/peninputvkbcnlafdatamgr.h Fri Sep 17 17:26:50 2010 +0100
@@ -171,6 +171,11 @@
* LAF data for tooltip box
*/
TPeninputCnTooltipBoxLayoutData iTooltipBox;
+
+ /*
+ * LAF data for composition area
+ */
+ TRect iCompositionRect;
};
class MPeninputCnLafDataBase
@@ -198,6 +203,14 @@
const CPeninputCnQwtLayoutDataInfo& QwtLayoutData() const;
/*
+ * Get layout rect for composition area
+ *
+ * @param none
+ * @return rect of composition area
+ */
+ const TRect& compositionLayoutData() const;
+
+ /*
* Return layout data for candidate list;
*
* @return The layout data for candidate list
@@ -432,6 +445,15 @@
* @return The layout data for tooltip box
*/
const TPeninputCnTooltipBoxLayoutData& TooltipBoxLayoutData() const;
+
+ /*
+ * Get layout rect for composition area
+ *
+ * @param none
+ * @return rect of composition area
+ */
+ const TRect& compositionLayoutData() const;
+
protected:
/**
--- a/textinput/peninputvkbcn/src/peninputvkbcnlafdatamgr.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/peninputvkbcn/src/peninputvkbcnlafdatamgr.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -235,6 +235,17 @@
}
// ---------------------------------------------------------------------------
+// CPeninputCnGenericVkbLafMgr::compositionLayoutData
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const TRect& CPeninputCnGenericVkbLafMgr::compositionLayoutData() const
+ {
+ ASSERT(iLafData);
+ return iLafData->compositionLayoutData();
+ }
+
+// ---------------------------------------------------------------------------
// CPeninputCnGenericVkbLafMgr::ICFRect
// (other items were commented in a header)
// ---------------------------------------------------------------------------
@@ -676,7 +687,18 @@
ASSERT( IsValid() );
return iLayoutDataInfo[iLayoutType]->iKeypad;
}
-
+
+// ---------------------------------------------------------------------------
+// MPeninputCnLafDataCommon::compositionLayoutData()
+// (other items were commented in a header)
+// ---------------------------------------------------------------------------
+//
+const TRect& MPeninputCnLafDataCommon::compositionLayoutData() const
+ {
+ ASSERT( IsValid());
+ return iLayoutDataInfo[iLayoutType]->iCompositionRect;
+ }
+
// ---------------------------------------------------------------------------
// CPeninputLafDataCommon::RangbarLayoutData(TInt aRangbarID)
// (other items were commented in a header)
@@ -855,6 +877,13 @@
aDataInfo.iRightButton.iInnerRect = cellBtnRect.Rect();
}
+ // Read composition area laf data
+ TAknWindowLineLayout compositionWindowLineLayout =
+ AknLayoutScalable_Avkon::vkb2_top_candi_pane(0).LayoutLine();
+ TAknLayoutRect compositionLayoutRect;
+ compositionLayoutRect.LayoutRect( toppaneRect.Rect(), compositionWindowLineLayout );
+ aDataInfo.iCompositionRect = compositionLayoutRect.Rect();
+
// bottom pane
const TInt VKBParamBottom2Range[] = { 6, 8, 8 };
const TInt FSQParamBottom2Range[] = { 0, 2, 4 };
--- a/textinput/ptienginev2/inc/PtiEngineImpl.h Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/ptienginev2/inc/PtiEngineImpl.h Fri Sep 17 17:26:50 2010 +0100
@@ -233,6 +233,9 @@
void SearchKeySequenceInSecLang(TPtrC aIn, TDes8& aOut);
#endif // FF_DUAL_LANGUAGE_SUPPORT
TBool IsCurrentCoreSupportCaseInfo();
+ void IsGroupUnicodeExist(TPtiKey aKey, TDes& aResult, TInt aPosition);
+ TBool MapAgainst(TInt aKey, TInt aMode, TInt16 aAgainst, TInt aCase);
+ TInt ScanCodeForCharacter( TUint aChar, TPtiTextCase& aCase );
private:
/*
* Pointer to PtiEngine front end.
--- a/textinput/ptienginev2/src/PtiEngineImpl.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/ptienginev2/src/PtiEngineImpl.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -131,6 +131,12 @@
const TInt16 KStrokeQuestionValue = 0x003f;
const TInt16 KStrokeUnicode = 0x2461;
const TInt16 KZhuyinIndicator = 0x2462;
+const TText KZhuyinTone2 = 0x02CA; // qwerty key6
+const TText KZhuyinTone3 = 0x02C7; // qwerty key3
+const TText KZhuyinTone4 = 0x02CB; // qwerty key4
+const TText KZhuyinTone5 = 0x02D9; // qwerty key7
+static const TUint KShortCombine = 0xF010;
+const TInt KMaxMapping = 10;
// Local method declarations.
LOCAL_C TInt RemapVietnameseAccentedCharacter(TUint16 aChr);
@@ -763,6 +769,29 @@
return KErrNoSuitableCore;
}
+// ---------------------------------------------------------------------------
+// Group Unicode is that kind of mapping which one visible character with more
+// than one unicode submitted.
+//
+// ---------------------------------------------------------------------------
+//
+void CPtiEngineImpl::IsGroupUnicodeExist(TPtiKey aKey, TDes& aResult, TInt aPosition)
+ {
+ TBuf<5> keyMappings;
+ MappingDataForKey( (TPtiKey)aKey, keyMappings, Case());
+ if(keyMappings.Length() > 0 && keyMappings.Locate(KShortCombine) == aPosition )
+ {
+ for(TInt i = 0; i < keyMappings.Length(); i++)
+ {
+ aResult.Append(keyMappings[i]);
+ }
+ }
+ else
+ {
+ aResult.Append(aKey);
+ }
+ }
+
// ---------------------------------------------------------------------------
// CPtiEngineImpl::AppendKeyPress
@@ -849,7 +878,24 @@
}
// Forward to core object
- Core()->AppendKeyPress(aKey);
+ TBuf<KMaxMapping> mappings;
+ IsGroupUnicodeExist(aKey, mappings, 0);
+ if(mappings.Length() == 1)
+ {
+ Core()->AppendKeyPress(aKey);
+ }
+ else
+ {
+ for(TInt i = 0; i < mappings.Length(); i++)
+ {
+ TPtiTextCase retCase, oriCase;
+ retCase = oriCase = Case();
+ TPtiKey key = (TPtiKey)ScanCodeForCharacter(mappings[i], retCase);
+ SetCase(retCase);
+ Core()->AppendKeyPress(key);
+ SetCase(oriCase);
+ }
+ }
if(KeyboardType() == EPtiKeyboardHalfQwerty && aKey == EStdKeyFullStop)
{
@@ -987,6 +1033,60 @@
return iTextBuffer;
}
+TBool CPtiEngineImpl::MapAgainst(TInt aKey, TInt aMode, TInt16 aAgainst, TInt aCase)
+ {
+ SetInputMode((TPtiEngineInputMode)aMode);
+ TBuf<KMaxName> data;
+ MappingDataForKey((TPtiKey)aKey, data, (TPtiTextCase)aCase);
+ if(data.Length() > 0)
+ {
+ return (data[0] == aAgainst);
+ }
+ return EFalse;
+ }
+TInt CPtiEngineImpl::ScanCodeForCharacter( TUint aChar, TPtiTextCase& aCase )
+ {
+#ifdef RD_INTELLIGENT_TEXT_INPUT
+ CPtiCoreLanguage *lang = static_cast<CPtiCoreLanguage*>( CurrentLanguage() );
+ MPtiKeyMappings* keymapping = lang->GetQwertyKeymappings();
+ if ( keymapping )
+ {
+ TPtiEngineInputMode oldInputMode = InputMode();
+ SetInputMode( EPtiEngineQwertyPredictive );
+ TInt retKey = keymapping->KeyForCharacter( (TUint16)aChar );
+ if(MapAgainst(retKey, EPtiEngineQwertyPredictive, aChar, EPtiCaseLower))
+ {
+ aCase = EPtiCaseLower;
+ }
+ else if(MapAgainst(retKey, EPtiEngineQwertyPredictive, aChar, EPtiCaseUpper))
+ {
+ aCase = EPtiCaseUpper;
+ }
+ else if(MapAgainst(retKey, EPtiEngineQwertyPredictive, aChar, EPtiCaseFnLower))
+ {
+ aCase = EPtiCaseFnLower;
+ }
+ else if(MapAgainst(retKey, EPtiEngineQwertyPredictive, aChar, EPtiCaseFnUpper))
+ {
+ aCase = EPtiCaseFnUpper;
+ }
+ else
+ {
+ }
+ SetInputMode( oldInputMode );
+#if defined(__WINS__)
+ if (retKey == EPtiKeyQwertyPlus)
+ {
+ retKey = EStdKeyNkpPlus;
+ }
+#endif
+ return retKey;
+ }
+ return EPtiKeyNone;
+#else
+ return EPtiKeyNone;
+#endif // RD_INTELLIGENT_TEXT_INPUT
+ }
// ---------------------------------------------------------------------------
// CPtiEngineImpl::DeleteKeyPress
@@ -1056,7 +1156,9 @@
TPtrC CPtiEngineImpl::RedirectKeyForChineseQwerty(TPtiKey aKey, TBool& aRedirected)
{
aRedirected = EFalse;
- TPtiKeyboardType kbdType = KeyboardType();
+ TPtiKeyboardType kbdType = KeyboardType();
+ TBuf<KMaxName> data;
+ TInt key;
switch (iInputMode)
{
@@ -1112,47 +1214,48 @@
if(EPtiKeyboardQwerty4x10 == keyboardType ||
EPtiKeyboardQwerty3x11 == keyboardType )
{
- TBuf<KMaxName> lowerdata;
TInt StrokeUnicodePosition =0;
- MappingDataForKey((TPtiKey)aKey, lowerdata, EPtiCaseLower);
- if(lowerdata.Length()>0)
+ MappingDataForKey((TPtiKey)aKey, data, EPtiCaseLower);
+ if(data.Length()>0)
{
- for(TInt i=0;i<lowerdata.Length();i++)
+ for(TInt i=0;i<data.Length();i++)
{
- if(lowerdata[i]==KStrokeUnicode)
+ if(data[i]==KStrokeUnicode)
{
StrokeUnicodePosition = i + 1;
break;
}
+ if(data[0] == KZhuyinTone2 ||
+ data[0] == KZhuyinTone3 ||
+ data[0] == KZhuyinTone4 ||
+ data[0] == KZhuyinTone5 )
+ {
+ return TPtrC();
+ }
}
}
- if (lowerdata.Length() > StrokeUnicodePosition && iCase
+ if (data.Length() > StrokeUnicodePosition && iCase
== EPtiCaseLower)
{
- if (lowerdata[StrokeUnicodePosition]
+ if (data[StrokeUnicodePosition]
== KStrokeHorizontalValue
- || lowerdata[StrokeUnicodePosition]
+ || data[StrokeUnicodePosition]
== KStrokeVerticalValue
- || lowerdata[StrokeUnicodePosition]
+ || data[StrokeUnicodePosition]
== KStrokeDownToLeftValue
- || lowerdata[StrokeUnicodePosition]
+ || data[StrokeUnicodePosition]
== KStrokeDownToRightValue
- || lowerdata[StrokeUnicodePosition]
+ || data[StrokeUnicodePosition]
== KStrokeBendingValue
- || lowerdata[StrokeUnicodePosition]
+ || data[StrokeUnicodePosition]
== KStrokeQuestionValue)
{
return TPtrC();
}
}
- if (iCase == EPtiCaseLower && (aKey == EPtiKeyQwertySpace
- || aKey == EPtiKeyQwertyChr || aKey
- == EPtiKeyQwertyApostrophe))
- {
- return TPtrC();
- }
- if(iCase == EPtiCaseLower && aKey == EPtiKeyQwertySpace)
+
+ if(iCase == EPtiCaseLower && (aKey == EPtiKeyQwertySpace || aKey == EPtiKeyQwertyZ))
{
return TPtrC();
}
@@ -1219,8 +1322,14 @@
case EPtiEngineNormalCangjieQwerty:
case EPtiEngineEasyCangjieQwerty:
case EPtiEngineAdvCangjieQwerty:
+ MappingDataForKey((TPtiKey)aKey, data, EPtiCaseUpper);
+ key = aKey;
+ if(data.Length() > 0)
+ {
+ key = (TPtiKey)data[0];
+ }
if ((iCase == EPtiCaseLower) &&
- (aKey >= EPtiKeyQwertyA) && (aKey <= EPtiKeyQwertyY))
+ (key >= EPtiKeyQwertyA) && (key <= EPtiKeyQwertyY))
{
return TPtrC();
}
@@ -1247,19 +1356,18 @@
else if(EPtiKeyboardQwerty4x10 == kbdType ||
EPtiKeyboardQwerty3x11 == kbdType )
{
- TBuf<KMaxName> lowerdata;
- TInt i;
- MappingDataForKey((TPtiKey) aKey, lowerdata, EPtiCaseLower);
- if (lowerdata.Length() > 0)
+ MappingDataForKey((TPtiKey) aKey, data, EPtiCaseLower);
+ if (data.Length() > 0)
{
- for ( i = 0; i < lowerdata.Length(); i++)
+ TInt i;
+ for ( i = 0; i < data.Length(); i++)
{
- if (lowerdata[i] == KZhuyinIndicator)
+ if (data[i] == KZhuyinIndicator)
{
break;
}
}
- if(i!=lowerdata.Length() && iCase == EPtiCaseLower )
+ if(i!=data.Length() && iCase == EPtiCaseLower )
{
return TPtrC();
}
@@ -3223,6 +3331,7 @@
CPtiQwertyKeyMappings* maps = static_cast<CPtiQwertyKeyMappings*>(iCurrentLanguage->GetQwertyKeymappings());
if( maps != NULL )
{
+ maps->SetKeyboardType(KeyboardType());
maps->GetDataForKey(aKey, aResult, aCase);
}
}
--- a/textinput/ptienginev2/src/PtiKeyMapData.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/ptienginev2/src/PtiKeyMapData.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -43,7 +43,7 @@
implArray->Close();
}
-const TInt KNumItemsPerDeadKeyDataRow = 6;
+
//
// CPtiKeyMapData
@@ -211,10 +211,10 @@
{
if (data[0] == index)
{
- data++;
- return TPtrC(data, KNumItemsPerDeadKeyDataRow - 1);
+ data += 2;
+ return TPtrC(data, *(data - 1));
}
- data += KNumItemsPerDeadKeyDataRow;
+ data += (data[1] + 2);
}
}
--- a/textinput/ptienginev2/src/PtiKeyMappings.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/ptienginev2/src/PtiKeyMappings.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -19,6 +19,7 @@
#include "PtiKeyMappings.h"
#include <PtiKeyMapData.h>
+
// CONSTANTS
#ifdef _DEBUG
_LIT(KPtiNoKeyMapDataPanic, "PtiEngine: No ITU-T keymap data set.");
--- a/textinput/ptienginev2/src/Ptiqwertykeymappings.cpp Thu Sep 02 15:52:50 2010 +0100
+++ b/textinput/ptienginev2/src/Ptiqwertykeymappings.cpp Fri Sep 17 17:26:50 2010 +0100
@@ -80,6 +80,7 @@
{
EPtiKeyQwertyS, EPtiKeyQwertyF, EPtiKeyQwertyR, EPtiKeyQwertyX, EPtiKeyQwertyJ
};
+const TUint16 KShortCombine = 0xF010;
//
@@ -540,6 +541,23 @@
//
TUint16 CPtiQwertyKeyMappings::GetCharForMode(TPtiEngineInputMode aMode, TPtrC aChars, TBool aSkipFirst)
{
+ if( DoesModeCharMatchToInputMode(KPtiPinyinMarker, aMode) ||
+ DoesModeCharMatchToInputMode(KPtiStrokeMarker, aMode) ||
+ DoesModeCharMatchToInputMode(KPtiZhuyinMarker, aMode) ||
+ DoesModeCharMatchToInputMode(KPtiCangjieMarker, aMode))
+ {
+ for (TInt i = 0; i < aChars.Length(); i++)
+ {
+ if (DoesModeCharMatchToInputMode(aChars[i], aMode))
+ {
+ if (i + 1 >= aChars.Length())
+ {
+ return 0;
+ }
+ return aChars[i + 1];
+ }
+ }
+ }
for (TInt i = 0; i < aChars.Length(); i++)
{
if (!IsModeControlChar(aChars[i]))
@@ -549,15 +567,14 @@
iCurrentChar++;
continue;
}
+ if(aChars[i] != KShortCombine)
+ {
return aChars[i];
}
- if (DoesModeCharMatchToInputMode(aChars[i], aMode))
- {
- if (i + 1 >= aChars.Length())
+ else
{
return 0;
}
- return aChars[i + 1];
}
i++; // Wrong mode, skip char
}
@@ -604,7 +621,13 @@
if (key != EPtiKeyNone)
{
TPtrC keyData = DataForKeyLocal(key, textCase, EPtiEngineQwerty);
- if (keyData.Locate(aChar) != KErrNotFound)
+ TInt indexOfSpecialMark = keyData.Locate(KShortCombine);
+ TInt indexOfChar = keyData.Locate(aChar);
+ if (indexOfSpecialMark != KErrNotFound && indexOfChar != KErrNotFound && indexOfChar > indexOfSpecialMark)
+ {
+ continue;
+ }
+ else if ( indexOfChar != KErrNotFound)
{
return key;
}