diff -r 000000000000 -r ff3acec5bc43 musichomescreen_multiview/musiccontentpublisher/inc/musiccontentpublisher.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/musichomescreen_multiview/musiccontentpublisher/inc/musiccontentpublisher.h Thu Dec 17 08:45:05 2009 +0200 @@ -0,0 +1,414 @@ +/* +* Copyright (c) 2008-2008 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: Manages MCP plugins, and content publishing. +* +*/ + + +#ifndef C_MUSICCONTENTPUBLISHER_H +#define C_MUSICCONTENTPUBLISHER_H + +#include +#include +#include // For wchar_t +#include +#include + +class MLiwInterface; +class CLiwGenericParamList; +class CPluginManager; +class CFbsBitmap; +class CCoeEnv; +class TAknsItemID; +class CMCPHarvesterPublisherObserver; + + +struct TMCPDestinationItem + { + const TInt id; + const wchar_t* type; + const char* dataKey; + const wchar_t* content; + }; + +struct TMCPImageDestinationInfoItem + { + const TMCPImageDestination id; + const TInt sizex; + const TInt sizey; + }; + + +struct TBmpMsk + { + CFbsBitmap *bitmap; + CFbsBitmap *mask; + }; + +struct TMyBufferItem + { + TAny* buf; + TInt size; + }; + + +const TMCPDestinationItem KMCPDestinationInfo[] = + { + { EMusicWidgetImage1, L"area1_image1", "area1_image1_data", L"*" } + ,{ EMusicWidgetText1, L"area2_text1", "area2_text1_data", L"*" } + ,{ EMusicWidgetToolbarB1, L"toolbar_b1", "toolbar_b1_data", L"*" } + ,{ EMusicWidgetToolbarB2, L"toolbar_b2", "toolbar_b2_data", L"*" } + ,{ EMusicWidgetToolbarB3, L"toolbar_b3", "toolbar_b3_data", L"*" } + ,{ EMusicWidgetDefaultText, L"default_text", "default_text_data", L"*" } + + ,{ EMusicWidgetTrigger1, L"area1_image1", "MWTrigger1", L"*" } + ,{ EMusicWidgetTrigger2, L"default_text", "MWTrigger2", L"*" } + ,{ EMusicWidgetTB1Trigger, L"toolbar_b1", "TB1Trigger", L"*" } + ,{ EMusicWidgetTB2Trigger, L"toolbar_b2", "TB2Trigger", L"*" } + ,{ EMusicWidgetTB3Trigger, L"toolbar_b3", "TB3Trigger", L"*" } + + ,{ EMusicMenuMusicInfoImage1, L"image", "musicmenu_musicinfo_imagedata", L"musicmenu_musicinfo_image" } + ,{ EMusicMenuMusicInfoLine1, L"text", "musicmenu_musicinfo_text1data", L"musicmenu_musicinfo_text1" } + ,{ EMusicMenuMusicInfoLine2, L"text", "musicmenu_musicinfo_text2data", L"musicmenu_musicinfo_text2" } + ,{ EMusicMenuMusicInfoTrigger, L"text", "MMInfoTrigger", L"musicmenu_musicinfo_text1" } + }; + + +const TMCPImageDestinationInfoItem KMCPImageDestinationInfo[] = + + { + {EMusicWidgetImage1, 70,70} + , + {EMusicWidgetToolbarB1, 41,41} + , + {EMusicWidgetToolbarB2, 41,41} + , + {EMusicWidgetToolbarB3, 41,41} + , + {EMusicMenuMusicInfoImage1, 70,70} + }; + +/** + * Music Content Publisher (a Content Harvester plugin) + * + * @lib musiccontentpublisher.dll + * @since S60 S60 v5.0 + */ +class CMusicContentPublisher : public CContentHarvesterPlugin + ,public MMCPPluginObserver + ,public MAknsSkinChangeObserver + { + +public: + +// from base class MMCPPluginObserver + /** + * from MMCPPluginObserver + * Called when an image needs to be updated. + * + * @since S60 5.0 + * @param aPlugin Where the mesage is coming from. + * @param aDestination Where the image is to be placed. + * @param aImagePath Source path of the Image. + */ + void PublishImageL(CMCPPlugin* aPlugin, + TMCPImageDestination aDestination, const TDesC& aImagePath); + + /** + * from MMCPPluginObserver + * Called when an image needs to be updated. + * + * @since S60 5.0 + * @param aPlugin Where the mesage is coming from. + * @param aDestination Where the image is to be placed. + * @param aBitmapHandle Bitmap handle to the image. + * @param aMaskBitmapHandle Mask Bitmap handle for the image. + */ + void PublishImageL(CMCPPlugin* aPlugin, + TMCPImageDestination aDestination, + TInt aBitmapHandle, + TInt aMaskBitmapHandle = NULL); + + /** + * from MMCPPluginObserver + * Called when an image needs to be updated. + * + * @since S60 5.0 + * @param aPlugin Where the mesage is coming from. + * @param aDestination Where the image is to be placed. + * @param aID major and minor Skin ID info. + * @param aFilename fallback mif/mbm file. + * @param aFileBitmapId bitmap id within the fallback file. + * @param aFileMaskId mask id within the fallback file. + */ + void PublishImageL(CMCPPlugin* aPlugin, + TMCPImageDestination aDestination, + const TAknsItemID& aID, + const TDesC& aFilename, + const TInt aFileBitmapId, + const TInt aFileMaskId ); + + /** + * from MMCPPluginObserver + * Called when a text needs to be updated. + * + * @since S60 5.0 + * @param aPlugin Where the mesage is coming from. + * @param aDestination Where the text is to be placed. + * @param aText Descriptor containing the text. + */ + void PublishTextL( CMCPPlugin* aPlugin, + TMCPTextDestination aDestination, const TDesC& aText ); + + /** + * from MMCPPluginObserver + * Called when an action needs to be updated. + * + * @since S60 5.0 + * @param aPlugin Where the mesage is coming from. + * @param aDestination Destination trigger that should launch the action. + * @param aTrigerMap LIW Map containint the action that can be interpreted + * by the specified action handler plugin. + */ + void PublishActionL( CMCPPlugin* aPlugin, + TMCPTriggerDestination aDestination, + CLiwDefaultMap* aTrigerMap ); + + /** + * from MMCPPluginObserver + * Called when a plugin becomes active. + * + * @since S60 5.0 + * @param aPlugin Where the mesage is coming from. + */ + void BecameActiveL( CMCPPlugin* aPlugin ); + + /** + * from MMCPPluginObserver + * Called when a plugin becomes active. + * + * @since S60 5.0 + * @param aDst The image destination. + * @return The size of the image destination. + */ + TSize GetImageDestinationSize(TMCPImageDestination aDst); + + /** + * From MAknsSkinChangeObserver. + * Called by the skin server when skin content is changed and the + * connected client wants to be informed. + * + * @since 2.0 + */ + void SkinContentChanged(); + + /** + * From MAknsSkinChangeObserver. + * Called by the skin server to indicate that the current skin + * configuration has changed. + * + * @param aReason Reason code. + * + * @since 2.5 + */ + void SkinConfigurationChanged( + const TAknsSkinStatusConfigurationChangeReason /*aReason*/){}; + + /** + * From MAknsSkinChangeObserver. + * Called by the skin server to indicate that the available + * skin packages have changed. + * + * @param aReason Reason code. + * + * @since 2.5 + */ + void SkinPackageChanged(const TAknsSkinStatusPackageChangeReason /*aReason*/){}; + + void HandlePublisherNotificationL( const TDesC& aContentId, const TDesC8& aTrigger ); + /** + * Two-phased constructor. + */ + static CMusicContentPublisher* NewL( MLiwInterface* aCPSInterface ); + + + + // from base class CContentHarvesterPlugin + /** + * From CContentHarvesterPlugin + * This is called by the Content Harvester Server to signal an update. + */ + void UpdateL(); + + /** + * Destructor. + */ + virtual ~CMusicContentPublisher(); + + /** + * Resets the destinations with default values and removes active plugin. + */ + void ResetL(); + +private: + + /** + * Default constructor. + */ + CMusicContentPublisher( MLiwInterface* aCPSInterface ); + + /** + * Perform the second phase construction + */ + void ConstructL(); + + /** + * Installs an action, mainly for readability purposes. + * + * @since S60 5.0 + * @param aDestination Destination trigger that should launch the action. + */ + void InstallGoToMusicL(TMCPTriggerDestination aDestination); + + /** + * Installs an action, mainly for readability purposes. + * + * @since S60 5.0 + * @param aDestination Destination trigger that should launch the action. + */ + void InstallGoToAlbumL(TMCPTriggerDestination aDestination); + + /** + * Installs an rmpty action, mainly for readability purposes. + * + * @since S60 5.0 + * @param aDestination Destination trigger that should launch the action. + */ + void InstallEmptyActionL(TMCPTriggerDestination aDestination); + + + /** + * Maps an enum from TMCPImageDestination, TMCPTextDestination and + * TMCPTriggerDestination to it's keys on CPS. + * @param aEnum the enum/destination + * @param aType the type key is loaded here + * @param aDataKey the data key is loaded here + * @param aContent the content key is loaded here + * + * @since S60 5.0 + */ + void MapEnumToDestinationInfoL(TInt aEnum,TPtrC& aType, TPtrC8& aDataKey, + TPtrC& aContent); + + /** + * Resets the Bitmap cache. + * + * @since S60 5.0 + */ + void ResetBitmapCache(); + + /** + * Resets the publishing buffers. + * + * @since S60 5.0 + */ + void ResetPublishingBuffers(); + + TUint RegisterPublisherL( + const TDesC& aPublisherId, + const TDesC& aContentId, + const TDesC& aContentType ); + + TUint CMusicContentPublisher::ExtractItemId( const CLiwGenericParamList& aInParamList ); + + void RemoveL( TInt aDestination ); + + /** + * Get a heap descriptor from the resource file + * + * @since S60 5.0 + */ + void GetLocalizedStringL(RResourceFile& aResourceFile, HBufC*& aRetBuf, + TInt aResourceId); + + void DoPublishL(); + + +private: // data + + /** + * Instance of CPS interface used for update with CPS. + * Not own + */ + MLiwInterface* iCPSInterface; + + /** + * Creates the plugins and manages the plugins table. + * Own. + */ + CPluginManager* iPluginManager; + + /** + * Pointer to the active plugin. + * Not own. + */ + CMCPPlugin* iActivePlugin; + + /** + * mapping for the destination translation. + */ + RHashMap iDestinationMap; + + /** + * mapping for the destination image info translation. + */ + RHashMap iImageDestinationSizeMap; + + /** + * bitmap cache map. + */ + RHashMap iBitmapCache; + + /** + * To keep the unpublished data. + */ + RHashMap iPublishingDataBuffers; + + /** + * To keep the unpublished actions. + */ + RHashMap iPublishingActionBuffers; + + /** + * Skin server session. + */ + RAknsSrvSession iAknsSrvSession; + + /** + * Buffers for the localized strings + */ + HBufC* iNowPlayingBuffer; + HBufC* iLastPlayedBuffer; + HBufC* iGoToMusicBuffer; + + CMCPHarvesterPublisherObserver* iHPObserver; + TBool iIsPublisherActive; + + HBufC* iInstanceId; + + }; + +#endif // C_MUSICCONTENTPUBLISHER_H + +// End of File