epoc32/include/coeccntx.h
author William Roberts <williamr@symbian.org>
Tue, 16 Mar 2010 16:12:26 +0000
branchSymbian2
changeset 2 2fe1408b6811
parent 0 061f57f2323e
permissions -rw-r--r--
Final list of Symbian^2 public API header files
williamr@2
     1
// Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies).
williamr@2
     2
// All rights reserved.
williamr@2
     3
// This component and the accompanying materials are made available
williamr@2
     4
// under the terms of the License "Symbian Foundation License v1.0" to Symbian Foundation members and "Symbian Foundation End User License Agreement v1.0" to non-members
williamr@2
     5
// which accompanies this distribution, and is available
williamr@2
     6
// at the URL "http://www.symbianfoundation.org/legal/licencesv10.html".
williamr@2
     7
//
williamr@2
     8
// Initial Contributors:
williamr@2
     9
// Nokia Corporation - initial contribution.
williamr@2
    10
//
williamr@2
    11
// Contributors:
williamr@2
    12
//
williamr@2
    13
// Description:
williamr@2
    14
//
williamr@2
    15
williamr@2
    16
#ifndef __COECCNTX_H__
williamr@2
    17
#define __COECCNTX_H__
williamr@2
    18
williamr@2
    19
#include <e32std.h>
williamr@2
    20
#include <e32base.h>
williamr@2
    21
#include <w32std.h>
williamr@2
    22
williamr@2
    23
/** Interface to allow sharing of graphics settings between controls. 
williamr@2
    24
williamr@2
    25
The interface provides functions to set the graphics context of a control 
williamr@2
    26
before drawing. If a control has its iContext member set, the UI Control Framework 
williamr@2
    27
calls functions defined by this interface when a control is about to be drawn. 
williamr@2
    28
Developers must implement PrepareContext(), which is called by the framework, 
williamr@2
    29
to initialise the control's window with the required graphics settings.
williamr@2
    30
williamr@2
    31
To use control contexts, a control should inherit from an MCoeControlContext-derived 
williamr@2
    32
class. To share the context between controls, this control should then be 
williamr@2
    33
set as the context for all controls that wish to share it. This is done by 
williamr@2
    34
setting the iContext member of each of the controls, using CCoeControl::SetControlContext() 
williamr@2
    35
and CCoeControl::CopyControlContextFrom(). 
williamr@2
    36
williamr@2
    37
@publishedAll 
williamr@2
    38
@released */
williamr@2
    39
class MCoeControlContext
williamr@2
    40
	{
williamr@2
    41
public:
williamr@2
    42
	IMPORT_C virtual void ActivateContext(CWindowGc& aGc,RDrawableWindow& aWindow) const;
williamr@2
    43
	IMPORT_C virtual void ResetContext(CWindowGc& aGc) const;
williamr@2
    44
	IMPORT_C virtual void PrepareContext(CWindowGc& aGc) const;
williamr@2
    45
protected:
williamr@2
    46
	IMPORT_C MCoeControlContext();
williamr@2
    47
	
williamr@2
    48
private:
williamr@2
    49
	IMPORT_C virtual void MCoeControlContext_Reserved1();	
williamr@2
    50
	IMPORT_C virtual void MCoeControlContext_Reserved2();
williamr@2
    51
	
williamr@2
    52
private:
williamr@2
    53
	TInt iMCoeControlContext_Reserved1;
williamr@2
    54
	};
williamr@2
    55
williamr@2
    56
/** Brush and pen graphics context. 
williamr@2
    57
williamr@2
    58
This class allows an MCoeControlContext to be instantiated and used to set 
williamr@2
    59
brush and pen properties before drawing a control. 
williamr@2
    60
williamr@2
    61
@publishedAll 
williamr@2
    62
@released */
williamr@2
    63
class CCoeBrushAndPenContext : public CBase, public MCoeControlContext
williamr@2
    64
	{
williamr@2
    65
public:
williamr@2
    66
	IMPORT_C static CCoeBrushAndPenContext* NewL();
williamr@2
    67
	//
williamr@2
    68
	IMPORT_C void SetBrushStyle(CWindowGc::TBrushStyle aBrushStyle);
williamr@2
    69
	IMPORT_C void SetBrushColor(TRgb aColor);
williamr@2
    70
	IMPORT_C void SetBrushBitmap(const CFbsBitmap& aBitmap);
williamr@2
    71
	IMPORT_C void SetPenColor(TRgb aColor);
williamr@2
    72
	//
williamr@2
    73
	IMPORT_C CWindowGc::TBrushStyle BrushStyle() const;
williamr@2
    74
	IMPORT_C TRgb BrushColor() const;
williamr@2
    75
	IMPORT_C const CFbsBitmap& BrushBitmap() const;
williamr@2
    76
	IMPORT_C TRgb PenColor() const;
williamr@2
    77
protected: // from MCoeControlContext
williamr@2
    78
	IMPORT_C void PrepareContext(CWindowGc& aGc) const;
williamr@2
    79
private:
williamr@2
    80
	CCoeBrushAndPenContext();
williamr@2
    81
private:
williamr@2
    82
	CWindowGc::TBrushStyle iBrushStyle;
williamr@2
    83
	TRgb iBrushColor;
williamr@2
    84
	const CFbsBitmap* iBitmap;
williamr@2
    85
	TRgb iPenColor;
williamr@2
    86
	};
williamr@2
    87
williamr@2
    88
williamr@2
    89
/** Protocol for sharing brush settings used in graphics operations. 
williamr@2
    90
williamr@2
    91
It can be used to set brush and pen properties before drawing a control.
williamr@2
    92
williamr@2
    93
The mixin provides a default implementation of a control context. It implements 
williamr@2
    94
PrepareContext() to initialise brush settings used in graphics operations. 
williamr@2
    95
Its data members are public so that the brush style, brush colour and brush 
williamr@2
    96
pattern can be set by application code.
williamr@2
    97
williamr@2
    98
@publishedAll
williamr@2
    99
@deprecated */
williamr@2
   100
class MCoeControlBrushContext : public MCoeControlContext
williamr@2
   101
	{
williamr@2
   102
public:
williamr@2
   103
	/** Cause vtable & typeinfo to be exported */
williamr@2
   104
	IMPORT_C MCoeControlBrushContext();
williamr@2
   105
protected: // from MCoeControlContext
williamr@2
   106
	IMPORT_C void PrepareContext(CWindowGc& aGc) const;
williamr@2
   107
public:
williamr@2
   108
	/** Brush style. (Not required if iBitmap is set.) */
williamr@2
   109
	CWindowGc::TBrushStyle iBrushStyle;
williamr@2
   110
	/** Brush colour. (Not required if iBitmap is set.) */
williamr@2
   111
	TRgb iBrushColor;
williamr@2
   112
	/** Brush pattern. */
williamr@2
   113
	const CFbsBitmap* iBitmap;
williamr@2
   114
williamr@2
   115
private:
williamr@2
   116
	TInt iMCoeControlBrushContext_Reserved1;
williamr@2
   117
	};
williamr@2
   118
williamr@2
   119
#endif