musichomescreen_multiview/mcpmusicplayer/inc/mcpmusicplayer.h
changeset 0 ff3acec5bc43
child 11 943ff5625028
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/musichomescreen_multiview/mcpmusicplayer/inc/mcpmusicplayer.h	Thu Dec 17 08:45:05 2009 +0200
@@ -0,0 +1,396 @@
+/*
+* 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:  Updates Music Content Plublisher
+*
+*/
+
+
+#ifndef C_MCPMUSICPLAYER_H
+#define C_MCPMUSICPLAYER_H 
+
+#include <mpxplaybackcommanddefs.h> //for TMPXPlaybackCommand
+#include <e32std.h> // for TExitType
+#include <mcpplugin.h>
+#include <mcppluginobserver.h>
+#include <mpxcollectionobserver.h>
+#include "aiplayerpluginengineobserver.h"
+#include "filemonitorobserver.h"
+#include "applicationmonitorobserver.h"
+#include "pnsmonitorobserver.h"
+
+class MLiwInterface;
+class CLiwGenericParamList;
+class CAiPlayerPluginEngine;
+class CFileMonitor;
+class CApplicationMonitor;
+class CPNSMonitor;
+class RResourceFile;
+class MMPXCollectionUtility;
+
+/**
+ *  Music Player MCP plugin.
+ *  CMCPMusicPlayer implements CMCPPlugin
+ *
+ *  @since S60 S60 v5.0
+ */
+class CMCPMusicPlayer : public CMCPPlugin,
+                                public MAiPlayerPluginEngineObserver,
+                                public MFileMonitorObserver,
+                                public MApplicationMonitorObserver,
+                                public MMPXCollectionObserver,
+                                public MPNSMonitorObserver
+    {
+public:
+    /**
+     * Standard Symbian 2 phase constructor
+     */
+    static CMCPMusicPlayer* NewL(
+            MMCPPluginObserver* aObserver);
+
+    /**
+     * Standard C++ destructor.
+     */
+    virtual ~CMCPMusicPlayer();
+
+ // from base class CMCPPlugin
+
+    /**
+     * From CMCPPlugin
+     * @since S60 5.0
+     */
+    void Deactivate();
+    
+    /**
+     * From CMCPPlugin
+     * @since S60 5.0
+     */
+    void SkinChanged();
+        
+
+// from base class MAiPlayerPluginEngineObserver
+    
+    /**
+     * From MAiPlayerPluginEngineObserver
+     * @since S60 5.0
+     * See aiplayerpluginengineobserver.h for detailed description.
+     */
+    void PlayerStateChanged(TMPlayerState aState);
+    
+    /**
+     * From MAiPlayerPluginEngineObserver
+     * @since S60 5.0
+     * See aiplayerpluginengineobserver.h for detailed description.
+     */
+    void TrackInfoChanged(const TDesC& aTitle, const TDesC& aArtist);
+    
+    /**
+     * From MAiPlayerPluginEngineObserver
+     * @since S60 5.0
+     * See aiplayerpluginengineobserver.h for detailed description.
+     */
+    void PlaybackPositionChanged(TInt aPosition);
+    
+    /**
+     * From MAiPlayerPluginEngineObserver
+     * @since S60 5.0
+     * See aiplayerpluginengineobserver.h for detailed description.
+     */
+    void AlbumArtChanged( CFbsBitmap* aBitmap );
+    
+    /**
+     * From MAiPlayerPluginEngineObserver
+     * @since S60 5.0
+     * See aiplayerpluginengineobserver.h for detailed description.
+     */
+    void Opening();
+    
+    /**
+     * From MAiPlayerPluginEngineObserver
+     * @since S60 5.0
+     * See aiplayerpluginengineobserver.h for detailed description.
+     */
+    void PlaylisIsEmpty();
+    
+// from base class MFileMonitorObserver
+    /**
+     * from MFileMonitorObserver
+     * Handle a file system change notification
+     *
+     */
+    void HandleFileRemovedL();
+       
+// from base class MApplicationMonitorObserver
+    /**
+     * from MApplicationMonitorObserver
+     * Handle an application close event.
+     */
+    void HandleApplicationClosedL(TExitType aReason);
+    
+//from base class MMPXCollectionObserver  
+    /** 
+     *  Handle collection message
+     * 
+     *  @param aMsg collection message, ownership not transferred. 
+     *         Please check aMsg is not NULL before using it. 
+     *         If aErr is not KErrNone, plugin might still call back with more
+     *         info in the aMsg.
+     *  @param aErr system error code.
+     */
+    void HandleCollectionMessage( CMPXMessage* aMsg, TInt aErr );
+
+    /**
+     *  Handles the collection entries being opened. Typically called
+     *  when client has Open()'d a folder.
+     *
+     *  @since S60 3.2.3
+     *  @param aEntries collection entries opened
+     *  @param aIndex focused entry
+     *  @param aComplete ETrue no more entries. EFalse more entries
+     *                   expected
+     *  @param aError error code   
+     */
+    void HandleOpenL( const CMPXMedia& aEntries, TInt aIndex, TBool aComplete,
+            TInt aError );
+
+    /**
+     *  Handles the item being opened. Typically called
+     *  when client has Open()'d an item. Client typically responds by
+     *  'playing' the item via the playlist.
+     *
+     *  @since S60 3.2.3
+     *  @param aPlaylist collection playlist
+     *  @param aError error code
+     */
+    void HandleOpenL( const CMPXCollectionPlaylist& aPlaylist, TInt aError );
+
+    /**
+     * From MMPXCollectionMediaObserver 
+     * It handles MediaL event.
+     *
+     * @param aMedia object containing collection's informations
+     * @param aError error code
+     */
+    void HandleCollectionMediaL( const CMPXMedia& aMedia, TInt aError );
+
+    /**
+     * from MPNSMonitorObserver
+     * Handle launching music player on the background.
+     */
+    void OpeningMusicPlayer();
+
+private:
+
+    /**
+     * Standard C++ constructor.
+     */
+    CMCPMusicPlayer( MMCPPluginObserver* aObserver );
+
+    /**
+     * Standard Symbian 2nd phase constructor.
+     */
+    void ConstructL();
+
+    /**
+     * returns ETrue if data can be propagated to the Music Content Publisher.
+     */
+    TBool IsOKToPublishData();
+     
+    /**
+     * Installs Playback command action, the puppose of this is to improve
+     * readability.
+     */
+    void InstallPlaybackCommandActionL( TMPXPlaybackCommand aCmd,
+            TMCPTriggerDestination aDestination );
+    /**
+     * Installs Launch Music Player action, the puppose of this is to improve
+     * readability.
+     */
+    void InstallLaunchMusicPlayerL( TMCPTriggerDestination aDestination );
+    
+    /**
+     * Installs Go To Now playing action, the puppose of this is to improve
+     * readability.
+     */
+    void InstallGoToNowPlayingL( TMCPTriggerDestination aDestination );
+        
+    /**
+     * Installs Go To Last Played action, the puppose of this is to improve
+     * readability.
+     */
+    void InstallGoToLastPlayedL( TMCPTriggerDestination aDestination, 
+             TBool aMinimized );
+    
+    /**
+     * 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 empty action, mainly for readability purposes.
+     *
+     * @since S60 5.0
+     * @param aDestination Destination trigger that should launch the action.
+     */
+    void InstallEmptyActionL(TMCPTriggerDestination aDestination);
+    
+    /**
+     * Installs actions and icons in the toolbar.
+     *
+     * @since S60 5.0
+     */
+    void UpdateToolBarL(TUint aToolBarState);
+    
+    /**
+     * Resets the widget an Music Suite.
+     *
+     * @since S60 5.0
+     */
+    void ResetL();
+
+    /**
+     * Get a heap descriptor from the resource file
+     *
+     * @since S60 5.0
+     */
+    void GetLocalizedStringL(RResourceFile& aResourceFile, HBufC*& aRetBuf,
+            TInt aResourceId);
+    
+    
+    /**
+     * @since S60 5.0
+     */
+    void ActivateL();
+    void DoUpdatePlayerStateL(TMPlayerState aState);
+    void DoUpdateTrackInfoL(const TDesC& aTitle, const TDesC& aArtist);
+    void DoUpdatePlaybackPositionL(TInt aPosition);
+    void DoUpdateAlbumArtL( CFbsBitmap* aBitmap );
+    void DoHandleOpeningL();
+    void DoHandlePlaylisIsEmptyL();
+    void DoHandleSkinChangedL();
+    
+    /**
+     * Logic of HandleCollectionMessageL, to avoid the function leaves
+     * 
+     * @param aMsg collection message
+     */
+    void HandleCollectionMessageL( CMPXMessage* aMsg );
+
+    /**
+     * Logic of HandleCollectionMessage, to avoid the function leaves
+     * 
+     * @param aMsg collection message
+     */
+    void DoHandleGeneralMessageL( const CMPXMessage& aMsg );
+       
+    /**
+    *  Music Player opening timer callback
+    *
+    *  @param aPtr pointer the this
+    */
+    static TInt MusicPlayerOpeningTimerCallback( TAny* aPtr );
+
+private: // data
+
+    /**
+     * Instance of MCP plugin observer
+     * Not owned.
+     */
+    MMCPPluginObserver* iMHObserver;
+    
+    /**
+     * Instance of CAiPlayerPluginEngine used to observe Music player via 
+     * MAiPlayerPluginEngineObserver.
+     * Owned.
+     */
+    CAiPlayerPluginEngine* iEngine;
+    
+    /**
+     * State indicator, the plugin can be active or inactive. 
+     */
+    TBool iActive;
+    
+    /**
+     * art cached indicator. 
+     */
+    TBool iArtCached;
+    
+    /**
+     * Used to monitor last played song. 
+     */
+    CFileMonitor* iFileMonitor;
+
+    /**
+     * Used to monitor if music player closes. 
+     */
+    CApplicationMonitor* iAppMonitor;
+    
+    /**
+     * Used to monitor publish and subscribe property. 
+     */
+    CPNSMonitor* iPNSMonitor;
+
+    /**
+     * Current Album Art. 
+     */
+    CFbsBitmap* iArtBitmap;
+    
+    /**
+     * The art that was extracted but not used due to the current stateof
+     * the plugin (acctive, not active) 
+     */
+    CFbsBitmap* iCachedArtBitmap;
+    
+    /**
+     * Album Art mask. 
+     */
+    CFbsBitmap* iArtBitmapMask;
+    
+    /**
+     * Current Toolbar State.
+     */  
+    TUint iToolBarState;
+    
+    /**
+    * Buffers for the localized strings
+    */
+    HBufC* iGoToMusicBuffer;
+    HBufC* iOpeningBuffer;
+    
+    /**
+     * Flag of Mass Storage mode or MTP mode
+     */
+    TBool iUSBOnGoing;
+   
+    /**
+     * collection utility
+     */
+    MMPXCollectionUtility* iCollectionUtility;
+
+    CPeriodic* iMusicPlayerOpeningTimer;
+    };
+
+#endif // C_MCPMUSICPLAYER_H
+
+//  End of File