m_brush = *wxWHITE_BRUSH;
};
-wxMacPortSetter::wxMacPortSetter( wxDC* dc ) :
+wxMacPortSetter::wxMacPortSetter( const wxDC* dc ) :
m_ph( dc->m_macPort )
{
wxASSERT( dc->Ok() ) ;
void wxDC::MacSetupPort(AGAPortHelper* help) const
{
- help->Setup( m_macPort ) ;
+// help->Setup( m_macPort ) ;
::SetOrigin(-m_macLocalOrigin.h, -m_macLocalOrigin.v);
- ::ClipRect(&m_macClipRect);
+
+ if ( m_clipping )
+ {
+ long x1 = XLOG2DEV(m_clipX1);
+ long y1 = YLOG2DEV(m_clipY1);
+ long x2 = XLOG2DEV(m_clipX2);
+ long y2 = YLOG2DEV(m_clipY2);
+
+ Rect clip = { y1 , x1 , y2 , x2 } ;
+ ::SectRect( &clip , &m_macClipRect , &clip ) ;
+ ::ClipRect( &clip ) ;
+ }
+ else
+ {
+ ::ClipRect(&m_macClipRect);
+ }
+
m_macFontInstalled = false ;
m_macBrushInstalled = false ;
void wxDC::DoSetClippingRegion( wxCoord x, wxCoord y, wxCoord width, wxCoord height )
{
- wxMacPortSetter helper(this) ;
if( m_clipping )
{
m_clipX1 = wxMax( m_clipX1 , x ) ;
m_clipX2 = x + width;
m_clipY2 = y + height;
}
-
- long x1 = XLOG2DEV(m_clipX1);
- long y1 = YLOG2DEV(m_clipY1);
- long x2 = XLOG2DEV(m_clipX2);
- long y2 = YLOG2DEV(m_clipY2);
-
- Rect clip = { y1 , x1 , y2 , x2 } ;
-
- ::ClipRect( &clip ) ;
-
-};
+ };
void wxDC::DoSetClippingRegionAsRegion( const wxRegion ®ion )
{
{
wxMacPortSetter helper(this) ;
m_clipping = FALSE;
-// Rect clip = { -32000 , -32000 , 32000 , 32000 } ;
- ::ClipRect(&m_macClipRect);
};
void wxDC::DoGetSize( int* width, int* height ) const