javauis/mmapi_akn/baseline/inc.nga/cmmasurfacewindow.h
branchRCL_3
changeset 26 2455ef1f5bbc
child 27 d5e927d5853b
equal deleted inserted replaced
25:ae942d28ec0e 26:2455ef1f5bbc
       
     1 /*
       
     2 * Copyright (c) 2002-2007 Nokia Corporation and/or its subsidiary(-ies).
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description:  This class implements MMMADisplayWindow functionality
       
    15 *               in graphics surface based displays for Helix engine.
       
    16 *
       
    17 */
       
    18 
       
    19 #ifndef CMMASURFACEWINDOW_H
       
    20 #define CMMASURFACEWINDOW_H
       
    21 
       
    22 
       
    23 //  INCLUDES
       
    24 #include <w32std.h>
       
    25 #include <reflcdui.h>
       
    26 #include <graphics/surface.h>
       
    27 #include <mmf/common/mmfvideosurfacecustomcommands.h>
       
    28 #include <mediaclientvideodisplay.h>
       
    29 
       
    30 #include <e32std.h>
       
    31 #include <mmf/common/mmfstandardcustomcommands.h>
       
    32 #include "mmmadisplaywindow.h"
       
    33 #include "cmmaeventsource.h"
       
    34 #include "cmmaplayer.h"
       
    35 
       
    36 //  FORWARD DECLARATIONS
       
    37 class RWsSession;
       
    38 class CWsScreenDevice;
       
    39 class RWindowBase;
       
    40 class MMMADisplay;
       
    41 
       
    42 //  CONSTANTS
       
    43 const TInt KMMAVideoMinDimension = 32; // minimum video width and height
       
    44 
       
    45 //  CLASS DECLARATION
       
    46 /**
       
    47 * This class implements MMMADisplayWindow functionality
       
    48 * in video display to graphics surface based displays for Helix engine.
       
    49 */
       
    50 NONSHARABLE_CLASS(CMMASurfaceWindow): public CBase,
       
    51         public MMMADisplayWindow,
       
    52         public MUiEventConsumer
       
    53 {
       
    54 public:
       
    55     /**
       
    56      * indicates what method needs to be called in UI thread context.
       
    57      */
       
    58     enum TUiCallbackType
       
    59     {
       
    60         ESetClipRect = 1,
       
    61         ERemoveSurface,
       
    62         ESetDrawRect,
       
    63         EInitVideoDisplay,
       
    64         EResetSurfaceParameters,
       
    65         ESetChangedSurfaceParameters,
       
    66         ECleanVideoDisplay,
       
    67         EDestroyWindow
       
    68     };
       
    69 
       
    70 private:
       
    71     /**
       
    72      * indicates different video display initialization states
       
    73      *
       
    74      * video display state transition can happen in following order:
       
    75      * 1. when MIDlet code is:
       
    76      * Player player = Manager.createPlayer(..);
       
    77      * player.realize();
       
    78      * VideoControl vc = (VideoControl)player.getControl("VideoControl");
       
    79      * vc.initDisplayMode(..);
       
    80      * player.start();
       
    81      *
       
    82      * EUIResourcesAndSurfaceParametersNotSet
       
    83      * EUIResourcesSetAndSurfaceParametersNotSet
       
    84      * EUIResourcesAndSurfaceParametersSet
       
    85      *
       
    86      *          OR
       
    87      *
       
    88      * 2. when MIDlet code is:
       
    89      * Player player = Manager.createPlayer(..);
       
    90      * player.start();
       
    91      * VideoControl vc = (VideoControl)player.getControl("VideoControl");
       
    92      * vc.initDisplayMode(..);
       
    93      *
       
    94      * EUIResourcesAndSurfaceParametersNotSet
       
    95      * ESurfaceParametersSetAndUIResourcesNotSet
       
    96      * EUIResourcesAndSurfaceParametersSet
       
    97      *
       
    98      * InitVideoDisplayL() should be called only after EUIResourcesAndSurfaceParametersSet
       
    99      * state is reached. ie both UI resources and surface parameters becomes available.
       
   100      *
       
   101      * 3. for below mentioned MIDlet code case:
       
   102      * Player player = Manager.createPlayer(..);
       
   103      * player.start(); // state transition is
       
   104      *
       
   105      * EUIResourcesAndSurfaceParametersNotSet
       
   106      * ESurfaceParametersSetAndUIResourcesNotSet
       
   107      * note that InitVideoDisplayL() is not called and video is not displayed in this case.
       
   108      */
       
   109     enum TVideoDisplayInitState
       
   110     {
       
   111         /**
       
   112          * indicates ui resources and surface parameters are not yet set.
       
   113          * UI resources are RWindowBase, CWsScreenDevice and RWsSession.
       
   114          * Surface parameters are TSurfaceId, TRect and TVideoAspectRatio.
       
   115          */
       
   116         EUIResourcesAndSurfaceParametersNotSet = 1,
       
   117         /**
       
   118          * indicates UI resources are set and surface parameters not yet set.
       
   119          * UI resources are set when initDisplayMode() is called and RWindow becomes available.
       
   120          */
       
   121         EUIResourcesSetAndSurfaceParametersNotSet,
       
   122         /**
       
   123          * indicates UI resources are not yet set and surface parameters are set.
       
   124          * Surface parameters are set when player.start() is called.
       
   125          */
       
   126         ESurfaceParametersSetAndUIResourcesNotSet,
       
   127         /**
       
   128          * indicates UI resources and surface parameters are set.
       
   129          */
       
   130         EUIResourcesAndSurfaceParametersSet
       
   131     };
       
   132 
       
   133 public:   // Constructors and destructors
       
   134     IMPORT_C static CMMASurfaceWindow* NewL(
       
   135         CMMAEventSource* aEventSource,
       
   136         CMMAPlayer* aPlayer,
       
   137         TBool aAVCableConnStatus);
       
   138 
       
   139     virtual ~CMMASurfaceWindow();
       
   140 
       
   141 private:  // Constructors and destructors
       
   142     CMMASurfaceWindow(
       
   143         CMMAEventSource* aEventSource,
       
   144         CMMAPlayer* aPlayer,
       
   145         TBool aAVCableConnStatus);
       
   146 
       
   147 public: // Methods derived from MMMADisplayWindow
       
   148     void SetDestinationBitmapL(CFbsBitmap* aBitmap);
       
   149     void DrawFrameL(const CFbsBitmap* aBitmap);
       
   150     void SetDrawRect(const TRect& aRect);
       
   151     void SetDrawRectThread(const TRect& aRect);
       
   152     const TRect& DrawRect();
       
   153     TSize WindowSize();
       
   154     void SetPosition(const TPoint& aPosition);
       
   155     void SetVisible(TBool aVisible, TBool aUseEventServer = ETrue);
       
   156     void SetWindowRect(const TRect& aRect, MMMADisplay::TThreadType aThreadType);
       
   157     void SetVideoCropRegion(const TRect& aRect);
       
   158     void SetRWindowRect(const TRect& aRect, MMMADisplay::TThreadType aThreadType);
       
   159     const TRect& WindowRect();
       
   160     void ContainerDestroyed();
       
   161     void ContainerSet();
       
   162 
       
   163 public: // from base class MUiEventConsumer
       
   164     void MdcDSAResourcesCallback(RWsSession &aWs,
       
   165                                  CWsScreenDevice &aScreenDevice,
       
   166                                  RWindowBase &aWindow);
       
   167     void MdcUICallback(TInt aCallbackId);
       
   168 
       
   169 public: // New methods
       
   170     TBool IsVisible() const;
       
   171     IMPORT_C void SetDisplay(MMMADisplay *aDisplay);
       
   172 
       
   173     /**
       
   174      * copies surface paramaters and intializes video display if
       
   175      * RWindow is already set, ie if intDisplayMode already called in midlet.
       
   176      * invokes InitVideoDisplayL() in UI thread context.
       
   177      *
       
   178      * @params aSurfaceId, aCropRect, aPixelAspectRatio surface paramaters.
       
   179      */
       
   180     IMPORT_C void SetSurfaceParameters(const TSurfaceId& aSurfaceId,
       
   181                               const TRect& aCropRect,
       
   182                               const TVideoAspectRatio& aPixelAspectRatio);
       
   183 
       
   184     /**
       
   185      * invokes DoRemoveSurface() in UI thread context.
       
   186      */
       
   187     IMPORT_C void RemoveSurface();
       
   188 
       
   189     /**
       
   190      * updates members variables with new surface parameters and invokes
       
   191      * DoSetChangedSurfaceParameters() in UI thread context.
       
   192      *
       
   193      * @params aSurfaceId, aCropRect, aPixelAspectRatio surface paramaters.
       
   194      */
       
   195     IMPORT_C void SetChangedSurfaceParameters(const TSurfaceId& aSurfaceId,
       
   196                                      const TRect& aCropRect,
       
   197                                      const TVideoAspectRatio& aPixelAspectRatio);
       
   198 
       
   199     /**
       
   200      * updates iAVCableConnected flag as and when the audio/video cable is
       
   201      * connected or disconnected
       
   202      *
       
   203      * @param aStatus true indicates cable connected else false
       
   204      */
       
   205     IMPORT_C void SetAVCableConnStatus(TBool aStatus);
       
   206 
       
   207 private: // New methods
       
   208     /**
       
   209      * starts video rendering to a graphics surface.
       
   210      * restarts video rendering to a graphics surafce with changed parameters.
       
   211      * This method must always be executed in UI-Thread context.
       
   212      */
       
   213     void RedrawVideoL();
       
   214 
       
   215     /**
       
   216      * utility function to invoke RedrawVideoL() function with in a TRAP harness.
       
   217      *
       
   218      * @param aSurfaceWindow reference to CMMASurfaceWindow instance on which RedrawVideoL()
       
   219      * has to be invoked
       
   220      * @return TInt Symbian OS error code, KErrNone if no error
       
   221      */
       
   222     static TInt StaticRedrawVideo(CMMASurfaceWindow& aSurfaceWindow);
       
   223 
       
   224     /**
       
   225      * creates new instance of CMediaClientVideoDisplay and intializes it with
       
   226      * surfaces and windows.
       
   227      * This method must always be executed in UI-Thread context.
       
   228      */
       
   229     void InitVideoDisplayL();
       
   230 
       
   231     /**
       
   232      * updates CMediaClientVideoDisplay with new RWindow rect value.
       
   233      * This method must always be executed in UI-Thread context.
       
   234      */
       
   235     TInt SetClipRect();
       
   236 
       
   237     /**
       
   238      * updates CMediaClientVideoDisplay instance with new surface parameters.
       
   239      * This method must always be executed in UI-Thread context.
       
   240      */
       
   241     void DoSetChangedSurfaceParameters();
       
   242 
       
   243     /**
       
   244      * resets CMediaClientVideoDisplay instance with new surface parameters.
       
   245      * This method must always be executed in UI-Thread context.
       
   246      */
       
   247     void DoResetSurfaceParameters();
       
   248 
       
   249     /**
       
   250      * Removes Surface from RWindow
       
   251      * This method must always be executed in UI-Thread context.
       
   252      */
       
   253     void DoRemoveSurface();
       
   254 
       
   255     /**
       
   256      * removes surfaces and windows from CMediaClientVideoDisplay instance
       
   257      * and deletes the instance.
       
   258      * This method must always be executed in UI-Thread context.
       
   259      */
       
   260     void CleanVideoDisplay();
       
   261 
       
   262     /**
       
   263      * Deletes this object.
       
   264      *
       
   265      * @since  S60 v5.2
       
   266      */
       
   267     void Destroy();
       
   268 
       
   269 private:  // Data
       
   270     /**
       
   271      * drawing area where video is rendered.
       
   272      */
       
   273     TRect iContentRect;
       
   274 
       
   275     /**
       
   276      * parent rectangle used for positioning contentRect.
       
   277      */
       
   278     TRect iParentRect;
       
   279 
       
   280     /**
       
   281      * Symbian RWindow rect
       
   282      */
       
   283     TRect iRWindowRect;
       
   284 
       
   285     /**
       
   286      * not owned, used for switching from UI thread to MMA thread
       
   287      */
       
   288     CMMAEventSource* iEventSource;
       
   289 
       
   290     /**
       
   291      * We must depend on player's state because direct screen access may
       
   292      * not be resumed before player is started.
       
   293      * not owned.
       
   294      */
       
   295     CMMAPlayer* iPlayer;
       
   296 
       
   297     /**
       
   298      * crop rectangle of video
       
   299      */
       
   300     TRect iVideoCropRegion;
       
   301 
       
   302     /**
       
   303      * owned, used for video display on surface
       
   304      * this instance is created & accessed in UI thread only.
       
   305      */
       
   306     CMediaClientVideoDisplay* iMediaClientVideoDisplay;
       
   307 
       
   308     /**
       
   309      * Display instance used to invoke UI callbacks.
       
   310      * Not owned.
       
   311      */
       
   312     MMMADisplay* iDisplay;
       
   313 
       
   314     /**
       
   315      * Window server session used by UI thread.
       
   316      * Adjustable and usable from UI thread only.
       
   317      * Not owned.
       
   318      */
       
   319     RWsSession* iWs;
       
   320 
       
   321     /**
       
   322      * Screen device used by UI thread.
       
   323      * Adjustable and usable from UI thread only.
       
   324      * Not owned.
       
   325      */
       
   326     CWsScreenDevice* iScreenDevice;
       
   327 
       
   328     /**
       
   329      * Window where video is displayed.
       
   330      * Adjustable and usable from UI thread only.
       
   331      * From UI thread.
       
   332      * Not owned.
       
   333      */
       
   334     RWindowBase* iWindow;
       
   335 
       
   336     /**
       
   337      * The surface to be created for composition.
       
   338      */
       
   339     TSurfaceId iSurfaceId;
       
   340 
       
   341     /**
       
   342      * The dimensions of the crop rectangle, relative to the video image.
       
   343      */
       
   344     TRect iCropRect;
       
   345 
       
   346     /**
       
   347      * The pixel aspect ratio to display video picture.
       
   348      */
       
   349     TVideoAspectRatio iPixelAspectRatio;
       
   350 
       
   351     /**
       
   352      * indicates the video display initialization state.
       
   353      *
       
   354      */
       
   355     TVideoDisplayInitState iVideoDisplayInitState;
       
   356 
       
   357     /**
       
   358      * Indicates if content need to be drawn.
       
   359      */
       
   360     TBool iVisible;
       
   361 
       
   362     /**
       
   363      * Audio/Video device cable connection status
       
   364      */
       
   365     TBool iAVCableConnected;
       
   366 };
       
   367 
       
   368 #endif // CMMASURFACEWINDOW_H