diff -r ae942d28ec0e -r 2455ef1f5bbc javauis/mmapi_akn/baseline/inc.nga/cmmacamerawindow.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/javauis/mmapi_akn/baseline/inc.nga/cmmacamerawindow.h Wed Sep 01 12:33:18 2010 +0100 @@ -0,0 +1,345 @@ +/* +* Copyright (c) 2009 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: This class implements MMMADisplayWindow functionality +* for Camera viewfinder usage. +* +*/ + + +#ifndef CMMACAMERAWINDOW_H +#define CMMACAMERAWINDOW_H + +// INCLUDES +#include +#include +#include +#include "mmmadisplaywindow.h" +#include "mmmadisplay.h" +// CONSTANTS + +// FORWARD DECLARATIONS +class CFbsBitmap; +class RWsSession; +class CWsScreenDevice; +class RWindowBase; +class MMMADisplay; + +// CLASS DECLARATION +/** +* This class implements MMMADisplayWindow functionality +* to use with CMMACameraPlayer. +* It duplicates its camera instance within the UI thread +* and displays the viewfinder using the UI +* DirectScreenAccess resources. +* +* @since S60 v5.0 +*/ + + +NONSHARABLE_CLASS(CMMACameraWindow): public CBase, + public MMMADisplayWindow, + public MCameraObserver2, + public MUiEventConsumer, + public MDirectScreenAccess +{ +public: + enum TUiCallbackType + { + EDeleteViewFinder = 1, + EHideViewFinder, + EShowViewFinder, + EResetViewFinder, + EDestroyWindow + }; + + /** + * Two-phased constructor. + * + * @param aCameraHandle A handle to existing CCamera instance. + */ + static CMMACameraWindow* NewL(TInt aCameraHandle); + + + /** + * Destructor. + */ + ~CMMACameraWindow(); + + /** + * Gets an information if the DirectViewFinder is started + * + * @since S60 v5.0 + * @return ETrue if DirectViewFinder is active + */ + TBool ViewFinderActive(); + + /** + * Notifies window about Started state change + * + * @since S60 v5.0 + * @param aStarted Indicates that camera player is in started state + */ + void SetStarted(TBool aStarted); + + /** + * Sets iDisplay + * Used to invoke callbacks in UI thread + * + * @since S60 v5.0 + * @param "aDisplay" A Display to be used for callbacks. + * When set, the duplicated CCamera is created in UI thread + * and the necessary DSA resources are got. + * When replacing an old Display (set earlier) + * all the old resources are deleted. + * NULL deletes all allocated UI resources. + */ + void SetDisplay(MMMADisplay *aDisplay); + + +// from base class MMMADisplayWindow + void SetDestinationBitmapL(CFbsBitmap* aBitmap); + void DrawFrameL(const CFbsBitmap* aBitmap); + void SetDrawRect(const TRect& aRect); + void SetDrawRectThread(const TRect& aRect); + const TRect& DrawRect(); + TSize WindowSize(); + void SetPosition(const TPoint& aPosition); + void SetVisible(TBool aVisible, TBool aUseEventServer = ETrue); + void SetWindowRect(const TRect& aRect,MMMADisplay::TThreadType aThreadType); + void SetRWindowRect(const TRect& aRect, MMMADisplay::TThreadType aThreadType); + const TRect& WindowRect(); + TDisplayWindowType GetDisplayWindowType() const; + TBool IsVisible() const; + void ContainerSet(); + void ContainerDestroyed(); + + +// from base class MCameraObserver2 + void HandleEvent(const TECAMEvent& aEvent); + void ViewFinderReady(MCameraBuffer& aCameraBuffer,TInt aError); + void ImageBufferReady(MCameraBuffer& aCameraBuffer,TInt aError); + void VideoBufferReady(MCameraBuffer& aCameraBuffer,TInt aError); + + +// from base class MUiEventConsumer + void MdcDSAResourcesCallback( + RWsSession &aWs, + CWsScreenDevice &aScreenDevice, + RWindowBase &aWindow); + void MdcUICallback(TInt aCallbackId); + + +// from base class MDirectScreenAccess + void AbortNow(RDirectScreenAccess::TTerminationReasons aReasons); + void Restart(RDirectScreenAccess::TTerminationReasons aReasons); + + +private: + /** + * Constructor. + * @see CMMACameraWindow::NewL() + */ + CMMACameraWindow(TInt aCameraIndex); + + /** + * Creates UI Camera - + * a new CCamera instance (duplicated from handle + * given to the constructor) + * Have to be called from the thread which UI Camera + * will be controlled from + * + * @since S60 v5.0 + * @param "aWs" WS session from the last MdcDSAResourcesCallback + * @param "aScreenDevice" Screen from the last MdcDSAResourcesCallback + * @param "aWindow" Window from the last MdcDSAResourcesCallback + */ + void UIStartViewFinder(RWsSession &aWs, CWsScreenDevice &aScreenDevice, RWindowBase &aWindow); + + /** + * If UI Camera have been created + * it starts/hides the DirectViewFinder + * Have to be called from UI thread in which UI Camera + * have been created! + * + * @since S60 v5.0 + * @param "aVisible" If true DirectViewFinder is started, else stopped + */ + void SetViewFinderVisibility(TBool aVisible); + + /** + * Stops the DirectViewFinder and deletes UI Camera instance + * Have to be called from UI thread in which UI Camera + * have been created before the CMMACameraWindow instance + * is deleted! + * + * @since S60 v5.0 + */ + void ReleaseUiResources(); + + /** + * The callback method invoked by starter timer + * + * @since S60 v5.0 + * @param aThis An instance of CMMACameraWindow + * @return Always returns EFalse + */ + static TInt StarterTimerCallback(TAny* aThis); + + /** + * Starts viewfinder. + * + * @since S60 v5.0 + */ + void StartViewFinder(); + + /** + * Resets (stops and starts) viewfinder + * + * @since S60 v5.0 + */ + void ResetViewFinder(); + + /** + * Draws the error message to specified area. + * Used in cases when viewfinder is unable to start + * + * @since S60 v5.0 + * @param aError Viewfinder error id + * @param aDrawRect Area to draw to + */ + void DrawViewFinderErrorL(const TInt aError, const TRect& aDrawRect); + + /** + * Deletes this object. + * + * @since S60 v5.0 + */ + void Destroy(); + +private: // data + /** + * Indicates the window visibility. + */ + TBool iVisible; + + /** + * Indicated that owning player is in Started state. + */ + TBool iStarted; + + /** + * Indicates that Direct viewfinder is displayed on screen. + */ + TBool iViewFinderVisible; + + /** + * Indicates that duplicated camera (iUICamera) is powered on. + */ + TBool iCameraPowerOn; + + /** + * Rectangle to display viewfinder on (Window coordinates). + */ + TRect iDrawRect; + + /** + * The area of the window. + */ + TRect iClientRect; + + /** + * The handle of original camera instance. + */ + TInt iCameraHandle; + + /** + * UI Camera instance + * Duplicated from iCameraHandle. + * Adjustable and usable from UI thread only. + * Own. + */ + CCamera* iUICamera; + + /** + * Display instance used to invoke UI callbacks. + * Not owned. + */ + MMMADisplay* iDisplay; + + /** + * Window server session used by UI thread. + * Adjustable and usable from UI thread only. + * Not owned. + */ + RWsSession* iWs; + + /** + * Screen device used by UI thread. + * Adjustable and usable from UI thread only. + * Not owned. + */ + CWsScreenDevice* iScreenDevice; + + /** + * Window to draw viewfinder on. + * Adjustable and usable from UI thread only. + * From UI thread. + * Not owned. + */ + RWindowBase* iWindow; + + /** + * The timer to delay viewfinder start + * to avoid many showing/hidding request + * (for instance when scrolling the viewfinder) + * Adjustable and usable from UI thread only. + * Own. + */ + CPeriodic* iStarterTimer; + + /** + * Direct screen access used to draw the error message. + * Adjustable and usable from UI thread only. + * Own. + */ + CDirectScreenAccess* iDirectAccess; + + /** + * Count of remaining allowed DSA restarts. + * In some cases (like screen orientation change) + * the DSA fails to start for some time. + * Therefore the start is tried more times. + */ + TUint iRemainingDSAStartAttempts; + + /** + * An icon used to display instead of viewfinder. + * in case that viewfinder start fails. + * Own. + */ + CFbsBitmap* iErrorIconBitmap; + + /** + * Bitmap mask of iErrorIconBitmap. + * Own. + */ + CFbsBitmap* iErrorIconMaskBitmap; + + /** + * Symbian RWindow rect + */ + TRect iRWindowRect; +}; + +#endif // CMMACAMERAWINDOW_H