fep/aknfep/peninputplugins/peninputimeplugincn/src/peninputimeplugincn.cpp
changeset 40 2cb9bae34d17
parent 31 f1bdd6b078d1
child 49 37f5d84451bd
--- a/fep/aknfep/peninputplugins/peninputimeplugincn/src/peninputimeplugincn.cpp	Tue Jul 06 14:38:41 2010 +0300
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,630 +0,0 @@
-/*
-* Copyright (c) 2002-2005 Nokia Corporation and/or its subsidiary(-ies). 
-* All rights reserved.
-* This component and the accompanying materials are made available
-* under the terms of "Eclipse Public License v1.0""
-* which accompanies this distribution, and is available
-* at the URL "http://www.eclipse.org/legal/epl-v10.html".
-*
-* Initial Contributors:
-* Nokia Corporation - initial contribution.
-*
-* Contributors:
-*
-* Description:            Input mode plugin implementation file
-*
-*/
-
-
-
-
-
-
-
-
-
-
-
-
-// System includes
-#include <ecom.h>
-#include <AknFepManagerInterface.h>
-#include <eikmenup.h>
-#include <avkon.hrh>
-#include <aknfepuiinterface.h>
-#include <aknfepuimenus.h>
-#include <bldvariant.hrh>
-#include <featmgr.h>
-
-// User includes
-#include "peninputimeplugincn.h"
-#include "peninputimeplugincndebug.h"
-#include "pluginfepmanagerhwr.h"
-#include "pluginfepmanagervkb.h"
-#include "aknfepuiinterface.h"
-
-
-
-const TInt KInvalidImplId = 0;
-
-_LIT(KFscImeName, "Chinese FSC");
-_LIT(KHwrImeName, "Chinese HWR");
-_LIT(KVkbImeName, "Chinese VKB");
-_LIT(KFsqImeName, "Chinese FSQ");
-_LIT(KFingerHwrImeName, "Chinese Fingerhwr");
-
-//lint -esym( 960, 58, * ) lint notes: break used outside of a switch
-
-// Implementation of Class CPenInputImePluginCn 
-
-// -----------------------------------------------------------------------------
-// RImplInfoPtrArray cleanup function
-// -----------------------------------------------------------------------------
-//
-void Cleanup( TAny* aAny )
-    {
-    RImplInfoPtrArray* implArray = 
-        reinterpret_cast< RImplInfoPtrArray*> ( aAny );
-    implArray->ResetAndDestroy();
-    implArray->Close();
-    }
-
-// ======== MEMBER FUNCTIONS ========
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::NewL
-// factory function
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-CPenInputImePluginCn* CPenInputImePluginCn::NewL(TAny* aInitParams)
-    {
-    CPenInputImePluginCn* self = new(ELeave)CPenInputImePluginCn(
-                                        static_cast<RPeninputServer*>(aInitParams));
-    CleanupStack::PushL(self);
-    self->ConstructL(); 
-    CleanupStack::Pop(self);
-    return self;
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::NewLC
-// factory function
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-CPenInputImePluginCn* CPenInputImePluginCn::NewLC(TAny* aInitParams)
-    {
-    CPenInputImePluginCn* self = new(ELeave) CPenInputImePluginCn(
-                                        static_cast<RPeninputServer*>(aInitParams));
-    CleanupStack::PushL(self);
-    self->ConstructL(); 
-    return self;
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::~CPenInputImePluginCn
-// destructor
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-CPenInputImePluginCn::~CPenInputImePluginCn()
-    {
-    DeActivate();
-    iUiLayoutImpIdList.Close();
-    delete iPluginUiManager;
-    REComSession::FinalClose();//cleanup ecom
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::GetInputMethodUiL
-// Create layout UI interface
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-MAknFepManagerInterface* CPenInputImePluginCn::GetInputMethodUiL(
-                                        MAknFepManagerUIInterface* aFepManager,
-                                        TLanguage aLanguage, 
-                                        TInt      aMode,
-                                        const TDesC8& /*aData*/,
-                                        const TBool aIsSplitView)
-    {
-    iFepManager = aFepManager;
-    iLanguage = aLanguage;
-    CPluginFepManagerBase* fepmanager = NULL;
-    
-    TUid layoutId;
-    TInt i;
-
-    switch(aMode)
-        {
-        case EPluginInputModeFSc:
-            {
-            layoutId.iUid = KFScUiId;
-            }
-            break;         
-        case EPluginInputModeHwr:
-            {
-            layoutId.iUid = KHwrUiId;
-            }
-            break; 
-        case EPluginInputModeVkb:
-            {
-            layoutId.iUid = KVkbUiId;
-            }
-            break;
-        case EPluginInputModeFSQ:
-            {
-            layoutId.iUid = KFsqUiId;
-            }
-            break;
-        case EPluginInputModeFingerHwr:
-            {
-            layoutId.iUid = KFingerHwrUiId;
-            }
-            break;            
-        default:
-            return NULL;
-        }
-    fepmanager = GetPluginUiL( aMode );
-    
-    for(i = 0; i < iUiLayoutImpIdList.Count(); ++i)
-        {
-        if(iUiLayoutImpIdList[i] == layoutId.iUid )
-            {
-            break;
-            }
-        }
-
-    if( i < iUiLayoutImpIdList.Count() )
-        {
-        iPenInputMode = aMode;
-        TInt errCode = iPenInputServer->SetUiLayoutId(layoutId);
-        if( errCode == KErrNone )
-            {
-            fepmanager->OnInit();
-            return fepmanager;
-            }
-        }
-        
-    return NULL;
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::GetInputMethodUiL
-// Create layout UI interface
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-MAknFepManagerInterface* CPenInputImePluginCn::GetInputMethodUiL(
-                                    MAknFepManagerUIInterface* aFepManager,
-                                    TInt aLayoutId,
-                                    const TDesC8& /*aData*/)
-    {
-    iFepManager = aFepManager;
-    CPluginFepManagerBase* fepmanager = NULL;   
-    TInt i;
-    TInt mode;    
-    
-    if ( aLayoutId == KHwrUiId )
-        {
-        mode = EPluginInputModeHwr;      
-        }
-    else if( aLayoutId == KVkbUiId )
-        {
-        mode = EPluginInputModeVkb;
-        }
-    else if (aLayoutId == KFScUiId)
-        {
-        mode = EPluginInputModeFSc;
-        }
-    else if( aLayoutId == KFsqUiId )
-        {
-        mode = EPluginInputModeFSQ;
-        }
-    else if( aLayoutId == KFingerHwrUiId )
-        {
-        mode = EPluginInputModeFingerHwr;
-        }
-    else
-        {
-        return NULL;
-        }
-    fepmanager = GetPluginUiL( mode );
-
-    for ( i = 0; i < iUiLayoutImpIdList.Count(); ++i )
-        {
-        if ( iUiLayoutImpIdList[i] == aLayoutId )
-            {
-            break;
-            }
-        }
-
-    if ( i < iUiLayoutImpIdList.Count() )
-        {
-        iPenInputMode = mode;
-        iPenInputServer->SetUiLayoutId(TUid::Uid(aLayoutId));
-        fepmanager->OnInit();    
-        return fepmanager;
-        }
-        
-    return NULL;
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::Activate
-// Activate current IME plugin.
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-void CPenInputImePluginCn::Activate()
-    {
-    if(iPenInputServer)
-        {
-        iPenInputServer->ActivateLayout(ETrue);        
-        }
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::DeActivate
-// Deactivate current IME plugin.
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-void CPenInputImePluginCn::DeActivate()
-    {
-    if (iPenInputServer && iPenInputServer->IsVisible())        
-        {
-        iPenInputServer->ActivateLayout(EFalse);
-        }
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::ImeImplId
-// Get current IME plugin implementation ID.
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-TInt CPenInputImePluginCn::ImeImplId()
-    {
-    return KInputMethodImplementationId;
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::LayoutUiImplId
-// Get current layout UI implementation id.
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-TInt CPenInputImePluginCn::LayoutUiImplId()
-    {
-    TInt id;
-    switch ( iPenInputMode )
-        {
-        case EPluginInputModeHwr:
-            {
-            id = KHwrUiId;
-            }
-            break;
-        case EPluginInputModeVkb:
-            {
-            id = KVkbUiId;
-            }
-            break;
-        case EPluginInputModeFSc:
-            {
-            id = KFScUiId;
-            }
-            break; 
-        case EPluginInputModeFSQ:
-            {
-            id = KFsqUiId;
-            }
-            break;
-        case EPluginInputModeFingerHwr:
-            {
-            id = KFingerHwrUiId;
-            }
-            break; 
-        default:
-            {
-            id = KInvalidImplId;
-            }
-            break;
-        }
-    return id;
-    }
-
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::SupportModes
-// Get suppored layout UI modes(VKB/HWR).
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-TInt CPenInputImePluginCn::SupportModes(CPtiEngine* aPtiEngine,
-                                             RArray<TImePlguinImplDetail>& aSupportList) const
-    {
-    TInt ret = 0;
-    TRAP_IGNORE( ret = SupportModesL( aPtiEngine, aSupportList ) );
-    return ret;
-    }
-    
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::SupportModesL
-// Get suppored layout UI modes(VKB/HWR).
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-TInt CPenInputImePluginCn::SupportModesL(CPtiEngine* /*aPtiEngine*/,
-                                             RArray<TImePlguinImplDetail>& aSupportList) const 
-    {
-    RImplInfoPtrArray infoArray;
-    TUid id;
-    id.iUid = KHwrLayoutInterfaceId;
-    TBool hwr = EFalse;
-    TBool vkb = EFalse;
-    TBool fsc = EFalse;
-    TBool fsq = EFalse;
-    TBool fingerhwr = EFalse;
-    
-    CleanupStack::PushL( TCleanupItem( Cleanup, &infoArray ) );
-    REComSession::ListImplementationsL(id, infoArray);
-        
-    for (TInt i = 0; i < infoArray.Count(); ++i)
-        {
-        if(infoArray[i]->ImplementationUid().iUid == KHwrUiId )
-            {
-            hwr = ETrue;
-            }
-
-        if (infoArray[i]->ImplementationUid().iUid == KVkbUiId
-                && FeatureManager::FeatureSupported(KFeatureIdVirtualKeyboardInput))
-            {
-            vkb = ETrue;
-            }
-        if(infoArray[i]->ImplementationUid().iUid == KFScUiId )
-            {
-            fsc = ETrue;
-            }          
-        if (infoArray[i]->ImplementationUid().iUid == KFsqUiId
-                && FeatureManager::FeatureSupported(KFeatureIdVirtualFullscrQwertyInput))
-            {
-            fsq = ETrue;
-            }
-        if (infoArray[i]->ImplementationUid().iUid == KFingerHwrUiId )
-            {
-            fingerhwr = ETrue;
-            }  
-        }
-    
-    TImePlguinImplDetail detail;
-    
-    detail.iImplementationId = KInputMethodImplementationId;
-    if( fsc )
-        {
-        detail.iMode = EPluginInputModeFSc;
-        detail.iMeritValue = EImeMerit_Preferred;
-        detail.iDisplayName.Copy(KFscImeName());
-        detail.iLanguage = ELangTaiwanChinese;
-        aSupportList.Append(detail);
-        detail.iLanguage = ELangHongKongChinese;
-        aSupportList.Append(detail);
-        detail.iLanguage = ELangPrcChinese;
-        aSupportList.Append(detail);
-        //detail.iLanguage = ELangEnglish;
-        //detail.iMeritValue = EImeMerit_NotUsed;
-        //aSupportList.Append(detail);
-        }
-    if( hwr )
-        {
-        detail.iMode = EPluginInputModeHwr;
-        detail.iMeritValue = EImeMerit_Preferred;
-        detail.iDisplayName.Copy(KHwrImeName());
-        detail.iLanguage = ELangTaiwanChinese;
-        aSupportList.Append(detail);
-        detail.iLanguage = ELangHongKongChinese;
-        aSupportList.Append(detail);
-        detail.iLanguage = ELangPrcChinese;
-        aSupportList.Append(detail);
-        //detail.iLanguage = ELangEnglish;
-        //detail.iMeritValue = EImeMerit_NotUsed;
-        //aSupportList.Append(detail);
-        }
-
-    if( vkb )
-        {
-        detail.iMode = EPluginInputModeVkb;
-        detail.iMeritValue = EImeMerit_Preferred;
-        detail.iDisplayName.Copy(KVkbImeName());
-        detail.iLanguage = ELangTaiwanChinese;
-        aSupportList.Append(detail);
-        detail.iLanguage = ELangHongKongChinese;
-        aSupportList.Append(detail);
-        detail.iLanguage = ELangPrcChinese;
-        aSupportList.Append(detail);
-        //detail.iLanguage = ELangEnglish;
-        //detail.iMeritValue = EImeMerit_NotUsed;
-        //aSupportList.Append(detail);
-        }
-        
-    if( fsq )
-        {
-        detail.iMode = EPluginInputModeFSQ;
-        detail.iMeritValue = EImeMerit_Preferred;
-        detail.iDisplayName.Copy(KFsqImeName());
-        detail.iLanguage = ELangTaiwanChinese;
-        aSupportList.Append(detail);
-        detail.iLanguage = ELangHongKongChinese;
-        aSupportList.Append(detail);
-        detail.iLanguage = ELangPrcChinese;
-        aSupportList.Append(detail);
-        //detail.iLanguage = ELangEnglish;
-        //detail.iMeritValue = EImeMerit_NotUsed;
-        //aSupportList.Append(detail);
-        }
-    if( fingerhwr )
-        {
-        detail.iMode = EPluginInputModeFingerHwr;
-        detail.iMeritValue = EImeMerit_Preferred;
-        detail.iDisplayName.Copy(KFingerHwrImeName());
-        detail.iLanguage = ELangTaiwanChinese;
-        aSupportList.Append(detail);
-        detail.iLanguage = ELangHongKongChinese;
-        aSupportList.Append(detail);
-        detail.iLanguage = ELangPrcChinese;
-        aSupportList.Append(detail);
-        }
-        
-    CleanupStack::PopAndDestroy(&infoArray); // infoArray    
-    
-    return 0;
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::CurrentMode
-// Get current layout UI mode.
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-TInt CPenInputImePluginCn::CurrentMode() const
-    {
-    return iPenInputMode;
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::HandleServerEventL
-// Handle pen input server event..
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-TBool CPenInputImePluginCn::HandleServerEventL(TInt aEventId, const TDesC& aData)
-    {
-    TBool bHandled = EFalse;
-    switch( aEventId )
-        {
-        case ESignalLayoutICFLengthChanged:
-            {
-            GetCurrentUi()->RetrieveEditorMaxLength();
-            }
-            break;
-        case ESignalCaseMode:
-            {
-            GetCurrentUi()->UpdateCaseMode(*(TInt*)(aData.Ptr())); //lint !e728
-            }
-            break;
-        default:
-            break;
-        }
-        
-    return bHandled;
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::HandleMenuCommandL
-// Handle the menu command.
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-TBool CPenInputImePluginCn::HandleMenuCommandL(TInt /*aCommandId*/)
-    {
-    return EFalse;
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::DynInitMenuPaneL
-// Dynamiclly update menu items during it displays.
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-void CPenInputImePluginCn::DynInitMenuPaneL(CAknFepUiInterfaceMenuPane* aMenuPane)
-    {
-    TInt index;
-    
-    if ((iPenInputMode == EPluginInputModeVkb ||
-        iPenInputMode == EPluginInputModeFSQ) &&
-        aMenuPane->MenuItemExists(EPenInputCmdSetting, index))
-        {
-        aMenuPane->SetItemDimmed(EPenInputCmdSetting, EFalse);   
-        }
-    aMenuPane->SetItemDimmed(EPenInputCmdHwrTraining, ETrue);			
-    }
-
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::CPenInputImePluginCn
-// C++ default constructor.
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-CPenInputImePluginCn::CPenInputImePluginCn(RPeninputServer* aHwrServer)
-:iPenInputServer(aHwrServer) 
-    {
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::ConstructL
-// 2nd phase constructor.
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-void CPenInputImePluginCn::ConstructL()
-    {
-    FindUiLayoutImplementationL();
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::FindUiLayoutImplementationL
-// Enumuate all layout UI ids.
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-void CPenInputImePluginCn::FindUiLayoutImplementationL()
-    {
-    RImplInfoPtrArray infoArray;
-    TUid id;
-    id.iUid = KHwrLayoutInterfaceId;
-
-    iUiLayoutImpIdList.Reset();
-    CleanupStack::PushL( TCleanupItem( Cleanup, &infoArray ) );
-    REComSession::ListImplementationsL(id, infoArray);
-        
-    for (TInt i = 0; i < infoArray.Count(); ++i)
-        {
-        iUiLayoutImpIdList.AppendL(infoArray[i]->ImplementationUid().iUid);
-        }
-
-    CleanupStack::PopAndDestroy(&infoArray); // infoArray    
-    }
-
-// -----------------------------------------------------------------------------
-// CPenInputImePluginCn::GetPluginUiL
-// Get HWR UI interface.
-// (other items were commented in a header).
-// -----------------------------------------------------------------------------
-//
-CPluginFepManagerBase* CPenInputImePluginCn::GetPluginUiL( TInt aMode )
-    {
-    delete iPluginUiManager;
-    iPluginUiManager = NULL;
-    
-    switch ( aMode )
-        {
-        case EPluginInputModeFingerHwr:
-        case EPluginInputModeFSc:
-        case EPluginInputModeHwr:
-            {
-            return iPluginUiManager = CPluginFepManagerHwr::NewL(*this, iPenInputServer);
-            }
-        case EPluginInputModeVkb:
-        case EPluginInputModeFSQ:
-            {
-            return iPluginUiManager = CPluginFepManagerVkb::NewL(*this, iPenInputServer);
-            }
-        default:
-            {
-            return NULL;
-            }
-        }
-    }
-//End Of File