idlefw/plugins/devicestatus/src/aioperatorlogopublisher.cpp
changeset 0 79c6a41cd166
child 8 d0529222e3f0
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/idlefw/plugins/devicestatus/src/aioperatorlogopublisher.cpp	Thu Dec 17 08:54:17 2009 +0200
@@ -0,0 +1,571 @@
+/*
+* Copyright (c) 2005-2006 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:  Operator logo publisher.
+*
+*/
+
+
+#include <RPhCltServer.h>
+
+#include <CPhCltImageHandler.h>
+#include <CPhCltBaseImageParams.h>
+
+#include <PhoneClientServerDomainPStypes.h>
+#include <fbs.h>
+#include <e32cmn.h>
+#include <gulicon.h>
+#include <centralrepository.h>
+#include <cenrepnotifyhandler.h>
+#include <settingsinternalcrkeys.h>
+#include <PhoneClientServerDomainPSkeys.h>
+#include <aknlayoutscalable_avkon.cdl.h>
+#include <AknLayout2ScalableDef.h>
+#include <bitdev.h>
+#include <AknStatuspaneUtils.h>
+#include <AknUtils.h>
+#include <aipspropertyobserver.h>
+#include "aioperatorlogopublisher.h"
+#include "ainetworkinfolistener.h"
+#include "aidevicestatuscontentmodel.h"
+#include "aiprioritizer.h"
+#include "ainwidpriorities.h"
+#include "debug.h"
+
+// Operator Logo showing state is OFF.
+const TInt KAIDisplayOperatorLogoOff = 0;
+
+// Operator Logo showing state is ON.
+const TInt KAIDisplayOperatorLogoOn = 1;
+
+const TInt KAddTwoPixels = 2;
+const TInt KMaskBlitStartOffset = -1;
+const TInt KMaskBlitEndOffset = 2;
+
+
+// ======== MEMBER FUNCTIONS ========
+
+CAiOperatorLogoPublisher::CAiOperatorLogoPublisher()
+: iPriority( EAiInvalidPriority )
+    {
+   
+    }
+
+
+void CAiOperatorLogoPublisher::ConstructL()
+    {
+    __PRINTS("CAiOperatorLogoPublisher:: ConstructL >>");
+    iListener = CAiNetworkInfoListener::InstanceL();
+    
+    iOperatorLogoObserver = AiUtility::CreatePSPropertyObserverL( 
+    	TCallBack( HandleOperatorLogoUpdateL, this ), 
+    	KPSUidPhoneClientServerInformation, KTelOperatorLogoUpdated );
+    
+    iCenRep = CRepository::NewL( KCRUidPersonalizationSettings );
+    
+    iCenRepNotify = CCenRepNotifyHandler::NewL( *this, 
+    											*iCenRep,
+    											CCenRepNotifyHandler::EIntKey, 
+    											KSettingsDisplayOperatorLogo );
+    											
+    iCenRepNotify->StartListeningL();
+    __PRINTS("CAiOperatorLogoPublisher:: ConstructL <<");
+    }
+
+
+CAiOperatorLogoPublisher* CAiOperatorLogoPublisher::NewL()
+    {
+    CAiOperatorLogoPublisher* self = new( ELeave ) CAiOperatorLogoPublisher;
+    CleanupStack::PushL( self );
+    self->ConstructL();
+    CleanupStack::Pop( self );
+    return self;
+    }
+
+
+CAiOperatorLogoPublisher::~CAiOperatorLogoPublisher()
+    {
+    __PRINTS("CAiOperatorLogoPublisher:: ~CAiOperatorLogoPublisher >>");
+    if( iCenRepNotify )
+        {
+        iCenRepNotify->StopListening();
+        }
+    delete iCenRepNotify;
+    delete iCenRep;
+    if( iListener )
+        {
+	    iListener->RemoveObserver( *this );
+        iListener->Release();
+        }
+    delete iIcon;
+    Release( iOperatorLogoObserver );
+    __PRINTS("CAiOperatorLogoPublisher:: ~CAiOperatorLogoPublisher <<");
+    }
+
+
+void CAiOperatorLogoPublisher::ResumeL()
+    {
+    __PRINTS("CAiOperatorLogoPublisher:: ResumeL >>");
+    iListener->AddObserverL( *this );
+    __PRINTS("CAiOperatorLogoPublisher:: ResumeL <<");
+    }
+
+
+void CAiOperatorLogoPublisher::HandleNetworkInfoChange(
+							const MNWMessageObserver::TNWMessages& /*aMessage*/,
+							const TNWInfo& /*aInfo*/,
+							const TBool aShowOpInd )
+    {
+    __PRINT(__DBG_FORMAT("CAiOperatorLogoPublisher:: HandleNetworkInfoChange >> aShowOpInd %d "), aShowOpInd);
+        if( aShowOpInd )
+        	{
+        	TRAP_IGNORE(UpdateOperatorLogoL( ETrue ));
+        	}
+        else
+        	{
+        	TRAP_IGNORE (iPrioritizer->TryToCleanL( *iBroadcaster,
+            							EAiDeviceStatusContentNetworkIdentity,
+            							iPriority ));
+        	}
+        
+    __PRINTS("CAiOperatorLogoPublisher:: HandleNetworkInfoChange <<");
+    }
+
+
+void CAiOperatorLogoPublisher::HandleNotifyInt( TUint32 aId, TInt /*aNewValue*/ )
+	{
+	__PRINT(__DBG_FORMAT("CAiOperatorLogoPublisher:: HandleNotifyInt >> aId %d "), aId);
+    if( aId == KSettingsDisplayOperatorLogo )
+        {
+        TRAP_IGNORE( UpdateOperatorLogoL( ETrue ) );
+        }
+    __PRINTS("CAiOperatorLogoPublisher:: HandleNotifyInt <<");
+	}
+	
+	
+void CAiOperatorLogoPublisher::Subscribe( MAiContentObserver& aObserver, 
+									        MAiPropertyExtension& aExtension,
+                                            MAiPublishPrioritizer& aPrioritizer,
+                                            MAiPublisherBroadcaster& aBroadcaster )
+    {
+    iContentObserver = &aObserver;
+    iExtension = &aExtension;
+    iPrioritizer = &aPrioritizer;
+    iBroadcaster = &aBroadcaster;
+    }
+
+
+void CAiOperatorLogoPublisher::RefreshL( TBool aClean )
+    {
+    __PRINTS("CAiOperatorLogoPublisher:: RefresL >> ");
+    TRAP_IGNORE( UpdateOperatorLogoL( aClean ) );
+    __PRINTS("CAiOperatorLogoPublisher:: RefresL << ");
+    }
+
+
+CFbsBitmap* CAiOperatorLogoPublisher::LoadLogoL( TInt aMCC, 
+                                                 TInt aMNC )
+    {
+    __PRINT(__DBG_FORMAT("CAiOperatorLogoPublisher:: LoadLogo >> aMCC %d, aMNC %d"), aMCC, aMNC);
+    CPhCltImageHandler* imageHandler = CPhCltImageHandler::NewL();       
+    User::LeaveIfNull( imageHandler );
+    
+    CleanupStack::PushL( imageHandler );
+    
+    // Create image parameter class
+    CPhCltImageParams* params = 
+    	imageHandler->CPhCltBaseImageParamsL( EPhCltTypeOperatorLogo );
+    CleanupStack::PushL( params );
+    
+    TInt err = KErrNotFound;
+    iPriority = EAiOTAOperatorLogo;
+    
+    CPhCltExtOperatorLogoParams* opLogoParams = 
+    	static_cast<CPhCltExtOperatorLogoParams*>(params);
+	
+	if( opLogoParams )
+        {
+		opLogoParams->SetCodesL( aMCC, aMNC, EPhCltLogoTypeOTA );
+		err = imageHandler->LoadImages( params );
+		
+		if( err == KErrNotFound )
+       		{
+            // OTA logo wasn't found, try programmable logo
+            opLogoParams->SetCodesL( aMCC, aMNC, EPhCltLogoTypeProgrammable );
+            err = imageHandler->LoadImages( params );
+            iPriority = EAiProgOperatorLogo;
+            }        
+        }
+    else
+        {
+        err = KErrNotFound;
+        }
+    __PRINT(__DBG_FORMAT("CAiOperatorLogoPublisher:: LoadLogo >> err %d"), err);
+	User::LeaveIfError( err );
+	 
+	//take always first image, we can show only one logo
+    TInt bitmapHandle = params->GetImageL( 0 );
+    
+    CFbsBitmap* bitmap = new ( ELeave ) CFbsBitmap;
+    CleanupStack::PushL( bitmap );
+    User::LeaveIfError( bitmap->Duplicate( bitmapHandle ) );
+
+    CleanupStack::Pop( bitmap );
+    
+    CleanupStack::PopAndDestroy( params );
+    CleanupStack::PopAndDestroy( imageHandler );
+    __PRINTS("CAiOperatorLogoPublisher:: LoadLogo << ");
+    return bitmap;
+    }
+
+
+void CAiOperatorLogoPublisher::UpdateOperatorLogoL( TBool aClean )
+    {
+    __PRINT(__DBG_FORMAT("CAiOperatorLogoPublisher:: UpdateOperatorLogoL >> aClean %d"), aClean);
+    iSuccess = EFalse;
+    if( aClean )
+        {
+        iPrioritizer->TryToCleanL( *iBroadcaster,
+        							EAiDeviceStatusContentNetworkIdentity,
+        							iPriority );
+        }
+        
+    if( !AllowToShowLogoL() )
+        {
+        iPrioritizer->TryToCleanL( *iBroadcaster,
+        							EAiDeviceStatusContentNetworkIdentity,
+        							iPriority );
+
+        delete iIcon;
+        iIcon = NULL;
+        __PRINTS("CAiOperatorLogoPublisher:: UpdateOperatorLogoL : not allowed to show logo");
+        return;
+        }
+
+    const TNWInfo& info = iListener->NetworkInfo();
+
+    if ( info.iRegistrationStatus == ENWNotRegisteredNoService ||
+    		info.iRegistrationStatus ==ENWRegistrationUnknown )
+    	{
+    	__PRINTS("CAiOperatorLogoPublisher:: UpdateOperatorLogoL : registrationstatus unknown");
+    	return;
+    	}
+
+    TInt mcc;
+
+    TLex lex( info.iCountryCode );
+    User::LeaveIfError( lex.Val( mcc ) );
+
+    TInt mnc;
+    lex.Assign( info.iNetworkId );
+    User::LeaveIfError( lex.Val( mnc ) );
+
+    CFbsBitmap* opLogo = NULL;
+	CFbsBitmap* opLogoMask = NULL;
+
+    TRAPD( err, opLogo = LoadLogoL( mcc,
+    								mnc ) );
+
+	if( err )
+        {
+        opLogo = NULL;
+        }
+
+	if ( opLogo && opLogo->IsMonochrome() )
+        {
+        __PRINTS("CAiOperatorLogoPublisher:: UpdateOperatorLogoL : monochrome icon");
+        CFbsBitmap* bitmap = opLogo;
+        opLogo = NULL;
+
+        CleanupStack::PushL( bitmap );
+        CreateMonochromeBitmapsL( *bitmap, opLogo, opLogoMask );
+        
+        CleanupStack::PopAndDestroy( bitmap );
+        }
+
+    //clean always, might be that there is old logo published
+    //and now the logo isn't valid anymore. So publish clean
+    //even if we didn't get new logo
+    if( opLogo )
+        {
+        delete iIcon;
+        iIcon = NULL;
+
+        if( opLogoMask )
+        	{
+        	iIcon = CGulIcon::NewL( opLogo, opLogoMask );
+        	}
+        else
+        	{
+        	iIcon = CGulIcon::NewL( opLogo, NULL );
+        	}
+
+        opLogo = NULL;
+        opLogoMask = NULL;
+
+        TPckg<CGulIcon*> pckg( iIcon );
+
+        iPrioritizer->TryToPublishL( *iBroadcaster,
+        							EAiDeviceStatusContentNetworkIdentity,
+        							pckg,
+        							iPriority );
+        __PRINTS("CAiOperatorLogoPublisher:: UpdateOperatorLogoL : logo published ");
+        iSuccess = ETrue;
+        }
+    else
+        {
+        iPrioritizer->TryToCleanL( *iBroadcaster,
+        							EAiDeviceStatusContentNetworkIdentity,
+        							iPriority );
+        __PRINTS("CAiOperatorLogoPublisher:: UpdateOperatorLogoL : logo cleaned ");
+        }
+    __PRINTS("CAiOperatorLogoPublisher:: UpdateOperatorLogoL << ");
+    }
+
+
+TBool CAiOperatorLogoPublisher::AllowToShowLogoL() const
+    {
+    TInt val;
+    iCenRep->Get( KSettingsDisplayOperatorLogo, val );
+    return val && iListener->IsOperatorIndicatorAllowed();
+    }
+
+
+void CAiOperatorLogoPublisher::CreateMonochromeBitmapsL(
+    const CFbsBitmap& aBitmap,
+    CFbsBitmap*& aNewLogoMain,
+    CFbsBitmap*& aNewLogoMask )
+    {
+    
+    __PRINTS("CAiOperatorLogoPublisher:: CreateMonochromeBitmapsL >> ");
+    TSize size = aBitmap.SizeInPixels();
+    const TRgb white = TRgb::Gray2( 1 );
+
+    // New size 2 pixels larger in every dimension.
+    TSize newSize( size.iWidth + KAddTwoPixels, size.iHeight + KAddTwoPixels );
+    TPoint delta( 1, 1 ); // adjust image position.
+
+    TSize opLogoSize;
+    TInt err = GetTitlePaneSize( opLogoSize );
+    if ( err != KErrNone )
+        {
+        return;
+        }
+
+    if ( newSize.iWidth > opLogoSize.iWidth &&
+        size.iWidth <= opLogoSize.iWidth )
+        {
+        newSize.iWidth = size.iWidth;
+        delta.iX = 0;
+        }
+    if ( newSize.iHeight > opLogoSize.iHeight &&
+        size.iHeight <= opLogoSize.iHeight )
+        {
+        newSize.iHeight = size.iHeight;
+        delta.iY = 0;
+        }
+
+    // Create mask image
+    CFbsBitmap* bitmapLargeMain =
+        new (ELeave) CFbsBitmap;
+    CleanupStack::PushL( bitmapLargeMain );
+    User::LeaveIfError(
+        bitmapLargeMain->Create( newSize, EGray2 ) );
+
+    CFbsBitmapDevice* device =
+        CFbsBitmapDevice::NewL( bitmapLargeMain );
+    CleanupStack::PushL( device );
+
+    CFbsBitGc* gc = NULL;
+    User::LeaveIfError( device->CreateContext( gc ) );
+
+    gc->SetPenStyle(CGraphicsContext::ENullPen);
+    gc->SetBrushColor( white );
+    gc->SetBrushStyle(CGraphicsContext::ESolidBrush);
+    gc->Clear();
+
+    gc->BitBlt( TPoint() + delta, &aBitmap );
+
+    delete gc;
+    gc = NULL;
+
+    CleanupStack::PopAndDestroy( device );
+
+    // Create main image
+    CFbsBitmap* bitmapLargeMask =
+        new (ELeave) CFbsBitmap;
+    CleanupStack::PushL( bitmapLargeMask );
+    User::LeaveIfError(
+        bitmapLargeMask->Create( newSize, EGray2 ) );
+
+    CFbsBitmapDevice* deviceMask =
+        CFbsBitmapDevice::NewL( bitmapLargeMask );
+    CleanupStack::PushL( deviceMask );
+
+    User::LeaveIfError( deviceMask->CreateContext( gc ) );
+
+    gc->SetPenStyle(CGraphicsContext::ENullPen);
+    gc->SetBrushColor( white );
+    gc->SetBrushStyle(CGraphicsContext::ESolidBrush);
+    gc->Clear();
+    gc->SetBrushStyle(CGraphicsContext::ENullBrush);
+
+    TPoint point;
+    TRect rect( point, size );
+
+    // Blit with mask 3 points from top left to down right.
+    for ( TInt j = KMaskBlitStartOffset;
+          j < KMaskBlitEndOffset;
+          j++ )
+        {
+        for ( TInt i = KMaskBlitStartOffset;
+              i < KMaskBlitEndOffset;
+              i++ )
+            {
+            point = TPoint( i, j );
+            point += delta;
+            gc->BitBltMasked(
+                point, &aBitmap, rect, &aBitmap, ETrue );
+            }
+        }
+
+    delete gc;
+    gc = NULL;
+
+    CleanupStack::PopAndDestroy( deviceMask );
+
+    CleanupStack::Pop( bitmapLargeMask );
+    CleanupStack::Pop( bitmapLargeMain );
+
+    aNewLogoMain = bitmapLargeMain;
+    aNewLogoMask = bitmapLargeMask;
+    __PRINTS("CAiOperatorLogoPublisher:: CreateMonochromeBitmapsL << ");
+    }
+
+
+TInt CAiOperatorLogoPublisher::GetTitlePaneSize( TSize& aSize )
+    {
+   	TRect titlePaneRect;
+    TBool hasTitlePane = AknLayoutUtils::LayoutMetricsRect( 
+        AknLayoutUtils::ETitlePane, titlePaneRect );
+    
+    if ( !hasTitlePane )
+        {
+        return KErrNotFound;            
+        }
+    
+    TAknLayoutRect oplogoLayout;
+    
+    if ( AknStatuspaneUtils::StaconPaneActive() )
+        {
+        // stacon
+        oplogoLayout.LayoutRect( titlePaneRect, 
+            AknLayoutScalable_Avkon::title_pane_stacon_g2(0).LayoutLine() );    
+        }
+    else if ( AknStatuspaneUtils::FlatLayoutActive() )
+        {
+        // flat
+        oplogoLayout.LayoutRect( titlePaneRect, 
+            AknLayoutScalable_Avkon::title_pane_stacon_g2(0).LayoutLine() );    
+        }   
+    else
+        {
+        // usual idle
+        oplogoLayout.LayoutRect( titlePaneRect, 
+            AknLayout::Title_pane_elements_Line_1() );
+        }             
+     
+    aSize = oplogoLayout.Rect().Size(); 
+    
+    
+    return KErrNone;  
+    }
+
+
+TBool CAiOperatorLogoPublisher::RefreshL( TInt aContentId, TBool aClean )
+	{
+	
+    if(aContentId == EAiDeviceStatusContentNetworkIdentity )
+        {
+        __PRINTS("CAiOperatorLogoPublisher:: RefreshL >> ");
+   	    RefreshL( aClean );
+   	    if( iSuccess )
+   	        {
+   	        __PRINTS("CAiOperatorLogoPublisher:: RefreshL << success ");
+   	        return ETrue;
+   	        }   
+   	    __PRINTS("CAiOperatorLogoPublisher:: RefreshL << failed ");	    
+    	}    	
+    return EFalse;
+	}
+
+
+TInt CAiOperatorLogoPublisher::HandleOperatorLogoUpdateL( TAny *aPtr )
+	{
+	__PRINTS("CAiOperatorLogoPublisher::  HandleOperatorLogoUpdateL >> ");
+	CAiOperatorLogoPublisher* self = static_cast<CAiOperatorLogoPublisher*>( aPtr );
+    
+    TTelOTALogoUpdate logoUpd;
+    TTelOTALogoUpdate::TOTALogoUpdatePckg logoUpdPckg( logoUpd );
+
+    if ( RProperty::Get( 
+    		KPSUidPhoneClientServerInformation, 
+        	KTelOperatorLogoUpdated, 
+        	logoUpdPckg ) == KErrNone )
+    	{
+        __PRINT(__DBG_FORMAT("CAiOperatorLogoPublisher:: HandleOperatorLogoUpdateL >> logoUpd.iEvent %d"), logoUpd.iEvent);
+        if ( logoUpd.iEvent == TTelOTALogoUpdate::EPSTelephonyLogoChanged )
+        	{
+        	if(self)
+        		{
+        		__PRINTS("CAiOperatorLogoPublisher::  HandleOperatorLogoUpdateL: logo changed ");
+        		self->iCenRep->Set( KSettingsDisplayOperatorLogo, KAIDisplayOperatorLogoOn );
+        		self->UpdateOperatorLogoL( ETrue );        			
+        		}
+        	}
+        else if ( logoUpd.iEvent == TTelOTALogoUpdate::EPSTelephonyLogoDeleted ||
+                  logoUpd.iEvent == TTelOTALogoUpdate::EPSTelephonyAllLogosDeleted )
+            {
+            if(self)
+                {  
+                __PRINTS("CAiOperatorLogoPublisher::  HandleOperatorLogoUpdateL: logo deleted ");
+        		self->iCenRep->Set( KSettingsDisplayOperatorLogo, KAIDisplayOperatorLogoOff );
+        		self->UpdateOperatorLogoL( ETrue );        			            
+                }
+            }
+  
+       	}
+    __PRINTS("CAiOperatorLogoPublisher::  HandleOperatorLogoUpdateL << ");
+    return KErrNone;
+	}
+
+
+TBool CAiOperatorLogoPublisher::RefreshContentWithPriorityL( TInt aContentId, 
+                                                                TInt aPriority )
+	{
+	if( aContentId == EAiDeviceStatusContentNetworkIdentity &&
+	    ( aPriority == EAiOTAOperatorLogo || 
+	    aPriority == EAiProgOperatorLogo ) )
+        {
+        __PRINTS("CAiOperatorLogoPublisher::  RefreshContentWithPriorityL >> ");
+	    RefreshL( EFalse );
+	    if( iSuccess )
+	        {
+	        __PRINTS("CAiOperatorLogoPublisher::  RefreshContentWithPriorityL << success");
+	        return ETrue;	        
+	        }
+	    __PRINTS("CAiOperatorLogoPublisher::  RefreshContentWithPriorityL << failed");
+        }
+    return EFalse;
+	}
+