--- /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 <contentharvesterplugin.h>
+#include <mcppluginobserver.h>
+#include <libc/stddef.h> // For wchar_t
+#include <e32hashtab.h>
+#include <AknsSrvClient.h>
+
+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<TInt, TMCPDestinationItem> iDestinationMap;
+
+ /**
+ * mapping for the destination image info translation.
+ */
+ RHashMap<TInt, TSize> iImageDestinationSizeMap;
+
+ /**
+ * bitmap cache map.
+ */
+ RHashMap<TInt, TBmpMsk> iBitmapCache;
+
+ /**
+ * To keep the unpublished data.
+ */
+ RHashMap<TInt, TMyBufferItem> iPublishingDataBuffers;
+
+ /**
+ * To keep the unpublished actions.
+ */
+ RHashMap<TInt, TMyBufferItem> 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