]> git.saurik.com Git - wxWidgets.git/blob - include/wx/dcbuffer.h
OS X savvy implementation
[wxWidgets.git] / include / wx / dcbuffer.h
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/dcbuffer.h
3 // Purpose: wxBufferedDC class
4 // Author: Ron Lee <ron@debian.org>
5 // Modified by: Vadim Zeitlin (refactored, added bg preservation)
6 // Created: 16/03/02
7 // RCS-ID: $Id$
8 // Copyright: (c) Ron Lee
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
11
12 #ifndef _WX_DCBUFFER_H_
13 #define _WX_DCBUFFER_H_
14
15 #include "wx/dcmemory.h"
16 #include "wx/dcclient.h"
17 #include "wx/window.h"
18
19 // ----------------------------------------------------------------------------
20 // Double buffering helper.
21 // ----------------------------------------------------------------------------
22
23 class wxBufferedDC : public wxMemoryDC
24 {
25 public:
26 // Default ctor, must subsequently call Init for two stage construction.
27 wxBufferedDC() : m_dc( 0 )
28 {
29 }
30
31 // Construct a wxBufferedDC using a user supplied buffer.
32 wxBufferedDC(wxDC *dc, const wxBitmap &buffer)
33 : m_dc( dc ),
34 m_buffer( buffer )
35 {
36 UseBuffer();
37 }
38
39 // Construct a wxBufferedDC with an internal buffer of 'area'
40 // (where area is usually something like the size of the window
41 // being buffered)
42 wxBufferedDC(wxDC *dc, const wxSize &area)
43 : m_dc( dc ),
44 m_buffer( area.GetWidth(), area.GetHeight() )
45 {
46 UseBuffer();
47 }
48
49 // default copy ctor ok.
50
51 // The usually desired action in the dtor is to blit the buffer.
52 virtual ~wxBufferedDC()
53 {
54 if ( m_dc ) UnMask();
55 }
56
57 // These reimplement the actions of the ctors for two stage creation, but
58 // are not used by the ctors themselves to save a few cpu cycles.
59 void Init(wxDC *dc, const wxBitmap &buffer)
60 {
61 wxASSERT_MSG( m_dc == 0 && m_buffer == wxNullBitmap,
62 _T("wxBufferedDC already initialised") );
63 m_dc = dc;
64 m_buffer = buffer;
65 UseBuffer();
66 }
67
68 void Init(wxDC *dc, const wxSize &area)
69 {
70 Init(dc, wxBitmap(area.GetWidth(), area.GetHeight()));
71 }
72
73 // Blits the buffer to the dc, and detaches the dc from the buffer (so it
74 // can be effectively used once only).
75 //
76 // Usually called in the dtor or by the dtor of derived classes if the
77 // BufferedDC must blit before the derived class (which may own the dc it's
78 // blitting to) is destroyed.
79 void UnMask()
80 {
81 wxASSERT_MSG( m_dc != 0,
82 _T("No underlying DC associated with wxBufferedDC (anymore)") );
83
84 m_dc->Blit( 0, 0,
85 m_buffer.GetWidth(), m_buffer.GetHeight(), this,
86 0, 0 );
87 m_dc = NULL;
88 }
89
90 private:
91 // check that the bitmap is valid and use it
92 void UseBuffer()
93 {
94 wxASSERT_MSG( m_buffer.Ok(), _T("invalid bitmap in wxBufferedDC") );
95
96 SelectObject(m_buffer);
97 }
98
99 // the underlying DC to which we copy everything drawn on this one in
100 // UnMask()
101 //
102 // NB: Without the existence of a wxNullDC, this must be a pointer, else it
103 // could probably be a reference.
104 wxDC *m_dc;
105
106 // the buffer (selected in this DC)
107 wxBitmap m_buffer;
108
109 DECLARE_NO_COPY_CLASS(wxBufferedDC)
110 };
111
112
113 // ----------------------------------------------------------------------------
114 // Double buffered PaintDC.
115 // ----------------------------------------------------------------------------
116
117 // Creates a double buffered wxPaintDC, optionally allowing the
118 // user to specify their own buffer to use.
119 class wxBufferedPaintDC : public wxBufferedDC
120 {
121 public:
122 // If no bitmap is supplied by the user, a temporary one wil; be created.
123 wxBufferedPaintDC(wxWindow *window, const wxBitmap& buffer = wxNullBitmap)
124 : m_paintdc(window)
125 {
126 window->PrepareDC( m_paintdc );
127
128 if( buffer != wxNullBitmap )
129 Init(&m_paintdc, buffer);
130 else
131 Init(&m_paintdc, window->GetClientSize());
132 }
133
134 // default copy ctor ok.
135
136 virtual ~wxBufferedPaintDC()
137 {
138 // We must UnMask here, else by the time the base class
139 // does it, the PaintDC will have already been destroyed.
140 UnMask();
141 }
142
143 private:
144 wxPaintDC m_paintdc;
145
146 DECLARE_NO_COPY_CLASS(wxBufferedPaintDC)
147 };
148
149 #endif // _WX_DCBUFFER_H_
150