wxWindow::ReParent()

wxDC::SetClippingRegio( region)
  lots if wxDC inline with wxPoint


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@1104 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Robert Roebling
1998-12-03 15:14:45 +00:00
parent 1cff61deed
commit 463c1fa1a9
19 changed files with 640 additions and 370 deletions

View File

@@ -57,133 +57,211 @@ class wxDC: public wxObject
{ {
DECLARE_ABSTRACT_CLASS(wxDC) DECLARE_ABSTRACT_CLASS(wxDC)
public: public:
wxDC(void); wxDC(void);
~wxDC(void); ~wxDC(void);
void BeginDrawing(void) {}; void BeginDrawing(void) {};
void EndDrawing(void) {}; void EndDrawing(void) {};
virtual bool Ok(void) const; virtual bool Ok(void) const;
virtual void FloodFill( long x1, long y1, wxColour *col, int style=wxFLOOD_SURFACE ) = 0; virtual void FloodFill( long x, long y, const wxColour& col, int style=wxFLOOD_SURFACE ) = 0;
virtual bool GetPixel( long x1, long y1, wxColour *col ) const = 0; inline void FloodFill(const wxPoint& pt, const wxColour& col, int style=wxFLOOD_SURFACE)
{
FloodFill(pt.x, pt.y, col, style);
}
virtual bool GetPixel( long x, long y, wxColour *col ) const = 0;
inline bool GetPixel(const wxPoint& pt, wxColour *col) const
{
return GetPixel(pt.x, pt.y, col);
}
virtual void DrawLine( long x1, long y1, long x2, long y2 ) = 0; virtual void DrawLine( long x1, long y1, long x2, long y2 ) = 0;
virtual void CrossHair( long x, long y ) = 0; inline void DrawLine(const wxPoint& pt1, const wxPoint& pt2)
virtual void DrawArc( long x1, long y1, long x2, long y2, double xc, double yc ); {
virtual void DrawEllipticArc( long x, long y, long width, long height, double sa, double ea ) = 0; DrawLine(pt1.x, pt1.y, pt2.x, pt2.y);
virtual void DrawPoint( long x, long y ) = 0; }
virtual void DrawPoint( wxPoint& point ); virtual void CrossHair( long x, long y ) = 0;
inline void CrossHair(const wxPoint& pt)
{
CrossHair(pt.x, pt.y);
}
virtual void DrawArc( long x1, long y1, long x2, long y2, double xc, double yc );
inline void DrawArc(const wxPoint& pt1, const wxPoint& pt2, const wxPoint& centre)
{
DrawArc(pt1.x, pt1.y, pt2.x, pt2.y, centre.x, centre.y);
}
virtual void DrawEllipticArc( long x, long y, long width, long height, double sa, double ea ) = 0;
virtual void DrawEllipticArc (const wxPoint& pt, const wxSize& sz, double sa, double ea)
{
DrawEllipticArc(pt.x, pt.y, sz.x, sz.y, sa, ea);
}
virtual void DrawPoint( long x, long y ) = 0;
inline void DrawPoint(const wxPoint& pt)
{
DrawPoint(pt.x, pt.y);
}
virtual void DrawPoint( wxPoint& point );
virtual void DrawLines( int n, wxPoint points[], long xoffset = 0, long yoffset = 0 ) = 0; virtual void DrawLines( int n, wxPoint points[], long xoffset = 0, long yoffset = 0 ) = 0;
virtual void DrawLines( wxList *points, long xoffset = 0, long yoffset = 0 ); virtual void DrawLines( wxList *points, long xoffset = 0, long yoffset = 0 );
virtual void DrawPolygon( int n, wxPoint points[], long xoffset = 0, long yoffset = 0, virtual void DrawPolygon( int n, wxPoint points[], long xoffset = 0, long yoffset = 0,
int fillStyle=wxODDEVEN_RULE ) = 0; int fillStyle=wxODDEVEN_RULE ) = 0;
virtual void DrawPolygon( wxList *lines, long xoffset = 0, long yoffset = 0, virtual void DrawPolygon( wxList *lines, long xoffset = 0, long yoffset = 0,
int fillStyle=wxODDEVEN_RULE ); int fillStyle=wxODDEVEN_RULE );
virtual void DrawRectangle( long x, long y, long width, long height ) = 0; virtual void DrawRectangle( long x, long y, long width, long height ) = 0;
virtual void DrawRoundedRectangle( long x, long y, long width, long height, double radius = 20.0 ) = 0; inline void DrawRectangle(const wxPoint& pt, const wxSize& sz)
virtual void DrawEllipse( long x, long y, long width, long height ) = 0; {
DrawRectangle(pt.x, pt.y, sz.x, sz.y);
}
inline void DrawRectangle(const wxRect& rect)
{
DrawRectangle(rect.x, rect.y, rect.width, rect.height);
}
virtual void DrawRoundedRectangle( long x, long y, long width, long height, double radius = 20.0 ) = 0;
inline void DrawRoundedRectangle(const wxPoint& pt, const wxSize& sz, double radius = 20.0)
{
DrawRoundedRectangle(pt.x, pt.y, sz.x, sz.y, radius);
}
inline void DrawRoundedRectangle(const wxRect& rect, double radius = 20.0)
{
DrawRoundedRectangle(rect.x, rect.y, rect.width, rect.height, radius);
}
virtual void DrawEllipse( long x, long y, long width, long height ) = 0;
inline void DrawEllipse(const wxPoint& pt, const wxSize& sz)
{
DrawEllipse(pt.x, pt.y, sz.x, sz.y);
}
inline void DrawEllipse(const wxRect& rect)
{
DrawEllipse(rect.x, rect.y, rect.width, rect.height);
}
virtual void DrawSpline( long x1, long y1, long x2, long y2, long x3, long y3 ); virtual void DrawSpline( long x1, long y1, long x2, long y2, long x3, long y3 );
virtual void DrawSpline( wxList *points ) = 0; virtual void DrawSpline( wxList *points ) = 0;
virtual void DrawSpline( int n, wxPoint points[] ); virtual void DrawSpline( int n, wxPoint points[] );
virtual bool CanDrawBitmap(void) const = 0; virtual bool CanDrawBitmap(void) const = 0;
virtual void DrawIcon( const wxIcon &icon, long x, long y ) virtual void DrawIcon( const wxIcon &icon, long x, long y ) = 0;
{ DrawIcon( icon, x, y, TRUE ); } inline void DrawIcon( const wxIcon& icon, const wxPoint& pt )
virtual void DrawIcon( const wxIcon &icon, long x, long y, bool useMask ); {
void DrawBitmap( const wxBitmap &bmp, long x, long y, bool useMask=FALSE ) DrawIcon(icon, pt.x, pt.y);
{ DrawIcon( *((wxIcon*)(&bmp)), x, y, useMask ); } }
virtual bool Blit( long xdest, long ydest, long width, long height, virtual void DrawBitmap( const wxBitmap &bmp, long x, long y, bool useMask=FALSE ) = 0;
wxDC *source, long xsrc, long ysrc, int logical_func = wxCOPY, bool useMask=FALSE ) = 0; inline void DrawBitmap( const wxBitmap& bitmap, const wxPoint& pt, bool useMask=FALSE )
{
DrawBitmap(bitmap, pt.x, pt.y, useMask );
}
virtual bool Blit( long xdest, long ydest,
long width, long height,
wxDC *source,
long xsrc, long ysrc,
int logical_func=wxCOPY,
bool useMask=FALSE ) = 0;
inline bool Blit( const wxPoint& destPt,
const wxSize& sz,
wxDC *source,
const wxPoint& srcPt,
int rop = wxCOPY,
bool useMask=FALSE)
{
return Blit(destPt.x, destPt.y, sz.x, sz.y, source, srcPt.x, srcPt.y, rop, useMask);
}
virtual void DrawText( const wxString &text, long x, long y, bool use16 = FALSE ) = 0; virtual void DrawText( const wxString &text, long x, long y, bool use16 = FALSE ) = 0;
virtual bool CanGetTextExtent(void) const = 0; inline void DrawText(const wxString& text, const wxPoint& pt, bool use16bit = FALSE )
virtual void GetTextExtent( const wxString &string, long *width, long *height, {
long *descent = (long *) NULL, long *externalLeading = (long *) NULL, DrawText(text, pt.x, pt.y, use16bit);
wxFont *theFont = (wxFont *) NULL, bool use16 = FALSE ) = 0; }
virtual long GetCharWidth(void) = 0; virtual bool CanGetTextExtent(void) const = 0;
virtual long GetCharHeight(void) = 0; virtual void GetTextExtent( const wxString &string,
long *width, long *height,
long *descent = (long *) NULL,
long *externalLeading = (long *) NULL,
wxFont *theFont = (wxFont *) NULL,
bool use16 = FALSE ) = 0;
virtual long GetCharWidth(void) = 0;
virtual long GetCharHeight(void) = 0;
virtual void Clear(void) = 0; virtual void Clear(void) = 0;
virtual void SetFont( const wxFont &font ) = 0; virtual void SetFont( const wxFont &font ) = 0;
virtual wxFont *GetFont(void) { return &m_font; }; virtual wxFont *GetFont(void) { return &m_font; };
virtual void SetPen( const wxPen &pen ) = 0; virtual void SetPen( const wxPen &pen ) = 0;
virtual wxPen *GetPen(void) { return &m_pen; }; virtual wxPen *GetPen(void) { return &m_pen; };
virtual void SetBrush( const wxBrush &brush ) = 0; virtual void SetBrush( const wxBrush &brush ) = 0;
virtual wxBrush *GetBrush(void) { return &m_brush; }; virtual wxBrush *GetBrush(void) { return &m_brush; };
virtual void SetBackground( const wxBrush &brush ) = 0; virtual void SetBackground( const wxBrush &brush ) = 0;
virtual wxBrush *GetBackground(void) { return &m_backgroundBrush; }; virtual wxBrush *GetBackground(void) { return &m_backgroundBrush; };
virtual void SetLogicalFunction( int function ) = 0; virtual void SetLogicalFunction( int function ) = 0;
virtual int GetLogicalFunction(void) { return m_logicalFunction; }; virtual int GetLogicalFunction(void) { return m_logicalFunction; };
virtual void SetTextForeground( const wxColour &col ); virtual void SetTextForeground( const wxColour &col );
virtual void SetTextBackground( const wxColour &col ); virtual void SetTextBackground( const wxColour &col );
virtual wxColour& GetTextBackground(void) const { return (wxColour&)m_textBackgroundColour; }; virtual wxColour& GetTextBackground(void) const { return (wxColour&)m_textBackgroundColour; };
virtual wxColour& GetTextForeground(void) const { return (wxColour&)m_textForegroundColour; }; virtual wxColour& GetTextForeground(void) const { return (wxColour&)m_textForegroundColour; };
virtual void SetBackgroundMode( int mode ) = 0; virtual void SetBackgroundMode( int mode ) = 0;
virtual int GetBackgroundMode(void) { return m_backgroundMode; }; virtual int GetBackgroundMode(void) { return m_backgroundMode; };
virtual void SetPalette( const wxPalette& palette ) = 0; virtual void SetPalette( const wxPalette& palette ) = 0;
void SetColourMap( const wxPalette& palette ) { SetPalette(palette); }; void SetColourMap( const wxPalette& palette ) { SetPalette(palette); };
// the first two must be overridden and called // the first two must be overridden and called
virtual void SetClippingRegion( long x, long y, long width, long height ); virtual void DestroyClippingRegion(void);
virtual void DestroyClippingRegion(void); virtual void SetClippingRegion( long x, long y, long width, long height );
virtual void GetClippingBox( long *x, long *y, long *width, long *height ) const; virtual void GetClippingBox( long *x, long *y, long *width, long *height ) const;
virtual void SetClippingRegion( const wxRegion &region ) = 0;
virtual inline long MinX(void) const { return m_minX; } virtual inline long MinX(void) const { return m_minX; }
virtual inline long MaxX(void) const { return m_maxX; } virtual inline long MaxX(void) const { return m_maxX; }
virtual inline long MinY(void) const { return m_minY; } virtual inline long MinY(void) const { return m_minY; }
virtual inline long MaxY(void) const { return m_maxY; } virtual inline long MaxY(void) const { return m_maxY; }
virtual void GetSize( int* width, int* height ) const; virtual void GetSize( int* width, int* height ) const;
inline wxSize GetSize(void) const { int w, h; GetSize(&w, &h); return wxSize(w, h); } inline wxSize GetSize(void) const { int w, h; GetSize(&w, &h); return wxSize(w, h); }
virtual void GetSizeMM( long* width, long* height ) const; virtual void GetSizeMM( long* width, long* height ) const;
virtual bool StartDoc( const wxString& WXUNUSED(message) ) { return TRUE; }; virtual bool StartDoc( const wxString& WXUNUSED(message) ) { return TRUE; };
virtual void EndDoc(void) {}; virtual void EndDoc(void) {};
virtual void StartPage(void) {}; virtual void StartPage(void) {};
virtual void EndPage(void) {}; virtual void EndPage(void) {};
virtual void SetMapMode( int mode ); virtual void SetMapMode( int mode );
virtual int GetMapMode(void) const { return m_mappingMode; }; virtual int GetMapMode(void) const { return m_mappingMode; };
virtual void SetUserScale( double x, double y ); virtual void SetUserScale( double x, double y );
virtual void GetUserScale( double *x, double *y ); virtual void GetUserScale( double *x, double *y );
virtual void SetLogicalScale( double x, double y ); virtual void SetLogicalScale( double x, double y );
virtual void GetLogicalScale( double *x, double *y ); virtual void GetLogicalScale( double *x, double *y );
virtual void SetLogicalOrigin( long x, long y ); virtual void SetLogicalOrigin( long x, long y );
virtual void GetLogicalOrigin( long *x, long *y ); virtual void GetLogicalOrigin( long *x, long *y );
virtual void SetDeviceOrigin( long x, long y ); virtual void SetDeviceOrigin( long x, long y );
virtual void GetDeviceOrigin( long *x, long *y ); virtual void GetDeviceOrigin( long *x, long *y );
virtual void SetAxisOrientation( bool xLeftRight, bool yBottomUp ); virtual void SetAxisOrientation( bool xLeftRight, bool yBottomUp );
virtual void SetOptimization( bool WXUNUSED(optimize) ) {}; virtual void SetOptimization( bool WXUNUSED(optimize) ) {};
virtual bool GetOptimization(void) { return m_optimize; }; virtual bool GetOptimization(void) { return m_optimize; };
virtual long DeviceToLogicalX(long x) const; virtual long DeviceToLogicalX(long x) const;
virtual long DeviceToLogicalY(long y) const; virtual long DeviceToLogicalY(long y) const;
virtual long DeviceToLogicalXRel(long x) const; virtual long DeviceToLogicalXRel(long x) const;
virtual long DeviceToLogicalYRel(long y) const; virtual long DeviceToLogicalYRel(long y) const;
virtual long LogicalToDeviceX(long x) const; virtual long LogicalToDeviceX(long x) const;
virtual long LogicalToDeviceY(long y) const; virtual long LogicalToDeviceY(long y) const;
virtual long LogicalToDeviceXRel(long x) const; virtual long LogicalToDeviceXRel(long x) const;
virtual long LogicalToDeviceYRel(long y) const; virtual long LogicalToDeviceYRel(long y) const;
public: // implementation
void CalcBoundingBox( long x, long y ); void CalcBoundingBox( long x, long y );
void ComputeScaleAndOrigin(void); void ComputeScaleAndOrigin(void);
@@ -279,7 +357,7 @@ class wxDC: public wxObject
// not sure what for, but what is a mm on a screen you don't know the size of? // not sure what for, but what is a mm on a screen you don't know the size of?
double m_mm_to_pix_x,m_mm_to_pix_y; double m_mm_to_pix_x,m_mm_to_pix_y;
long m_deviceOriginX,m_deviceOriginY; // Sum of the two above. long m_deviceOriginX,m_deviceOriginY;
long m_logicalOriginX,m_logicalOriginY; // User defined. long m_logicalOriginX,m_logicalOriginY; // User defined.

View File

@@ -40,7 +40,7 @@ public:
~wxWindowDC(void); ~wxWindowDC(void);
virtual void FloodFill( long x1, long y1, wxColour *col, int style=wxFLOOD_SURFACE ); virtual void FloodFill( long x, long y, const wxColour& col, int style=wxFLOOD_SURFACE );
virtual bool GetPixel( long x1, long y1, wxColour *col ) const; virtual bool GetPixel( long x1, long y1, wxColour *col ) const;
virtual void DrawLine( long x1, long y1, long x2, long y2 ); virtual void DrawLine( long x1, long y1, long x2, long y2 );
@@ -61,7 +61,8 @@ public:
virtual void DrawEllipse( long x, long y, long width, long height ); virtual void DrawEllipse( long x, long y, long width, long height );
virtual bool CanDrawBitmap(void) const; virtual bool CanDrawBitmap(void) const;
virtual void DrawIcon( const wxIcon &icon, long x, long y, bool useMask=FALSE ); virtual void DrawIcon( const wxIcon &icon, long x, long y );
virtual void DrawBitmap( const wxBitmap &bitmap, long x, long y, bool useMask=FALSE );
virtual bool Blit( long xdest, long ydest, long width, long height, virtual bool Blit( long xdest, long ydest, long width, long height,
wxDC *source, long xsrc, long ysrc, int logical_func = wxCOPY, bool useMask=FALSE ); wxDC *source, long xsrc, long ysrc, int logical_func = wxCOPY, bool useMask=FALSE );
@@ -87,6 +88,7 @@ public:
virtual void SetClippingRegion( long x, long y, long width, long height ); virtual void SetClippingRegion( long x, long y, long width, long height );
virtual void DestroyClippingRegion(void); virtual void DestroyClippingRegion(void);
virtual void SetClippingRegion( const wxRegion &region );
virtual void DrawSpline( wxList *points ); virtual void DrawSpline( wxList *points );

View File

@@ -165,6 +165,7 @@ public:
{ return (m_parent ? m_parent->m_parent : (wxWindow*)NULL); } { return (m_parent ? m_parent->m_parent : (wxWindow*)NULL); }
void SetParent( wxWindow *p ) void SetParent( wxWindow *p )
{ m_parent = p; } { m_parent = p; }
virtual wxWindow *ReParent( wxWindow *newParent );
wxEvtHandler *GetEventHandler(); wxEvtHandler *GetEventHandler();
void SetEventHandler( wxEvtHandler *handler ); void SetEventHandler( wxEvtHandler *handler );

View File

@@ -57,133 +57,211 @@ class wxDC: public wxObject
{ {
DECLARE_ABSTRACT_CLASS(wxDC) DECLARE_ABSTRACT_CLASS(wxDC)
public: public:
wxDC(void); wxDC(void);
~wxDC(void); ~wxDC(void);
void BeginDrawing(void) {}; void BeginDrawing(void) {};
void EndDrawing(void) {}; void EndDrawing(void) {};
virtual bool Ok(void) const; virtual bool Ok(void) const;
virtual void FloodFill( long x1, long y1, wxColour *col, int style=wxFLOOD_SURFACE ) = 0; virtual void FloodFill( long x, long y, const wxColour& col, int style=wxFLOOD_SURFACE ) = 0;
virtual bool GetPixel( long x1, long y1, wxColour *col ) const = 0; inline void FloodFill(const wxPoint& pt, const wxColour& col, int style=wxFLOOD_SURFACE)
{
FloodFill(pt.x, pt.y, col, style);
}
virtual bool GetPixel( long x, long y, wxColour *col ) const = 0;
inline bool GetPixel(const wxPoint& pt, wxColour *col) const
{
return GetPixel(pt.x, pt.y, col);
}
virtual void DrawLine( long x1, long y1, long x2, long y2 ) = 0; virtual void DrawLine( long x1, long y1, long x2, long y2 ) = 0;
virtual void CrossHair( long x, long y ) = 0; inline void DrawLine(const wxPoint& pt1, const wxPoint& pt2)
virtual void DrawArc( long x1, long y1, long x2, long y2, double xc, double yc ); {
virtual void DrawEllipticArc( long x, long y, long width, long height, double sa, double ea ) = 0; DrawLine(pt1.x, pt1.y, pt2.x, pt2.y);
virtual void DrawPoint( long x, long y ) = 0; }
virtual void DrawPoint( wxPoint& point ); virtual void CrossHair( long x, long y ) = 0;
inline void CrossHair(const wxPoint& pt)
{
CrossHair(pt.x, pt.y);
}
virtual void DrawArc( long x1, long y1, long x2, long y2, double xc, double yc );
inline void DrawArc(const wxPoint& pt1, const wxPoint& pt2, const wxPoint& centre)
{
DrawArc(pt1.x, pt1.y, pt2.x, pt2.y, centre.x, centre.y);
}
virtual void DrawEllipticArc( long x, long y, long width, long height, double sa, double ea ) = 0;
virtual void DrawEllipticArc (const wxPoint& pt, const wxSize& sz, double sa, double ea)
{
DrawEllipticArc(pt.x, pt.y, sz.x, sz.y, sa, ea);
}
virtual void DrawPoint( long x, long y ) = 0;
inline void DrawPoint(const wxPoint& pt)
{
DrawPoint(pt.x, pt.y);
}
virtual void DrawPoint( wxPoint& point );
virtual void DrawLines( int n, wxPoint points[], long xoffset = 0, long yoffset = 0 ) = 0; virtual void DrawLines( int n, wxPoint points[], long xoffset = 0, long yoffset = 0 ) = 0;
virtual void DrawLines( wxList *points, long xoffset = 0, long yoffset = 0 ); virtual void DrawLines( wxList *points, long xoffset = 0, long yoffset = 0 );
virtual void DrawPolygon( int n, wxPoint points[], long xoffset = 0, long yoffset = 0, virtual void DrawPolygon( int n, wxPoint points[], long xoffset = 0, long yoffset = 0,
int fillStyle=wxODDEVEN_RULE ) = 0; int fillStyle=wxODDEVEN_RULE ) = 0;
virtual void DrawPolygon( wxList *lines, long xoffset = 0, long yoffset = 0, virtual void DrawPolygon( wxList *lines, long xoffset = 0, long yoffset = 0,
int fillStyle=wxODDEVEN_RULE ); int fillStyle=wxODDEVEN_RULE );
virtual void DrawRectangle( long x, long y, long width, long height ) = 0; virtual void DrawRectangle( long x, long y, long width, long height ) = 0;
virtual void DrawRoundedRectangle( long x, long y, long width, long height, double radius = 20.0 ) = 0; inline void DrawRectangle(const wxPoint& pt, const wxSize& sz)
virtual void DrawEllipse( long x, long y, long width, long height ) = 0; {
DrawRectangle(pt.x, pt.y, sz.x, sz.y);
}
inline void DrawRectangle(const wxRect& rect)
{
DrawRectangle(rect.x, rect.y, rect.width, rect.height);
}
virtual void DrawRoundedRectangle( long x, long y, long width, long height, double radius = 20.0 ) = 0;
inline void DrawRoundedRectangle(const wxPoint& pt, const wxSize& sz, double radius = 20.0)
{
DrawRoundedRectangle(pt.x, pt.y, sz.x, sz.y, radius);
}
inline void DrawRoundedRectangle(const wxRect& rect, double radius = 20.0)
{
DrawRoundedRectangle(rect.x, rect.y, rect.width, rect.height, radius);
}
virtual void DrawEllipse( long x, long y, long width, long height ) = 0;
inline void DrawEllipse(const wxPoint& pt, const wxSize& sz)
{
DrawEllipse(pt.x, pt.y, sz.x, sz.y);
}
inline void DrawEllipse(const wxRect& rect)
{
DrawEllipse(rect.x, rect.y, rect.width, rect.height);
}
virtual void DrawSpline( long x1, long y1, long x2, long y2, long x3, long y3 ); virtual void DrawSpline( long x1, long y1, long x2, long y2, long x3, long y3 );
virtual void DrawSpline( wxList *points ) = 0; virtual void DrawSpline( wxList *points ) = 0;
virtual void DrawSpline( int n, wxPoint points[] ); virtual void DrawSpline( int n, wxPoint points[] );
virtual bool CanDrawBitmap(void) const = 0; virtual bool CanDrawBitmap(void) const = 0;
virtual void DrawIcon( const wxIcon &icon, long x, long y ) virtual void DrawIcon( const wxIcon &icon, long x, long y ) = 0;
{ DrawIcon( icon, x, y, TRUE ); } inline void DrawIcon( const wxIcon& icon, const wxPoint& pt )
virtual void DrawIcon( const wxIcon &icon, long x, long y, bool useMask ); {
void DrawBitmap( const wxBitmap &bmp, long x, long y, bool useMask=FALSE ) DrawIcon(icon, pt.x, pt.y);
{ DrawIcon( *((wxIcon*)(&bmp)), x, y, useMask ); } }
virtual bool Blit( long xdest, long ydest, long width, long height, virtual void DrawBitmap( const wxBitmap &bmp, long x, long y, bool useMask=FALSE ) = 0;
wxDC *source, long xsrc, long ysrc, int logical_func = wxCOPY, bool useMask=FALSE ) = 0; inline void DrawBitmap( const wxBitmap& bitmap, const wxPoint& pt, bool useMask=FALSE )
{
DrawBitmap(bitmap, pt.x, pt.y, useMask );
}
virtual bool Blit( long xdest, long ydest,
long width, long height,
wxDC *source,
long xsrc, long ysrc,
int logical_func=wxCOPY,
bool useMask=FALSE ) = 0;
inline bool Blit( const wxPoint& destPt,
const wxSize& sz,
wxDC *source,
const wxPoint& srcPt,
int rop = wxCOPY,
bool useMask=FALSE)
{
return Blit(destPt.x, destPt.y, sz.x, sz.y, source, srcPt.x, srcPt.y, rop, useMask);
}
virtual void DrawText( const wxString &text, long x, long y, bool use16 = FALSE ) = 0; virtual void DrawText( const wxString &text, long x, long y, bool use16 = FALSE ) = 0;
virtual bool CanGetTextExtent(void) const = 0; inline void DrawText(const wxString& text, const wxPoint& pt, bool use16bit = FALSE )
virtual void GetTextExtent( const wxString &string, long *width, long *height, {
long *descent = (long *) NULL, long *externalLeading = (long *) NULL, DrawText(text, pt.x, pt.y, use16bit);
wxFont *theFont = (wxFont *) NULL, bool use16 = FALSE ) = 0; }
virtual long GetCharWidth(void) = 0; virtual bool CanGetTextExtent(void) const = 0;
virtual long GetCharHeight(void) = 0; virtual void GetTextExtent( const wxString &string,
long *width, long *height,
long *descent = (long *) NULL,
long *externalLeading = (long *) NULL,
wxFont *theFont = (wxFont *) NULL,
bool use16 = FALSE ) = 0;
virtual long GetCharWidth(void) = 0;
virtual long GetCharHeight(void) = 0;
virtual void Clear(void) = 0; virtual void Clear(void) = 0;
virtual void SetFont( const wxFont &font ) = 0; virtual void SetFont( const wxFont &font ) = 0;
virtual wxFont *GetFont(void) { return &m_font; }; virtual wxFont *GetFont(void) { return &m_font; };
virtual void SetPen( const wxPen &pen ) = 0; virtual void SetPen( const wxPen &pen ) = 0;
virtual wxPen *GetPen(void) { return &m_pen; }; virtual wxPen *GetPen(void) { return &m_pen; };
virtual void SetBrush( const wxBrush &brush ) = 0; virtual void SetBrush( const wxBrush &brush ) = 0;
virtual wxBrush *GetBrush(void) { return &m_brush; }; virtual wxBrush *GetBrush(void) { return &m_brush; };
virtual void SetBackground( const wxBrush &brush ) = 0; virtual void SetBackground( const wxBrush &brush ) = 0;
virtual wxBrush *GetBackground(void) { return &m_backgroundBrush; }; virtual wxBrush *GetBackground(void) { return &m_backgroundBrush; };
virtual void SetLogicalFunction( int function ) = 0; virtual void SetLogicalFunction( int function ) = 0;
virtual int GetLogicalFunction(void) { return m_logicalFunction; }; virtual int GetLogicalFunction(void) { return m_logicalFunction; };
virtual void SetTextForeground( const wxColour &col ); virtual void SetTextForeground( const wxColour &col );
virtual void SetTextBackground( const wxColour &col ); virtual void SetTextBackground( const wxColour &col );
virtual wxColour& GetTextBackground(void) const { return (wxColour&)m_textBackgroundColour; }; virtual wxColour& GetTextBackground(void) const { return (wxColour&)m_textBackgroundColour; };
virtual wxColour& GetTextForeground(void) const { return (wxColour&)m_textForegroundColour; }; virtual wxColour& GetTextForeground(void) const { return (wxColour&)m_textForegroundColour; };
virtual void SetBackgroundMode( int mode ) = 0; virtual void SetBackgroundMode( int mode ) = 0;
virtual int GetBackgroundMode(void) { return m_backgroundMode; }; virtual int GetBackgroundMode(void) { return m_backgroundMode; };
virtual void SetPalette( const wxPalette& palette ) = 0; virtual void SetPalette( const wxPalette& palette ) = 0;
void SetColourMap( const wxPalette& palette ) { SetPalette(palette); }; void SetColourMap( const wxPalette& palette ) { SetPalette(palette); };
// the first two must be overridden and called // the first two must be overridden and called
virtual void SetClippingRegion( long x, long y, long width, long height ); virtual void DestroyClippingRegion(void);
virtual void DestroyClippingRegion(void); virtual void SetClippingRegion( long x, long y, long width, long height );
virtual void GetClippingBox( long *x, long *y, long *width, long *height ) const; virtual void GetClippingBox( long *x, long *y, long *width, long *height ) const;
virtual void SetClippingRegion( const wxRegion &region ) = 0;
virtual inline long MinX(void) const { return m_minX; } virtual inline long MinX(void) const { return m_minX; }
virtual inline long MaxX(void) const { return m_maxX; } virtual inline long MaxX(void) const { return m_maxX; }
virtual inline long MinY(void) const { return m_minY; } virtual inline long MinY(void) const { return m_minY; }
virtual inline long MaxY(void) const { return m_maxY; } virtual inline long MaxY(void) const { return m_maxY; }
virtual void GetSize( int* width, int* height ) const; virtual void GetSize( int* width, int* height ) const;
inline wxSize GetSize(void) const { int w, h; GetSize(&w, &h); return wxSize(w, h); } inline wxSize GetSize(void) const { int w, h; GetSize(&w, &h); return wxSize(w, h); }
virtual void GetSizeMM( long* width, long* height ) const; virtual void GetSizeMM( long* width, long* height ) const;
virtual bool StartDoc( const wxString& WXUNUSED(message) ) { return TRUE; }; virtual bool StartDoc( const wxString& WXUNUSED(message) ) { return TRUE; };
virtual void EndDoc(void) {}; virtual void EndDoc(void) {};
virtual void StartPage(void) {}; virtual void StartPage(void) {};
virtual void EndPage(void) {}; virtual void EndPage(void) {};
virtual void SetMapMode( int mode ); virtual void SetMapMode( int mode );
virtual int GetMapMode(void) const { return m_mappingMode; }; virtual int GetMapMode(void) const { return m_mappingMode; };
virtual void SetUserScale( double x, double y ); virtual void SetUserScale( double x, double y );
virtual void GetUserScale( double *x, double *y ); virtual void GetUserScale( double *x, double *y );
virtual void SetLogicalScale( double x, double y ); virtual void SetLogicalScale( double x, double y );
virtual void GetLogicalScale( double *x, double *y ); virtual void GetLogicalScale( double *x, double *y );
virtual void SetLogicalOrigin( long x, long y ); virtual void SetLogicalOrigin( long x, long y );
virtual void GetLogicalOrigin( long *x, long *y ); virtual void GetLogicalOrigin( long *x, long *y );
virtual void SetDeviceOrigin( long x, long y ); virtual void SetDeviceOrigin( long x, long y );
virtual void GetDeviceOrigin( long *x, long *y ); virtual void GetDeviceOrigin( long *x, long *y );
virtual void SetAxisOrientation( bool xLeftRight, bool yBottomUp ); virtual void SetAxisOrientation( bool xLeftRight, bool yBottomUp );
virtual void SetOptimization( bool WXUNUSED(optimize) ) {}; virtual void SetOptimization( bool WXUNUSED(optimize) ) {};
virtual bool GetOptimization(void) { return m_optimize; }; virtual bool GetOptimization(void) { return m_optimize; };
virtual long DeviceToLogicalX(long x) const; virtual long DeviceToLogicalX(long x) const;
virtual long DeviceToLogicalY(long y) const; virtual long DeviceToLogicalY(long y) const;
virtual long DeviceToLogicalXRel(long x) const; virtual long DeviceToLogicalXRel(long x) const;
virtual long DeviceToLogicalYRel(long y) const; virtual long DeviceToLogicalYRel(long y) const;
virtual long LogicalToDeviceX(long x) const; virtual long LogicalToDeviceX(long x) const;
virtual long LogicalToDeviceY(long y) const; virtual long LogicalToDeviceY(long y) const;
virtual long LogicalToDeviceXRel(long x) const; virtual long LogicalToDeviceXRel(long x) const;
virtual long LogicalToDeviceYRel(long y) const; virtual long LogicalToDeviceYRel(long y) const;
public: // implementation
void CalcBoundingBox( long x, long y ); void CalcBoundingBox( long x, long y );
void ComputeScaleAndOrigin(void); void ComputeScaleAndOrigin(void);
@@ -279,7 +357,7 @@ class wxDC: public wxObject
// not sure what for, but what is a mm on a screen you don't know the size of? // not sure what for, but what is a mm on a screen you don't know the size of?
double m_mm_to_pix_x,m_mm_to_pix_y; double m_mm_to_pix_x,m_mm_to_pix_y;
long m_deviceOriginX,m_deviceOriginY; // Sum of the two above. long m_deviceOriginX,m_deviceOriginY;
long m_logicalOriginX,m_logicalOriginY; // User defined. long m_logicalOriginX,m_logicalOriginY; // User defined.

View File

@@ -40,7 +40,7 @@ public:
~wxWindowDC(void); ~wxWindowDC(void);
virtual void FloodFill( long x1, long y1, wxColour *col, int style=wxFLOOD_SURFACE ); virtual void FloodFill( long x, long y, const wxColour& col, int style=wxFLOOD_SURFACE );
virtual bool GetPixel( long x1, long y1, wxColour *col ) const; virtual bool GetPixel( long x1, long y1, wxColour *col ) const;
virtual void DrawLine( long x1, long y1, long x2, long y2 ); virtual void DrawLine( long x1, long y1, long x2, long y2 );
@@ -61,7 +61,8 @@ public:
virtual void DrawEllipse( long x, long y, long width, long height ); virtual void DrawEllipse( long x, long y, long width, long height );
virtual bool CanDrawBitmap(void) const; virtual bool CanDrawBitmap(void) const;
virtual void DrawIcon( const wxIcon &icon, long x, long y, bool useMask=FALSE ); virtual void DrawIcon( const wxIcon &icon, long x, long y );
virtual void DrawBitmap( const wxBitmap &bitmap, long x, long y, bool useMask=FALSE );
virtual bool Blit( long xdest, long ydest, long width, long height, virtual bool Blit( long xdest, long ydest, long width, long height,
wxDC *source, long xsrc, long ysrc, int logical_func = wxCOPY, bool useMask=FALSE ); wxDC *source, long xsrc, long ysrc, int logical_func = wxCOPY, bool useMask=FALSE );
@@ -87,6 +88,7 @@ public:
virtual void SetClippingRegion( long x, long y, long width, long height ); virtual void SetClippingRegion( long x, long y, long width, long height );
virtual void DestroyClippingRegion(void); virtual void DestroyClippingRegion(void);
virtual void SetClippingRegion( const wxRegion &region );
virtual void DrawSpline( wxList *points ); virtual void DrawSpline( wxList *points );

View File

@@ -165,6 +165,7 @@ public:
{ return (m_parent ? m_parent->m_parent : (wxWindow*)NULL); } { return (m_parent ? m_parent->m_parent : (wxWindow*)NULL); }
void SetParent( wxWindow *p ) void SetParent( wxWindow *p )
{ m_parent = p; } { m_parent = p; }
virtual wxWindow *ReParent( wxWindow *newParent );
wxEvtHandler *GetEventHandler(); wxEvtHandler *GetEventHandler();
void SetEventHandler( wxEvtHandler *handler ); void SetEventHandler( wxEvtHandler *handler );

View File

@@ -61,7 +61,7 @@ class WXDLLEXPORT wxPostScriptDC: public wxDC
inline virtual void BeginDrawing(void) {} ; inline virtual void BeginDrawing(void) {} ;
inline virtual void EndDrawing(void) {} ; inline virtual void EndDrawing(void) {} ;
void FloodFill(long x1, long y1, wxColour *col, int style=wxFLOOD_SURFACE) ; void FloodFill(long x1, long y1, const wxColour &col, int style=wxFLOOD_SURFACE) ;
bool GetPixel(long x1, long y1, wxColour *col) const; bool GetPixel(long x1, long y1, wxColour *col) const;
void DrawLine(long x1, long y1, long x2, long y2); void DrawLine(long x1, long y1, long x2, long y2);
@@ -85,11 +85,8 @@ class WXDLLEXPORT wxPostScriptDC: public wxDC
void DrawSpline(wxList *points); void DrawSpline(wxList *points);
void DrawIcon(const wxIcon& icon, long x, long y); void DrawIcon( const wxIcon& icon, long x, long y );
#ifdef __WXGTK__ void DrawBitmap( const wxBitmap& bitmap, long x, long y, bool useMask=FALSE );
void DrawIcon(const wxIcon& icon, long x, long y, bool WXUNUSED(usemask) )
{ DrawIcon( icon, x, y ); }
#endif
void DrawText(const wxString& text, long x, long y, bool use16 = FALSE); void DrawText(const wxString& text, long x, long y, bool use16 = FALSE);
void Clear(); void Clear();
@@ -98,7 +95,9 @@ class WXDLLEXPORT wxPostScriptDC: public wxDC
void SetBrush(const wxBrush& brush); void SetBrush(const wxBrush& brush);
void SetLogicalFunction(int function); void SetLogicalFunction(int function);
void SetBackground(const wxBrush& brush); void SetBackground(const wxBrush& brush);
void SetClippingRegion(long x, long y, long width, long height); void SetClippingRegion(long x, long y, long width, long height);
void SetClippingRegion( const wxRegion &region );
void DestroyClippingRegion(); void DestroyClippingRegion();
bool StartDoc(const wxString& message); bool StartDoc(const wxString& message);

View File

@@ -304,6 +304,10 @@ void wxPostScriptDC::SetClippingRegion (long cx, long cy, long cw, long ch)
*m_pstream << "closepath clip newpath\n"; *m_pstream << "closepath clip newpath\n";
} }
void wxPostScriptDC::SetClippingRegion( const wxRegion &WXUNUSED(region) )
{
}
void wxPostScriptDC::DestroyClippingRegion () void wxPostScriptDC::DestroyClippingRegion ()
{ {
if (!m_pstream) if (!m_pstream)
@@ -319,7 +323,7 @@ void wxPostScriptDC::Clear ()
{ {
} }
void wxPostScriptDC::FloodFill (long WXUNUSED(x), long WXUNUSED(y), wxColour * WXUNUSED(col), int WXUNUSED(style)) void wxPostScriptDC::FloodFill (long WXUNUSED(x), long WXUNUSED(y), const wxColour &WXUNUSED(col), int WXUNUSED(style))
{ {
} }
@@ -685,6 +689,10 @@ void wxPostScriptDC::DrawIcon (const wxIcon& icon, long x, long y)
#endif #endif
} }
void wxPostScriptDC::DrawBitmap( const wxBitmap& bitmap, long x, long y, bool useMask )
{
}
void wxPostScriptDC::SetFont (const wxFont& the_font) void wxPostScriptDC::SetFont (const wxFont& the_font)
{ {
if (!m_pstream) if (!m_pstream)

View File

@@ -113,8 +113,7 @@ bool wxImageList::Draw( int index, wxDC &dc, int x, int y,
if (!node) return FALSE; if (!node) return FALSE;
wxBitmap *bm = (wxBitmap*)node->Data(); wxBitmap *bm = (wxBitmap*)node->Data();
wxIcon *icon = (wxIcon*)bm; dc.DrawBitmap( *bm, x, y, (flags & wxIMAGELIST_DRAW_TRANSPARENT) > 0 );
dc.DrawIcon( *icon, x, y, (flags & wxIMAGELIST_DRAW_TRANSPARENT) > 0 );
return TRUE; return TRUE;
} }

View File

@@ -2,9 +2,9 @@
NONE = NONE =
# define library name # define library name
LIB_TARGET=wx_gtk LIB_TARGET=wx_gtk_1_0
LIB_MAJOR=1 LIB_MAJOR=1
LIB_MINOR=97 LIB_MINOR=99
# define library sources # define library sources

View File

@@ -93,10 +93,6 @@ void wxDC::DrawArc( long WXUNUSED(x1), long WXUNUSED(y1), long WXUNUSED(x2), lon
{ {
} }
void wxDC::DrawIcon( const wxIcon &WXUNUSED(icon), long WXUNUSED(x), long WXUNUSED(y), bool WXUNUSED(useMask) )
{
}
void wxDC::DrawPoint( wxPoint& point ) void wxDC::DrawPoint( wxPoint& point )
{ {
DrawPoint( point.x, point.y ); DrawPoint( point.x, point.y );

View File

@@ -116,15 +116,6 @@ wxWindowDC::wxWindowDC( wxWindow *window )
SetUpDC(); SetUpDC();
/*
wxRegion update = window->GetUpdateRegion();
if (update.Empty()) return;
gdk_gc_set_clip_region( m_penGC, update.GetRegion() );
gdk_gc_set_clip_region( m_brushGC, update.GetRegion() );
gdk_gc_set_clip_region( m_textGC, update.GetRegion() );
gdk_gc_set_clip_region( m_bgGC, update.GetRegion() );
*/
} }
wxWindowDC::~wxWindowDC(void) wxWindowDC::~wxWindowDC(void)
@@ -132,8 +123,8 @@ wxWindowDC::~wxWindowDC(void)
Destroy(); Destroy();
} }
void wxWindowDC::FloodFill( long WXUNUSED(x1), long WXUNUSED(y1), void wxWindowDC::FloodFill( long WXUNUSED(x), long WXUNUSED(y),
wxColour *WXUNUSED(col), int WXUNUSED(style) ) const wxColour &WXUNUSED(col), int WXUNUSED(style) )
{ {
wxFAIL_MSG( "wxWindowDC::FloodFill not implemented" ); wxFAIL_MSG( "wxWindowDC::FloodFill not implemented" );
} }
@@ -505,7 +496,7 @@ bool wxWindowDC::CanDrawBitmap(void) const
return TRUE; return TRUE;
} }
void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y, bool useMask ) void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y )
{ {
if (!Ok()) return; if (!Ok()) return;
@@ -517,7 +508,7 @@ void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y, bool useMask )
GdkBitmap *mask = (GdkBitmap *) NULL; GdkBitmap *mask = (GdkBitmap *) NULL;
if (icon.GetMask()) mask = icon.GetMask()->GetBitmap(); if (icon.GetMask()) mask = icon.GetMask()->GetBitmap();
if (useMask && mask) if (mask)
{ {
gdk_gc_set_clip_mask( m_penGC, mask ); gdk_gc_set_clip_mask( m_penGC, mask );
gdk_gc_set_clip_origin( m_penGC, xx, yy ); gdk_gc_set_clip_origin( m_penGC, xx, yy );
@@ -526,6 +517,39 @@ void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y, bool useMask )
GdkPixmap *pm = icon.GetPixmap(); GdkPixmap *pm = icon.GetPixmap();
gdk_draw_pixmap( m_window, m_penGC, pm, 0, 0, xx, yy, -1, -1 ); gdk_draw_pixmap( m_window, m_penGC, pm, 0, 0, xx, yy, -1, -1 );
if (mask)
{
gdk_gc_set_clip_mask( m_penGC, (GdkBitmap *) NULL );
gdk_gc_set_clip_origin( m_penGC, 0, 0 );
}
CalcBoundingBox( x, y );
int width = icon.GetWidth();
int height = icon.GetHeight();
CalcBoundingBox( x + width, y + height );
}
void wxWindowDC::DrawBitmap( const wxBitmap &bitmap, long x, long y, bool useMask )
{
if (!Ok()) return;
if (!bitmap.Ok()) return;
int xx = XLOG2DEV(x);
int yy = YLOG2DEV(y);
GdkBitmap *mask = (GdkBitmap *) NULL;
if (bitmap.GetMask()) mask = bitmap.GetMask()->GetBitmap();
if (useMask && mask)
{
gdk_gc_set_clip_mask( m_penGC, mask );
gdk_gc_set_clip_origin( m_penGC, xx, yy );
}
GdkPixmap *pm = bitmap.GetPixmap();
gdk_draw_pixmap( m_window, m_penGC, pm, 0, 0, xx, yy, -1, -1 );
if (useMask && mask) if (useMask && mask)
{ {
gdk_gc_set_clip_mask( m_penGC, (GdkBitmap *) NULL ); gdk_gc_set_clip_mask( m_penGC, (GdkBitmap *) NULL );
@@ -533,8 +557,8 @@ void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y, bool useMask )
} }
CalcBoundingBox( x, y ); CalcBoundingBox( x, y );
int width = icon.GetWidth(); int width = bitmap.GetWidth();
int height = icon.GetHeight(); int height = bitmap.GetHeight();
CalcBoundingBox( x + width, y + height ); CalcBoundingBox( x + width, y + height );
} }
@@ -941,6 +965,20 @@ void wxWindowDC::SetClippingRegion( long x, long y, long width, long height )
gdk_gc_set_clip_rectangle( m_bgGC, &rect ); gdk_gc_set_clip_rectangle( m_bgGC, &rect );
} }
void wxWindowDC::SetClippingRegion( const wxRegion &region )
{
if (region.Empty())
{
DestroyClippingRegion();
return;
}
gdk_gc_set_clip_region( m_penGC, region.GetRegion() );
gdk_gc_set_clip_region( m_brushGC, region.GetRegion() );
gdk_gc_set_clip_region( m_textGC, region.GetRegion() );
gdk_gc_set_clip_region( m_bgGC, region.GetRegion() );
}
void wxWindowDC::DestroyClippingRegion(void) void wxWindowDC::DestroyClippingRegion(void)
{ {
wxDC::DestroyClippingRegion(); wxDC::DestroyClippingRegion();

View File

@@ -211,7 +211,7 @@ gtk_myfixed_move (GtkMyFixed *myfixed,
if (child->widget == widget) if (child->widget == widget)
{ {
/* if ((child->x == x) && (child->y == y)) return; */ if ((child->x == x) && (child->y == y)) return;
child->x = x; child->x = x;
child->y = y; child->y = y;

View File

@@ -1729,38 +1729,38 @@ int wxWindow::GetCharHeight() const
int wxWindow::GetCharWidth() const int wxWindow::GetCharWidth() const
{ {
wxASSERT_MSG( (m_widget != NULL), "invalid window" ); wxASSERT_MSG( (m_widget != NULL), "invalid window" );
if (!m_font.Ok()) if (!m_font.Ok())
{ {
wxFAIL_MSG( "invalid font" ); wxFAIL_MSG( "invalid font" );
return -1; return -1;
} }
GdkFont *font = m_font.GetInternalFont( 1.0 ); GdkFont *font = m_font.GetInternalFont( 1.0 );
return gdk_string_width( font, "H" ); return gdk_string_width( font, "H" );
} }
void wxWindow::GetTextExtent( const wxString& string, int *x, int *y, void wxWindow::GetTextExtent( const wxString& string, int *x, int *y,
int *descent, int *externalLeading, const wxFont *theFont, bool WXUNUSED(use16) ) const int *descent, int *externalLeading, const wxFont *theFont, bool WXUNUSED(use16) ) const
{ {
wxASSERT_MSG( (m_widget != NULL), "invalid window" ); wxASSERT_MSG( (m_widget != NULL), "invalid window" );
wxFont fontToUse = m_font; wxFont fontToUse = m_font;
if (theFont) fontToUse = *theFont; if (theFont) fontToUse = *theFont;
if (!fontToUse.Ok()) if (!fontToUse.Ok())
{ {
wxFAIL_MSG( "invalid font" ); wxFAIL_MSG( "invalid font" );
return; return;
} }
wxASSERT_MSG( (m_font.Ok()), "invalid font" ); wxASSERT_MSG( (m_font.Ok()), "invalid font" );
GdkFont *font = fontToUse.GetInternalFont( 1.0 ); GdkFont *font = fontToUse.GetInternalFont( 1.0 );
if (x) (*x) = gdk_string_width( font, string ); if (x) (*x) = gdk_string_width( font, string );
if (y) (*y) = font->ascent + font->descent; if (y) (*y) = font->ascent + font->descent;
if (descent) (*descent) = font->descent; if (descent) (*descent) = font->descent;
if (externalLeading) (*externalLeading) = 0; // ?? if (externalLeading) (*externalLeading) = 0; // ??
} }
void wxWindow::MakeModal( bool modal ) void wxWindow::MakeModal( bool modal )
@@ -1783,105 +1783,122 @@ void wxWindow::MakeModal( bool modal )
void wxWindow::SetFocus() void wxWindow::SetFocus()
{ {
wxASSERT_MSG( (m_widget != NULL), "invalid window" ); wxASSERT_MSG( (m_widget != NULL), "invalid window" );
GtkWidget *connect_widget = GetConnectWidget(); GtkWidget *connect_widget = GetConnectWidget();
if (connect_widget) if (connect_widget)
{
if (GTK_WIDGET_CAN_FOCUS(connect_widget) && !GTK_WIDGET_HAS_FOCUS (connect_widget) )
{ {
gtk_widget_grab_focus (connect_widget); if (GTK_WIDGET_CAN_FOCUS(connect_widget) && !GTK_WIDGET_HAS_FOCUS (connect_widget) )
{
gtk_widget_grab_focus (connect_widget);
}
} }
}
} }
bool wxWindow::OnClose() bool wxWindow::OnClose()
{ {
return TRUE; return TRUE;
} }
void wxWindow::AddChild( wxWindow *child ) void wxWindow::AddChild( wxWindow *child )
{ {
wxASSERT_MSG( (m_widget != NULL), "invalid window" ); wxASSERT_MSG( (m_widget != NULL), "invalid window" );
wxASSERT_MSG( (child != NULL), "invalid child" ); wxASSERT_MSG( (child != NULL), "invalid child" );
m_children.Append( child ); m_children.Append( child );
} }
wxList *wxWindow::GetChildren() wxList *wxWindow::GetChildren()
{ {
return (&m_children); return (&m_children);
}
wxWindow *wxWindow::ReParent( wxWindow *newParent )
{
wxWindow *oldParent = GetParent();
if (oldParent) oldParent->RemoveChild( this );
gtk_widget_unparent( m_widget );
if (newParent)
{
newParent->AddChild( this );
(newParent->m_insertCallback)( newParent, this );
}
return oldParent;
} }
void wxWindow::RemoveChild( wxWindow *child ) void wxWindow::RemoveChild( wxWindow *child )
{ {
if (GetChildren()) GetChildren()->DeleteObject( child ); if (GetChildren()) GetChildren()->DeleteObject( child );
child->m_parent = (wxWindow *) NULL; child->m_parent = (wxWindow *) NULL;
} }
void wxWindow::SetReturnCode( int retCode ) void wxWindow::SetReturnCode( int retCode )
{ {
m_retCode = retCode; m_retCode = retCode;
} }
int wxWindow::GetReturnCode() int wxWindow::GetReturnCode()
{ {
return m_retCode; return m_retCode;
} }
void wxWindow::Raise() void wxWindow::Raise()
{ {
wxASSERT_MSG( (m_widget != NULL), "invalid window" ); wxASSERT_MSG( (m_widget != NULL), "invalid window" );
if (m_widget) gdk_window_raise( m_widget->window ); if (m_widget) gdk_window_raise( m_widget->window );
} }
void wxWindow::Lower() void wxWindow::Lower()
{ {
wxASSERT_MSG( (m_widget != NULL), "invalid window" ); wxASSERT_MSG( (m_widget != NULL), "invalid window" );
if (m_widget) gdk_window_lower( m_widget->window ); if (m_widget) gdk_window_lower( m_widget->window );
} }
wxEvtHandler *wxWindow::GetEventHandler() wxEvtHandler *wxWindow::GetEventHandler()
{ {
return m_eventHandler; return m_eventHandler;
} }
void wxWindow::SetEventHandler( wxEvtHandler *handler ) void wxWindow::SetEventHandler( wxEvtHandler *handler )
{ {
m_eventHandler = handler; m_eventHandler = handler;
} }
void wxWindow::PushEventHandler(wxEvtHandler *handler) void wxWindow::PushEventHandler(wxEvtHandler *handler)
{ {
handler->SetNextHandler(GetEventHandler()); handler->SetNextHandler(GetEventHandler());
SetEventHandler(handler); SetEventHandler(handler);
} }
wxEvtHandler *wxWindow::PopEventHandler(bool deleteHandler) wxEvtHandler *wxWindow::PopEventHandler(bool deleteHandler)
{ {
if (GetEventHandler()) if (GetEventHandler())
{
wxEvtHandler *handlerA = GetEventHandler();
wxEvtHandler *handlerB = handlerA->GetNextHandler();
handlerA->SetNextHandler((wxEvtHandler *) NULL);
SetEventHandler(handlerB);
if (deleteHandler)
{ {
delete handlerA; wxEvtHandler *handlerA = GetEventHandler();
return (wxEvtHandler*) NULL; wxEvtHandler *handlerB = handlerA->GetNextHandler();
} handlerA->SetNextHandler((wxEvtHandler *) NULL);
else SetEventHandler(handlerB);
return handlerA; if (deleteHandler)
} {
else delete handlerA;
return (wxEvtHandler *) NULL; return (wxEvtHandler*) NULL;
}
else
return handlerA;
}
else
return (wxEvtHandler *) NULL;
} }
wxValidator *wxWindow::GetValidator() wxValidator *wxWindow::GetValidator()
{ {
return m_windowValidator; return m_windowValidator;
} }
void wxWindow::SetValidator( const wxValidator& validator ) void wxWindow::SetValidator( const wxValidator& validator )

View File

@@ -93,10 +93,6 @@ void wxDC::DrawArc( long WXUNUSED(x1), long WXUNUSED(y1), long WXUNUSED(x2), lon
{ {
} }
void wxDC::DrawIcon( const wxIcon &WXUNUSED(icon), long WXUNUSED(x), long WXUNUSED(y), bool WXUNUSED(useMask) )
{
}
void wxDC::DrawPoint( wxPoint& point ) void wxDC::DrawPoint( wxPoint& point )
{ {
DrawPoint( point.x, point.y ); DrawPoint( point.x, point.y );

View File

@@ -116,15 +116,6 @@ wxWindowDC::wxWindowDC( wxWindow *window )
SetUpDC(); SetUpDC();
/*
wxRegion update = window->GetUpdateRegion();
if (update.Empty()) return;
gdk_gc_set_clip_region( m_penGC, update.GetRegion() );
gdk_gc_set_clip_region( m_brushGC, update.GetRegion() );
gdk_gc_set_clip_region( m_textGC, update.GetRegion() );
gdk_gc_set_clip_region( m_bgGC, update.GetRegion() );
*/
} }
wxWindowDC::~wxWindowDC(void) wxWindowDC::~wxWindowDC(void)
@@ -132,8 +123,8 @@ wxWindowDC::~wxWindowDC(void)
Destroy(); Destroy();
} }
void wxWindowDC::FloodFill( long WXUNUSED(x1), long WXUNUSED(y1), void wxWindowDC::FloodFill( long WXUNUSED(x), long WXUNUSED(y),
wxColour *WXUNUSED(col), int WXUNUSED(style) ) const wxColour &WXUNUSED(col), int WXUNUSED(style) )
{ {
wxFAIL_MSG( "wxWindowDC::FloodFill not implemented" ); wxFAIL_MSG( "wxWindowDC::FloodFill not implemented" );
} }
@@ -505,7 +496,7 @@ bool wxWindowDC::CanDrawBitmap(void) const
return TRUE; return TRUE;
} }
void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y, bool useMask ) void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y )
{ {
if (!Ok()) return; if (!Ok()) return;
@@ -517,7 +508,7 @@ void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y, bool useMask )
GdkBitmap *mask = (GdkBitmap *) NULL; GdkBitmap *mask = (GdkBitmap *) NULL;
if (icon.GetMask()) mask = icon.GetMask()->GetBitmap(); if (icon.GetMask()) mask = icon.GetMask()->GetBitmap();
if (useMask && mask) if (mask)
{ {
gdk_gc_set_clip_mask( m_penGC, mask ); gdk_gc_set_clip_mask( m_penGC, mask );
gdk_gc_set_clip_origin( m_penGC, xx, yy ); gdk_gc_set_clip_origin( m_penGC, xx, yy );
@@ -526,6 +517,39 @@ void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y, bool useMask )
GdkPixmap *pm = icon.GetPixmap(); GdkPixmap *pm = icon.GetPixmap();
gdk_draw_pixmap( m_window, m_penGC, pm, 0, 0, xx, yy, -1, -1 ); gdk_draw_pixmap( m_window, m_penGC, pm, 0, 0, xx, yy, -1, -1 );
if (mask)
{
gdk_gc_set_clip_mask( m_penGC, (GdkBitmap *) NULL );
gdk_gc_set_clip_origin( m_penGC, 0, 0 );
}
CalcBoundingBox( x, y );
int width = icon.GetWidth();
int height = icon.GetHeight();
CalcBoundingBox( x + width, y + height );
}
void wxWindowDC::DrawBitmap( const wxBitmap &bitmap, long x, long y, bool useMask )
{
if (!Ok()) return;
if (!bitmap.Ok()) return;
int xx = XLOG2DEV(x);
int yy = YLOG2DEV(y);
GdkBitmap *mask = (GdkBitmap *) NULL;
if (bitmap.GetMask()) mask = bitmap.GetMask()->GetBitmap();
if (useMask && mask)
{
gdk_gc_set_clip_mask( m_penGC, mask );
gdk_gc_set_clip_origin( m_penGC, xx, yy );
}
GdkPixmap *pm = bitmap.GetPixmap();
gdk_draw_pixmap( m_window, m_penGC, pm, 0, 0, xx, yy, -1, -1 );
if (useMask && mask) if (useMask && mask)
{ {
gdk_gc_set_clip_mask( m_penGC, (GdkBitmap *) NULL ); gdk_gc_set_clip_mask( m_penGC, (GdkBitmap *) NULL );
@@ -533,8 +557,8 @@ void wxWindowDC::DrawIcon( const wxIcon &icon, long x, long y, bool useMask )
} }
CalcBoundingBox( x, y ); CalcBoundingBox( x, y );
int width = icon.GetWidth(); int width = bitmap.GetWidth();
int height = icon.GetHeight(); int height = bitmap.GetHeight();
CalcBoundingBox( x + width, y + height ); CalcBoundingBox( x + width, y + height );
} }
@@ -941,6 +965,20 @@ void wxWindowDC::SetClippingRegion( long x, long y, long width, long height )
gdk_gc_set_clip_rectangle( m_bgGC, &rect ); gdk_gc_set_clip_rectangle( m_bgGC, &rect );
} }
void wxWindowDC::SetClippingRegion( const wxRegion &region )
{
if (region.Empty())
{
DestroyClippingRegion();
return;
}
gdk_gc_set_clip_region( m_penGC, region.GetRegion() );
gdk_gc_set_clip_region( m_brushGC, region.GetRegion() );
gdk_gc_set_clip_region( m_textGC, region.GetRegion() );
gdk_gc_set_clip_region( m_bgGC, region.GetRegion() );
}
void wxWindowDC::DestroyClippingRegion(void) void wxWindowDC::DestroyClippingRegion(void)
{ {
wxDC::DestroyClippingRegion(); wxDC::DestroyClippingRegion();

View File

@@ -211,7 +211,7 @@ gtk_myfixed_move (GtkMyFixed *myfixed,
if (child->widget == widget) if (child->widget == widget)
{ {
/* if ((child->x == x) && (child->y == y)) return; */ if ((child->x == x) && (child->y == y)) return;
child->x = x; child->x = x;
child->y = y; child->y = y;

View File

@@ -1729,38 +1729,38 @@ int wxWindow::GetCharHeight() const
int wxWindow::GetCharWidth() const int wxWindow::GetCharWidth() const
{ {
wxASSERT_MSG( (m_widget != NULL), "invalid window" ); wxASSERT_MSG( (m_widget != NULL), "invalid window" );
if (!m_font.Ok()) if (!m_font.Ok())
{ {
wxFAIL_MSG( "invalid font" ); wxFAIL_MSG( "invalid font" );
return -1; return -1;
} }
GdkFont *font = m_font.GetInternalFont( 1.0 ); GdkFont *font = m_font.GetInternalFont( 1.0 );
return gdk_string_width( font, "H" ); return gdk_string_width( font, "H" );
} }
void wxWindow::GetTextExtent( const wxString& string, int *x, int *y, void wxWindow::GetTextExtent( const wxString& string, int *x, int *y,
int *descent, int *externalLeading, const wxFont *theFont, bool WXUNUSED(use16) ) const int *descent, int *externalLeading, const wxFont *theFont, bool WXUNUSED(use16) ) const
{ {
wxASSERT_MSG( (m_widget != NULL), "invalid window" ); wxASSERT_MSG( (m_widget != NULL), "invalid window" );
wxFont fontToUse = m_font; wxFont fontToUse = m_font;
if (theFont) fontToUse = *theFont; if (theFont) fontToUse = *theFont;
if (!fontToUse.Ok()) if (!fontToUse.Ok())
{ {
wxFAIL_MSG( "invalid font" ); wxFAIL_MSG( "invalid font" );
return; return;
} }
wxASSERT_MSG( (m_font.Ok()), "invalid font" ); wxASSERT_MSG( (m_font.Ok()), "invalid font" );
GdkFont *font = fontToUse.GetInternalFont( 1.0 ); GdkFont *font = fontToUse.GetInternalFont( 1.0 );
if (x) (*x) = gdk_string_width( font, string ); if (x) (*x) = gdk_string_width( font, string );
if (y) (*y) = font->ascent + font->descent; if (y) (*y) = font->ascent + font->descent;
if (descent) (*descent) = font->descent; if (descent) (*descent) = font->descent;
if (externalLeading) (*externalLeading) = 0; // ?? if (externalLeading) (*externalLeading) = 0; // ??
} }
void wxWindow::MakeModal( bool modal ) void wxWindow::MakeModal( bool modal )
@@ -1783,105 +1783,122 @@ void wxWindow::MakeModal( bool modal )
void wxWindow::SetFocus() void wxWindow::SetFocus()
{ {
wxASSERT_MSG( (m_widget != NULL), "invalid window" ); wxASSERT_MSG( (m_widget != NULL), "invalid window" );
GtkWidget *connect_widget = GetConnectWidget(); GtkWidget *connect_widget = GetConnectWidget();
if (connect_widget) if (connect_widget)
{
if (GTK_WIDGET_CAN_FOCUS(connect_widget) && !GTK_WIDGET_HAS_FOCUS (connect_widget) )
{ {
gtk_widget_grab_focus (connect_widget); if (GTK_WIDGET_CAN_FOCUS(connect_widget) && !GTK_WIDGET_HAS_FOCUS (connect_widget) )
{
gtk_widget_grab_focus (connect_widget);
}
} }
}
} }
bool wxWindow::OnClose() bool wxWindow::OnClose()
{ {
return TRUE; return TRUE;
} }
void wxWindow::AddChild( wxWindow *child ) void wxWindow::AddChild( wxWindow *child )
{ {
wxASSERT_MSG( (m_widget != NULL), "invalid window" ); wxASSERT_MSG( (m_widget != NULL), "invalid window" );
wxASSERT_MSG( (child != NULL), "invalid child" ); wxASSERT_MSG( (child != NULL), "invalid child" );
m_children.Append( child ); m_children.Append( child );
} }
wxList *wxWindow::GetChildren() wxList *wxWindow::GetChildren()
{ {
return (&m_children); return (&m_children);
}
wxWindow *wxWindow::ReParent( wxWindow *newParent )
{
wxWindow *oldParent = GetParent();
if (oldParent) oldParent->RemoveChild( this );
gtk_widget_unparent( m_widget );
if (newParent)
{
newParent->AddChild( this );
(newParent->m_insertCallback)( newParent, this );
}
return oldParent;
} }
void wxWindow::RemoveChild( wxWindow *child ) void wxWindow::RemoveChild( wxWindow *child )
{ {
if (GetChildren()) GetChildren()->DeleteObject( child ); if (GetChildren()) GetChildren()->DeleteObject( child );
child->m_parent = (wxWindow *) NULL; child->m_parent = (wxWindow *) NULL;
} }
void wxWindow::SetReturnCode( int retCode ) void wxWindow::SetReturnCode( int retCode )
{ {
m_retCode = retCode; m_retCode = retCode;
} }
int wxWindow::GetReturnCode() int wxWindow::GetReturnCode()
{ {
return m_retCode; return m_retCode;
} }
void wxWindow::Raise() void wxWindow::Raise()
{ {
wxASSERT_MSG( (m_widget != NULL), "invalid window" ); wxASSERT_MSG( (m_widget != NULL), "invalid window" );
if (m_widget) gdk_window_raise( m_widget->window ); if (m_widget) gdk_window_raise( m_widget->window );
} }
void wxWindow::Lower() void wxWindow::Lower()
{ {
wxASSERT_MSG( (m_widget != NULL), "invalid window" ); wxASSERT_MSG( (m_widget != NULL), "invalid window" );
if (m_widget) gdk_window_lower( m_widget->window ); if (m_widget) gdk_window_lower( m_widget->window );
} }
wxEvtHandler *wxWindow::GetEventHandler() wxEvtHandler *wxWindow::GetEventHandler()
{ {
return m_eventHandler; return m_eventHandler;
} }
void wxWindow::SetEventHandler( wxEvtHandler *handler ) void wxWindow::SetEventHandler( wxEvtHandler *handler )
{ {
m_eventHandler = handler; m_eventHandler = handler;
} }
void wxWindow::PushEventHandler(wxEvtHandler *handler) void wxWindow::PushEventHandler(wxEvtHandler *handler)
{ {
handler->SetNextHandler(GetEventHandler()); handler->SetNextHandler(GetEventHandler());
SetEventHandler(handler); SetEventHandler(handler);
} }
wxEvtHandler *wxWindow::PopEventHandler(bool deleteHandler) wxEvtHandler *wxWindow::PopEventHandler(bool deleteHandler)
{ {
if (GetEventHandler()) if (GetEventHandler())
{
wxEvtHandler *handlerA = GetEventHandler();
wxEvtHandler *handlerB = handlerA->GetNextHandler();
handlerA->SetNextHandler((wxEvtHandler *) NULL);
SetEventHandler(handlerB);
if (deleteHandler)
{ {
delete handlerA; wxEvtHandler *handlerA = GetEventHandler();
return (wxEvtHandler*) NULL; wxEvtHandler *handlerB = handlerA->GetNextHandler();
} handlerA->SetNextHandler((wxEvtHandler *) NULL);
else SetEventHandler(handlerB);
return handlerA; if (deleteHandler)
} {
else delete handlerA;
return (wxEvtHandler *) NULL; return (wxEvtHandler*) NULL;
}
else
return handlerA;
}
else
return (wxEvtHandler *) NULL;
} }
wxValidator *wxWindow::GetValidator() wxValidator *wxWindow::GetValidator()
{ {
return m_windowValidator; return m_windowValidator;
} }
void wxWindow::SetValidator( const wxValidator& validator ) void wxWindow::SetValidator( const wxValidator& validator )

View File

@@ -36,7 +36,7 @@ while test $# -gt 0; do
echo $exec_prefix echo $exec_prefix
;; ;;
--version) --version)
echo 1.97 echo 1.99
;; ;;
--cflags) --cflags)
if test @includedir@ != /usr/include ; then if test @includedir@ != /usr/include ; then