uifw/EikStd/coctlsrc/EikCcpu.cpp
branchRCL_3
changeset 4 8ca85d2f0db7
parent 0 2f259fa3e83a
child 10 9f56a4e1b8ab
--- a/uifw/EikStd/coctlsrc/EikCcpu.cpp	Tue Feb 02 01:00:49 2010 +0200
+++ b/uifw/EikStd/coctlsrc/EikCcpu.cpp	Fri Feb 19 23:04:46 2010 +0200
@@ -24,7 +24,7 @@
 #include <avkon.rsg>
 #include <avkon.hrh>
 #include <eikappui.h>
-
+#include <eikdialg.h>
 const TInt ELeftSoftkeyIndex = 0;
 const TInt ERightSoftkeyIndex = 2;
 const TInt ENullCommandId = -1;
@@ -48,7 +48,8 @@
 	{
 	if (iMenu)
 		iMenu->RemoveEditMenuObserver(this);
-	delete iCba;
+	//delete iCba;
+	TRAP_IGNORE(DeleteCBAL());
 	iEikonEnv->EikAppUi()->RemoveFromStack(this);
 	}
 
@@ -91,8 +92,9 @@
 	if (iCba && !focused)
 		{
 		// something has caused loss of focus while shift is pressed - drop everything.
-		delete iCba;
-		iCba = NULL;
+		//delete iCba;
+		//iCba = NULL;
+		DeleteCBAL();
 		}
 	}
 
@@ -104,11 +106,54 @@
 	if (aKeyEvent.iCode == EKeyF21)		// FEP generates F21 on long shift press
 		{
 		if (aType == EEventKey)
-			{
-			delete iCba;
-			iCba = NULL;
-			iCba = CEikButtonGroupContainer::NewL(CEikButtonGroupContainer::ECba, CEikButtonGroupContainer::EHorizontal, this, R_AVKON_SOFTKEYS_EMPTY);
-			iCba->SetBoundingRect(iEikonEnv->EikAppUi()->ApplicationRect());
+			{		
+			DeleteCBAL();
+			CEikAppUi* eikAppUi = (CEikAppUi *)CCoeEnv::Static()->AppUi();
+			if( eikAppUi!= NULL && eikAppUi->IsDisplayingDialog() && eikAppUi->TopFocusedControl() )
+				{
+				CEikDialog* dlg = eikAppUi->TopFocusedControl()->MopGetObject( dlg );
+				if ( dlg )
+					{
+					CEikButtonGroupContainer* currentCba = dlg->MopGetObject( currentCba );
+					
+					if ( currentCba )
+						{
+						CEikCba* dlgcba = static_cast<CEikCba*>( currentCba->ButtonGroup() );
+						TUint flags( 0 ); 
+						flags |= CEikButtonGroupContainer::EIsEmbedded | CEikButtonGroupContainer::EAddToStack;
+						iCba = CEikButtonGroupContainer::NewL(CEikButtonGroupContainer::ECba, CEikButtonGroupContainer::EHorizontal, 
+								this, R_AVKON_SOFTKEYS_EMPTY, flags );
+						
+						CEikCba* cba = static_cast<CEikCba*>(
+								iCba->ButtonGroup() );					   
+						
+						if( ! isCbaEmded )
+							{
+							currentCba->AddCommandToStackL(ELeftSoftkeyIndex, -1, _L(""), NULL, NULL);
+							currentCba->AddCommandToStackL(ERightSoftkeyIndex, -1, _L(""), NULL, NULL);
+							currentCba->ActivateL();
+							currentCba->DrawNow();
+							iDialogCba = currentCba;
+							isCbaEmded = ETrue;
+							}
+					
+						cba->SetButtonGroupFlags( ~(EEikCbaFlagTransparent | EEikCbaFlagOutlineFont) );
+						TRect dlgRect(dlg->Rect());
+						TRect cbaRect(currentCba->Rect());
+						iCba->SetRect( currentCba->Rect());
+						iCba->SetPosition(TPoint(dlg->DrawableWindow()->Position().iX,dlg->DrawableWindow()->Position().iY + dlgRect.Height() - cbaRect.Height()));
+						iCba->SetBoundingRect( dlg->Rect());
+						
+						}
+					
+					}
+				
+				}
+			if(iCba == NULL)//if iCba was not create in the above branch but was deleted by DeleteCBA
+				{
+				iCba = CEikButtonGroupContainer::NewL(CEikButtonGroupContainer::ECba, CEikButtonGroupContainer::EHorizontal, this, R_AVKON_SOFTKEYS_EMPTY);
+				iCba->SetBoundingRect(iEikonEnv->EikAppUi()->ApplicationRect());
+				}
 			UpdateCBALabelsL();
 			}
 		return EKeyWasConsumed;
@@ -124,8 +169,9 @@
         }					
 	else if ((aKeyEvent.iScanCode == EStdKeyLeftShift || aKeyEvent.iScanCode == EStdKeyRightShift) && aType == EEventKeyUp)
 		{
-		delete iCba;
-		iCba = NULL;
+		//delete iCba;
+		//iCba = NULL;
+		DeleteCBAL();
 		}
 	
 	return EKeyWasNotConsumed;
@@ -178,7 +224,9 @@
 		change = UpdateCBALabelL(ERightSoftkeyIndex, ENullCommandId, R_TEXT_SOFTKEY_EMPTY) || change;
 
 	if (change)
+		{
 		iCba->DrawNow();
+		}
 	}
 
 TBool CAknCcpuSupport::UpdateCBALabelL(TInt aPosition, TInt aCommandId, TInt aTextResId)
@@ -206,5 +254,37 @@
     {
     return NULL;
     }
+void CAknCcpuSupport::DeleteCBAL()
+	{
+	if ( iCba != NULL )
+		{
+	    delete iCba;
+	    iCba = NULL;
+		}
+	if (isCbaEmded)
+		{
+		CEikAppUi* eikAppUi = (CEikAppUi *)CCoeEnv::Static()->AppUi();
+		    if( eikAppUi!= NULL && eikAppUi->IsDisplayingDialog() && eikAppUi->TopFocusedControl() )
+		        {
+		        CEikDialog* dlg = eikAppUi->TopFocusedControl()->MopGetObject( dlg );
+		        if ( dlg )
+		        	{
+		            CEikButtonGroupContainer* currentCba = dlg->MopGetObject( currentCba );
+	        	    CEikCba* dlgcba = static_cast<CEikCba*>(
+	        	        currentCba->ButtonGroup() );
+	        	    if ( currentCba && iDialogCba == currentCba )
+		        	    {
+		        	    currentCba->RemoveCommandFromStack(ELeftSoftkeyIndex,-1);
+		        	    currentCba->RemoveCommandFromStack(ERightSoftkeyIndex,-1);
 
+		        	    //dlgcba->UpdateCbaLabels(EFalse);
+		        	    currentCba->DrawNow();
+		        	    currentCba->ActivateL();
+		        	    iDialogCba = NULL;
+                        isCbaEmded = EFalse;
+		        	    }
+		        	}
+		        }
+		}
 
+	}