windowing/windowserver/nga/SERVER/openwfc/window.h
author MattD <ext-matt.4.davies@nokia.com>
Fri, 24 Sep 2010 16:58:15 +0100
branchEGL_MERGE
changeset 191 6356de74619b
parent 0 5d03bc08d59c
permissions -rw-r--r--
merged faisal's branch of EGL_MERGE on top of all of the dead heads of Jose. This makes Faisal's changes the 'tip' of EGL_MERGE again. No changes.

// Copyright (c) 2006-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:
// CWsWindow and associated classes definitions
// 
//

#ifndef __WINDOW_H__
#define __WINDOW_H__

#include "server.h"
#include "winbase.h"

#ifndef _DEBUG

#define LOG_WINDOW_FADE_START(wswin)
#define LOG_WINDOW_FADE_REGION(region)
#define LOG_WINDOW_FADE_END(wswin)

#else

#define LOG_WINDOW_FADE_START(wswin) LogFadeStart(wswin)
#define LOG_WINDOW_FADE_REGION(region) LogFadeRegion(region)
#define LOG_WINDOW_FADE_END(wswin) LogFadeEnd(wswin)

class TTruncateOverflow : public TDesOverflow
    {
    public:
    virtual void Overflow(TDes&) {};
    };

void LogRegion(const TRegion* aRegion);
void LogFadeStart(const CWsWindow* aWsWin);
void LogFadeRegion(const TRegion* aRegion);
void LogFadeEnd(const CWsWindow* aWsWin);

#endif

void AnnotateWindowRedrawStart(const CWsWindow& aWsWin, const TRegion& aRegion);
void AnnotateWindowRedrawEnd(const CWsWindow& aWsWin);
void AnnotateWindowAnimRedrawStart(const CWsWindow& aWsWin, const CWsAnim& aAnim, const TRegion& aRegion);
void AnnotateWindowAnimRedrawEnd(const CWsWindow& aWsWin, const CWsAnim& aAnim);
void AnnotateSpriteRedrawStart(const CWsWindow& aWsWin, const CWsSpriteBase& aSprite, const TRegion& aRegion);
void AnnotateSpriteRedrawEnd(const CWsWindow& aWsWin, const CWsSpriteBase& aSprite);

class MWsGraphicsContext;
class CWsRenderStage;

class CWsWindow : public CWsWindowBase, public MWsWindow
	{
	friend class TWalkWindowTreeDisconnect;
	friend class CWsRootWindow;
	friend class TWalkWindowTreeFindWithFlag;
public:
	CWsWindow(CWsClient* aOwner,WH_HANDLES aType, CScreen* aScreen);
	~CWsWindow();
	void Construct();
	inline const TRect& Rel() const;
	inline const TRect& Abs() const;
	inline CWsWindow *PrevSiblingMultiParent() const;
	inline CWsWindow *NextSiblingMultiParent() const;
	inline TUint PointerFilter() const;
	inline TBool HasPointerGrab() const;
	inline TBool ShutDownInProgress() const;
	inline TRgb BackColor() const;
	virtual void AreaCovered(TRegion &aRegion);
	const TRegion* VisibleRegionIfValid() const;
	const TRegion& VisibleRegion() const;
	void ClearVisibleRegion();
	void SetVisibleRegion(const TRegion& aNewVisibleRegion, const TRegion* aTop);
	void SetFadeableRegion(const TRegion& aNewFadeableRegion, const TRegion& aTop);
	
	virtual void GenerateWindowRegion(RWsRegion &aRegion) const=0;
	TRect FullRect() const;
	inline TBool ClientSetInvisible() const;
	inline TBool IsVisible() const;
	inline TBool DragDropCapture() const;
	inline CWsBackedUpWindow *Backup() const;
	TDisplayMode DisplayMode() const;
	inline TInt UsingPointerBuffer() const;
	virtual TDblQue<TPointerKeyList> *PointerKeyList() const;
	inline CWsWindowRedraw *Redraw() const;
	inline TBool IsTopClientWindow() const;
	TDisplayMode SetRequiredDisplayModeL(TDisplayMode aDisplayMode);
	inline TBool IsActive() const;
	TInt AddDSA(CWsDirectScreenAccess& aDirect);
	void RemoveDSA(CWsDirectScreenAccess& aDirect);
	void AbortAllDSAs();
#if defined(_DEBUG)
	inline const TSglQue<CWsDirectScreenAccess>& DSAs() const;
#endif
	void PossibleVisibilityChangedEvent(TBool aForceSend);
	void SetNonFading(TBool aNonFading); 
	void SetFadeBehind(TBool aFade);
	inline void GetFadingParams(TUint8& aBlackMap,TUint8& aWhiteMap) const;
	inline TBool IsTranslucent() const;
	inline TBool HasAlpha() const;
	inline TBool HasBeenDrawnToScreen() const;
	inline void SetDrawnToScreen(TBool aDrawn);
	void FocusChanged(TBool aNewFocusState);
	void ClipRectToViewport(TRect& aRect) const;
	void SetNextScheduled(CWsWindow * aWin);
	CWsWindow * NextScheduled() const;
	inline const TRegion& ScheduledRegion() const;
	inline const TRegion& ScheduledSpriteRegion() const;
	TBool SetScheduledRegion(const TRegion& aRegion);
	void ClearScheduledRegion();
	void ClearScheduledSpriteRegion();
	static TBool ReleaseMemory(MWsMemoryRelease::TMemoryReleaseLevel aLevel);
	TBool ReadyToDraw() const;
	void Render(MWsGraphicsContext& aGc, const TRegion& aWindowRegion, const TRegion& aWindowChildNodeRegion);	
	void Accessed();
	
	inline TBool IsNonFading() const;
	const TRegion& QuickFadeRegion() const;
	void Fade(MWsGraphicsContext * aGc, const TRegion& aRegion);
	
	inline void SetValidRedraw();
	inline TBool IsValidRedraw() const;
	inline TBool HasElement() const;
	inline TBool IsFading() const;
	inline TBool HasAnimation() const;
	inline TBool IsBackgroundClearEnabled() const;
	void AddDirtyWindowRegion(const TRegion& aRegion);
	void AddDirtySpriteRegion(const TRegion& aRegion);
	const TRegion& DirtyWindowRegion() const;
	const TRegion& DirtySpriteRegion() const;
	void ScheduleDirtyWindowRegion();
	void ScheduleDirtySpriteRegion();
	void SetupVisibleRegionTracking(TBool aRegister);
	inline TBool IsTrackingVisibleRegion() const;
	const TRegion& FadableRegion() const;
	
public: // from CWsWindowBase
	TBool IsDSAHost() const;
	void SendState(MWsWindowTreeObserver& aWindowTreeObserver) const;

public:	// from MWsWindow
	TPoint Origin() const;
	TRect AbsRect() const;
	TSize Size() const;
	TUint32 Handle() const;
	MWsScreen * WsScreen() const;
	void Invalidate(const TRect *) {}
	MWsWindow * FindChildByHandle(TUint32 aHandle);
	TInt OrdinalPriority() const;

protected:
	TPoint InquireOffset(TUint32 aHandle) const;
	void Shutdown();	// Part of two phase destruction
	void FocusChangedL(TBool aNewFocusState);
	void RemoveFromAccessList();
	void InsertIntoAccessListOldestEnd();
	void InsertIntoAccessListRecentEnd();
	void DeactivateAllSprites();
private:
	void StatusDump(TDes &aBuf);
	void ResetVisibleRegion();
	void AbortDsaIfRequired(const TRegion& aNewRegion, const TRegion* aTop);
	void RestartAnimations(const TRegion& aNewRegion);
#if defined (_DEBUG)
public:
	TBool iInteresting;  // Often useful while debugging for conditional breakpoints.
#endif
protected:
	TRect iRel;
	TRect iAbs;
	TPoint iOrigin;
	RWsRegionBuf<1> iVisibleRegion;
	TUint iPointerFilter;
	TInt iPointerCapturePriority;
	TUint iFlags;
	CWsWindowRedraw *iRedraw;
	TSglQue<CWsDirectScreenAccess> iDSAs;
	CWsWindow * iNextScheduled;
	RWsRegionBuf<1> iScheduledRegion;
	RWsRegionBuf<1> iScheduledSpriteRegion;
	// The access list is a "most recently drawn" ordering list of all redraw msg windows.
	static CWsWindow * iAccessListRecentEnd;
	static CWsWindow * iAccessListOldestEnd;
	CWsWindow * iAccessListPrev;
	CWsWindow * iAccessListNext;
	TUint8 iBlackMap;
	TUint8 iWhiteMap;		
	RWsRegionBuf<1> iQuickFadeRegion;
	RWsRegionBuf<1> iFadableRegion;  // Region which can be faded (Visible region minus already faded regions)
	RWsRegionBuf<1> iDirtyWindowRegion;
	RWsRegionBuf<1> iDirtySpriteRegion;
	TInt iVisibleRegionTrackingCounter;
public:
	/** The list of graphic contexts associated with this window. The list is managed by calling the
	GcActivated() and GcDeactivated() functions. 
	This is a linked list. The CWsGc class contains a pointer to the next item: CWsGc::iNextWinGc.
	*/
	CWsGc *iWinGcList;
	CWsAnim *iAnimList;	// Start of linked list of animated objects attached to the window
	};

#include "wnredraw.h"

inline TBool CWsWindow::IsVisible() const
	{
	return(!(iFlags&EFlagHidden));
	}

inline TBool CWsWindow::ClientSetInvisible() const
	{
	return(iFlags&EFlagInvisible);
	}

inline TBool CWsWindow::DragDropCapture() const
	{
	return(iFlags&EFlagPointerCaptureDragDrop);
	}

inline TRgb CWsWindow::BackColor() const
	{
	return(iRedraw->BackColor());
	}

inline TInt CWsWindow::UsingPointerBuffer() const
	{
	return(iFlags&EFlagUsingPointerBuffer);
	}

inline CWsWindowRedraw *CWsWindow::Redraw() const
	{
	return iRedraw;
	}

inline const TRect& CWsWindow::Rel() const
	{
	return iRel;
	}
	
inline const TRect& CWsWindow::Abs() const
	{
	return iAbs;
	}
	
inline TBool CWsWindow::IsTopClientWindow() const
	{
	return(iFlags&EFlagIsTopClientWindow);
	}

inline TUint CWsWindow::PointerFilter() const
	{
	return(iPointerFilter);
	}

inline TBool CWsWindow::HasPointerGrab() const
	{
	return(iFlags&EFlagPointerGrab);
	}

inline TBool CWsWindow::ShutDownInProgress() const
	{
	return(iFlags&EFlagShutDownInProgress);
	}

inline CWsBackedUpWindow *CWsWindow::Backup() const
	{
	return(iRedraw->Backup());
	}

inline CWsWindow *CWsWindow::PrevSiblingMultiParent() const
	{
	return((CWsWindow *)CWsWindowBase::PrevSiblingMultiParent());
	}

inline CWsWindow *CWsWindow::NextSiblingMultiParent() const
	{
	return((CWsWindow *)CWsWindowBase::NextSiblingMultiParent());
	}

inline TBool CWsWindow::IsActive() const
	{
	return iFlags&EFlagActive;
	}

inline TBool CWsWindow::IsTranslucent() const
	{
	return (iFlags & static_cast<TUint>(EFlagHasAlpha)) != 0;
	}

inline TBool CWsWindow::HasAlpha() const
	{
	return (iFlags & static_cast<TUint>(EFlagHasAlpha)) !=0;
	}

inline TBool CWsWindow::HasBeenDrawnToScreen() const
	{
	return (iFlags & static_cast<TUint>(EFlagDrawnToScreen)) != 0;
	}

inline void CWsWindow::SetDrawnToScreen(TBool aDrawn)
	{
	if (aDrawn)
		iFlags |= static_cast<TUint>(EFlagDrawnToScreen);
	else
		iFlags &= ~static_cast<TUint>(EFlagDrawnToScreen);
	}

inline const TRegion& CWsWindow::ScheduledRegion() const
	{
	return iScheduledRegion;
	}

inline const TRegion& CWsWindow::ScheduledSpriteRegion() const
	{
	return iScheduledSpriteRegion;
	}

#if defined(_DEBUG)
inline const TSglQue<CWsDirectScreenAccess>& CWsWindow::DSAs() const
	{
	return iDSAs;
	}
#endif

inline TBool CWsWindow::IsNonFading() const
	{
	return (iFlags&EFlagNonFadingWindow);
	}
	
inline void CWsWindow::GetFadingParams(TUint8& aBlackMap,TUint8& aWhiteMap) const
    {aBlackMap=iBlackMap;aWhiteMap=iWhiteMap;}

inline TBool CWsWindow::HasElement() const
	{
	return (Redraw())?(Redraw()->HasElement()):(EFalse);
	}

inline TBool CWsWindow::IsFading() const
	{
	return (!IsNonFading() && (iFadeCount > 0));
	}

inline void CWsWindow::SetValidRedraw()
	{
	iFlags |= EFlagValidRedraw;
	}

inline TBool CWsWindow::IsValidRedraw() const
	{
	return (iFlags & EFlagValidRedraw);
	}

inline TBool CWsWindow::HasAnimation() const
	{
	return (NULL != iAnimList);
	}

inline TBool CWsWindow::IsBackgroundClearEnabled() const
	{
	return Redraw()->IsBackgroundClearEnabled();
	}

inline TBool CWsWindow::IsTrackingVisibleRegion() const
	{
	WS_ASSERT_DEBUG(iVisibleRegionTrackingCounter>=0,EWsPanicVisibleRegionTracking);
	return iVisibleRegionTrackingCounter;
	}

#endif