- if (m_selected.Ok())
- {
- if (width) (*width) = m_selected.GetWidth();
- if (height) (*height) = m_selected.GetHeight();
- }
- else
- {
- if (width) (*width) = 0;
- if (height) (*height) = 0;
- }
+ if (m_selected.Ok() && m_selected.GetBitmap() && (*wxTRANSPARENT_BRUSH != brush))
+ {
+ if (*wxWHITE_BRUSH == brush)
+ wxWindowDC::SetBrush( *wxBLACK_BRUSH );
+ else
+ wxWindowDC::SetBrush( *wxWHITE_BRUSH );
+ }
+ else
+ {
+ wxWindowDC::SetBrush( brush );
+ }
+}
+
+void wxMemoryDC::SetTextForeground( const wxColour &col )
+{
+ if (m_selected.Ok() && m_selected.GetBitmap())
+ {
+ if (col == *wxWHITE)
+ wxWindowDC::SetTextForeground( *wxBLACK );
+ else
+ wxWindowDC::SetTextForeground( *wxWHITE );
+ }
+ else
+ {
+ wxWindowDC::SetTextForeground( col );
+ }
+}
+
+void wxMemoryDC::SetTextBackground( const wxColour &col )
+{
+ if (m_selected.Ok() && m_selected.GetBitmap())
+ {
+ if (col == *wxWHITE)
+ wxWindowDC::SetTextBackground( *wxBLACK );
+ else
+ wxWindowDC::SetTextBackground( *wxWHITE );
+ }
+ else
+ {
+ wxWindowDC::SetTextBackground( col );
+ }
+}
+
+void wxMemoryDC::DoGetSize( int *width, int *height ) const
+{
+ if (m_selected.Ok())
+ {
+ if (width) (*width) = m_selected.GetWidth();
+ if (height) (*height) = m_selected.GetHeight();
+ }
+ else
+ {
+ if (width) (*width) = 0;
+ if (height) (*height) = 0;
+ }