Symbian
Symbian Developer Library

SYMBIAN OS V9.4

Feedback

[Index] [Previous] [Next]

#include <W32STD.H>

Class RDirectScreenAccess

class RDirectScreenAccess : public MWsClientClass;

Description

The interface between an application that directly accesses the screen and the window server.

Note that most applications that need to access the screen directly should use CDirectScreenAccess instead. RDirectScreenAccess only needs to be used directly by applications without access to an active scheduler.

Derivation

Members

Defined in RDirectScreenAccess:

Inherited from MWsClientClass:


Construction and destruction


RDirectScreenAccess()

IMPORT_C RDirectScreenAccess();

Description

Default constructor.

Developers should use the other constructor overload instead.


RDirectScreenAccess(RWsSession &)

IMPORT_C RDirectScreenAccess(RWsSession &aWs);

Description

C++ constructor with a connected window server session.

RDirectScreenAccess::Construct() must be called to complete construction.

Parameters

RWsSession &aWs

Connected session with the window server.

[Top]


Member functions


Construct()

IMPORT_C TInt Construct();

Description

Second phase constructor.

Creates the server side resource and initialises the client's handle to it.

This function always causes a flush of the window server buffer.

Return value

TInt

KErrNone if successful, otherwise one of the system wide error codes.


Request(RRegion *&,TRequestStatus &,const RWindowBase &)

IMPORT_C TInt Request(RRegion *&aRegion, TRequestStatus &aStatus, const RWindowBase &aWindow);

Description

Issues a request to the window server for permission to perform direct screen access on a window.

Direct access to the screen may be refused due to lack of memory or if the target window is completely obscured.

If direct access is allowed, the function passes back a clipping region which is the part of the screen the caller can draw to.

When direct screen access must stop, for instance because a dialog is to be displayed in front of the region where direct screen access is taking place, the window server completes the request. The recommended way to check for this is for aStatus to be the request status of an active object that will be run when the request completes, i.e. if RDirectScreenAccess::Request(RRegion *&,TRequestStatus &,const RWindowBase &) returns KErrNone, call SetActive(), and in the object's RunL(), you should immediately abort direct screen access.

While the DSA is in operation, it is strongly advised that the client should not make any call to WSERV that will affect the visible area of the window in which the DSA is taking place.

When WSERV tells the client that it needs to abort its DSA, it waits to receive the acknowledgment from the client that it has done so. However, it doesn't wait for ever, since the client may have entered some long running calculation or even an infinite loop. So WSERV also waits on a timer: if the timer expires before the client acknowledges, then WSERV continues; if, later on, WSERV gets notification from the client that it has aborted the DSA, then WSERV will invalidate the region in which the DSA was taking place, just in case there had been a conflict between the DSA and another client.

This function always causes a flush of the window server buffer.

Parameters

RRegion *&aRegion

On return, the clipping region that the caller can draw to. NULL if the function was not successful.

TRequestStatus &aStatus

A request status that is set to a completion code by the window server when direct screen access must stop.

const RWindowBase &aWindow

The window that you want to perform the direct screen access on. There must not already be direct access on this window or a panic occurs.

Return value

TInt

KErrNone if the request was successful, otherwise one of the system wide error codes, e.g. KErrNotReady if none of the window is currently visible, KErrNoMemory if out of memory.


Completed()

IMPORT_C void Completed();

Description

Indicates to the window server that you have responded to the completion of the request status passed to RDirectScreenAccess::Request(RRegion *&,TRequestStatus &,const RWindowBase &), by stopping direct screen access.


Cancel()

IMPORT_C void Cancel();

Description

Indicates to the window server that you have finished performing direct screen access.


Close()

IMPORT_C void Close();

Description

Calls RDirectScreenAccess::Completed() then deletes the server side resource and sets the client's handle to it to NULL.

[Top]


Member enumerations


Enum TTerminationReasons

TTerminationReasons

Description

Provides the reason why direct screen access must terminate. This enum is used in the MAbortDirectScreenAccess::AbortNow(RDirectScreenAccess::TTerminationReasons) and MDirectScreenAccess::Restart(RDirectScreenAccess::TTerminationReasons) functions.

The first value (ETerminateCancel) indicates that direct screen access is being terminated by the application. The final three values indicate that direct screen access is being terminated by the window server. Note that for users of CDirectScreenAccess, the termination code is not important because these issues are dealt with by CDirectScreenAccess::StartL().

ETerminateCancel

The application has finished direct screen access.

ETerminateRegion

A window is about to come in front of a part of the area that is being used for direct screen access.

ETerminateScreenMode

The screen's color depth (as enumerated by TDisplayMode) is about to change.

ETerminateRotation

The current screen mode (the combination of screen rotation and screen size) is about to change.


Enum TPriority

TPriority

Description

The priority of the active object that responds to notification that direct screen access must stop.

EPriorityVeryHigh

A suggested value for the priority of the active object that responds to notification from the window server that direct screen access must stop. This is also the value used by CDirectScreenAccess for this purpose.