This commit is contained in:
dickelbeck 2008-03-06 01:45:39 +00:00
parent 1c14ec7402
commit b58c2a0554
1 changed files with 339 additions and 231 deletions

View File

@ -11,10 +11,10 @@
class wxSVGFileDC : public wxDC
{
private:
wxFileOutputStream* m_outfile;
wxString m_filename;
//holds number of png format images we have
int m_sub_images;
bool m_OK, m_graphics_changed;
@ -38,13 +38,17 @@ class wxSVGFileDC : public wxDC
bool DoGetPixel( wxCoord, wxCoord, class wxColour* ) const
{ wxASSERT_MSG (false, wxT("wxSVGFILEDC::DoGetPixel Call not implemented")); return true; };
{
wxASSERT_MSG( false, wxT( "wxSVGFILEDC::DoGetPixel Call not implemented" ) ); return true;
};
virtual bool DoBlit( wxCoord, wxCoord, wxCoord, wxCoord, class wxDC*,
wxCoord, wxCoord, int = wxCOPY, bool = 0, int = -1, int = -1 );
void DoCrossHair( wxCoord, wxCoord )
{ wxASSERT_MSG (false, wxT("wxSVGFILEDC::CrossHair Call not implemented")); return ; };
{
wxASSERT_MSG( false, wxT( "wxSVGFILEDC::CrossHair Call not implemented" ) ); return;
};
void DoDrawArc( wxCoord, wxCoord, wxCoord, wxCoord, wxCoord, wxCoord );
@ -62,26 +66,48 @@ class wxSVGFileDC : public wxDC
void DoDrawPoint( wxCoord, wxCoord );
void DoDrawPolygon(int n, wxPoint points[], wxCoord xoffset, wxCoord yoffset,int fillStyle) ;
void DoDrawPolygon( int n,
wxPoint points[],
wxCoord xoffset,
wxCoord yoffset,
int fillStyle );
void DoDrawRectangle( wxCoord x, wxCoord y, wxCoord width, wxCoord height );
void DoDrawRotatedText( const wxString& text, wxCoord x, wxCoord y, double angle );
void DoDrawRoundedRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord height, double radius = 20) ;
void DoDrawRoundedRectangle( wxCoord x,
wxCoord y,
wxCoord width,
wxCoord height,
double radius = 20 );
void DoDrawText( const wxString& text, wxCoord x, wxCoord y );
bool DoFloodFill( wxCoord WXUNUSED (x), wxCoord WXUNUSED (y), const wxColour& WXUNUSED (col),
int WXUNUSED (style) = wxFLOOD_SURFACE )
{ wxASSERT_MSG (false, wxT("wxSVGFILEDC::DoFloodFill Call not implemented")); return false ; };
{
wxASSERT_MSG( false, wxT( "wxSVGFILEDC::DoFloodFill Call not implemented" ) );
return false;
};
void DoGetSize(int * x, int *y) const { *x = m_width; *y = m_height ; return ; } ;
void DoGetSize( int* x, int* y ) const
{
*x = m_width; *y = m_height; return;
};
void DoGetTextExtent(const wxString& string, wxCoord *w, wxCoord *h, wxCoord *descent = NULL, wxCoord *externalLeading = NULL, wxFont *font = NULL) const ;
void DoGetTextExtent( const wxString& string,
wxCoord* w,
wxCoord* h,
wxCoord* descent = NULL,
wxCoord* externalLeading = NULL,
wxFont* font = NULL ) const;
void DoSetClippingRegionAsRegion( const class wxRegion& )
{ wxASSERT_MSG (false, wxT("wxSVGFILEDC::DoSetClippingRegionAsRegion Call not yet implemented")); return ; };
{
wxASSERT_MSG( false,
wxT( "wxSVGFILEDC::DoSetClippingRegionAsRegion Call not yet implemented" ) ); return;
};
void Init( wxString f, int Width, int Height, float dpi );
@ -93,11 +119,14 @@ class wxSVGFileDC : public wxDC
wxCoord XDEV2LOG( wxCoord x ) const
{
wxCoord new_x = x - m_deviceOriginX;
if( new_x > 0 )
return (wxCoord) ( (double) (new_x) / m_scaleX + 0.5 ) * m_signX + m_logicalOriginX;
else
return (wxCoord) ( (double) (new_x) / m_scaleX - 0.5 ) * m_signX + m_logicalOriginX;
}
#ifdef XDEV2LOGREL
#undef XDEV2LOGREL
#endif
@ -108,17 +137,22 @@ class wxSVGFileDC : public wxDC
else
return (wxCoord) ( (double) (x) / m_scaleX - 0.5 );
}
#ifdef YDEV2LOG
#undef YDEV2LOG
#endif
wxCoord YDEV2LOG( wxCoord y ) const
{
wxCoord new_y = y - m_deviceOriginY;
if( new_y > 0 )
return (wxCoord) ( (double) (new_y) / m_scaleY + 0.5 ) * m_signY + m_logicalOriginY;
else
return (wxCoord) ( (double) (new_y) / m_scaleY - 0.5 ) * m_signY + m_logicalOriginY;
}
#ifdef YDEV2LOGREL
#undef YDEV2LOGREL
#endif
@ -129,17 +163,22 @@ class wxSVGFileDC : public wxDC
else
return (wxCoord) ( (double) (y) / m_scaleY - 0.5 );
}
#ifdef XLOG2DEV
#undef XLOG2DEV
#endif
wxCoord XLOG2DEV( wxCoord x ) const
{
wxCoord new_x = x - m_logicalOriginX;
if( new_x > 0 )
return (wxCoord) ( (double) (new_x) * m_scaleX + 0.5 ) * m_signX + m_deviceOriginX;
else
return (wxCoord) ( (double) (new_x) * m_scaleX - 0.5 ) * m_signX + m_deviceOriginX;
}
#ifdef XLOG2DEVREL
#undef XLOG2DEVREL
#endif
@ -150,17 +189,22 @@ class wxSVGFileDC : public wxDC
else
return (wxCoord) ( (double) (x) * m_scaleX - 0.5 );
}
#ifdef YLOG2DEV
#undef YLOG2DEV
#endif
wxCoord YLOG2DEV( wxCoord y ) const
{
wxCoord new_y = y - m_logicalOriginY;
if( new_y > 0 )
return (wxCoord) ( (double) (new_y) * m_scaleY + 0.5 ) * m_signY + m_deviceOriginY;
else
return (wxCoord) ( (double) (new_y) * m_scaleY - 0.5 ) * m_signY + m_deviceOriginY;
}
#ifdef YLOG2DEVREL
#undef YLOG2DEVREL
#endif
@ -172,6 +216,7 @@ class wxSVGFileDC : public wxDC
return (wxCoord) ( (double) (y) * m_scaleY - 0.5 );
}
void write( const wxString& s );
public:
@ -182,28 +227,57 @@ class wxSVGFileDC : public wxDC
~wxSVGFileDC();
bool CanDrawBitmap() const { return true; };
bool CanDrawBitmap() const
{
return true;
};
bool CanGetTextExtent() const { return true; };
bool CanGetTextExtent() const
{
return true;
};
int GetDepth() const
{ wxASSERT_MSG (false, wxT("wxSVGFILEDC::GetDepth Call not implemented")); return -1 ; };
{
wxASSERT_MSG( false, wxT( "wxSVGFILEDC::GetDepth Call not implemented" ) ); return -1;
};
void BeginDrawing() { return;};
void BeginDrawing()
{
return;
};
bool Blit(wxCoord xdest, wxCoord ydest, wxCoord width, wxCoord height, wxDC* source, wxCoord xsrc, wxCoord ysrc, int logicalFunc = wxCOPY, bool useMask = false)
{ return DoBlit(xdest, ydest, width, height, source, xsrc, ysrc, logicalFunc, useMask); };
bool Blit( wxCoord xdest,
wxCoord ydest,
wxCoord width,
wxCoord height,
wxDC* source,
wxCoord xsrc,
wxCoord ysrc,
int logicalFunc = wxCOPY,
bool useMask = false )
{
return DoBlit( xdest, ydest, width, height, source, xsrc, ysrc, logicalFunc, useMask );
};
void Clear()
{ wxASSERT_MSG (false, wxT("wxSVGFILEDC::Clear() Call not implemented \nNot sensible for an output file?")); return ; };
{
wxASSERT_MSG( false,
wxT( "wxSVGFILEDC::Clear() Call not implemented \nNot sensible for an output file?" ) );
return;
};
void CrossHair( wxCoord x, wxCoord y )
{ DoCrossHair (x,y); return; };
{
DoCrossHair( x, y ); return;
};
virtual void ComputeScaleAndOrigin();
void DestroyClippingRegion()
{ wxASSERT_MSG (false, wxT("wxSVGFILEDC::void Call not yet implemented")); return ; };
{
wxASSERT_MSG( false, wxT( "wxSVGFILEDC::void Call not yet implemented" ) ); return;
};
wxCoord DeviceToLogicalX( wxCoord x ) const;
@ -214,39 +288,60 @@ class wxSVGFileDC : public wxDC
wxCoord DeviceToLogicalYRel( wxCoord y ) const;
void DrawBitmap( const wxBitmap& bitmap, wxCoord x, wxCoord y, bool transparent )
{ DoDrawBitmap ( bitmap, x, y, transparent ) ; return ;};
{
DoDrawBitmap( bitmap, x, y, transparent ); return;
};
void DrawIcon( const wxIcon& icon, wxCoord x, wxCoord y )
{DoDrawIcon(icon, x, y) ; return ; };
{
DoDrawIcon( icon, x, y ); return;
};
void DoDrawLines( int n, wxPoint points[], wxCoord xoffset = 0, wxCoord yoffset = 0 );
void EndDoc()
{ return ; };
{
return;
};
void EndDrawing()
{ return ; };
{
return;
};
void EndPage()
{ return ; };
{
return;
};
void FloodFill( wxCoord x, wxCoord y, wxColour* colour, int style = wxFLOOD_SURFACE )
{ DoFloodFill (x, y, *colour, style); return ;} ;
{
DoFloodFill( x, y, *colour, style ); return;
};
wxCoord GetCharHeight() const;
wxCoord GetCharWidth() const;
void GetClippingBox(wxCoord *WXUNUSED(x), wxCoord *WXUNUSED(y), wxCoord * WXUNUSED(width), wxCoord * WXUNUSED(height))
{ wxASSERT_MSG (false, wxT("wxSVGFILEDC::GetClippingBox Call not yet implemented")); return ; };
void GetClippingBox( wxCoord* WXUNUSED (x), wxCoord* WXUNUSED (y), wxCoord* WXUNUSED (width),
wxCoord* WXUNUSED (height) )
{
wxASSERT_MSG( false, wxT( "wxSVGFILEDC::GetClippingBox Call not yet implemented" ) );
return;
};
int GetLogicalFunction()
{ wxASSERT_MSG (false, wxT("wxSVGFILEDC::GetLogicalFunction() Call not implemented")); return wxCOPY ; };
{
wxASSERT_MSG( false, wxT( "wxSVGFILEDC::GetLogicalFunction() Call not implemented" ) );
return wxCOPY;
};
int GetMapMode();
bool GetPixel( wxCoord x, wxCoord y, wxColour* colour )
{ return DoGetPixel (x, y, colour) ; } ;
{
return DoGetPixel( x, y, colour );
};
void GetUserScale( double* x, double* y ) const;
@ -258,15 +353,24 @@ class wxSVGFileDC : public wxDC
wxCoord LogicalToDeviceYRel( wxCoord y ) const;
bool Ok() const {return m_OK;};
bool Ok() const
{
return m_OK;
};
void SetAxisOrientation( bool xLeftRight, bool yBottomUp );
void SetClippingRegion(wxCoord WXUNUSED(x), wxCoord WXUNUSED(y), wxCoord WXUNUSED(width), wxCoord WXUNUSED(height))
{ wxASSERT_MSG (false, wxT("wxSVGFILEDC::SetClippingRegion Call not yet implemented")); return ; };
void SetClippingRegion( wxCoord WXUNUSED (x), wxCoord WXUNUSED (y), wxCoord WXUNUSED (width),
wxCoord WXUNUSED (height) )
{
wxASSERT_MSG( false, wxT( "wxSVGFILEDC::SetClippingRegion Call not yet implemented" ) );
return;
};
void SetPalette( const wxPalette& WXUNUSED (palette) )
{ wxASSERT_MSG (false, wxT("wxSVGFILEDC::SetPalette Call not yet implemented")); return ; };
{
wxASSERT_MSG( false, wxT( "wxSVGFILEDC::SetPalette Call not yet implemented" ) ); return;
};
void SetBackground( const wxBrush& brush );
@ -277,7 +381,9 @@ class wxSVGFileDC : public wxDC
void SetFont( const wxFont& font );
void SetLogicalFunction( int WXUNUSED (function) )
{ /*wxASSERT_MSG (false, wxT("wxSVGFILEDC::SetLogicalFunction Call implemented")); */ return ; };
{ /*wxASSERT_MSG (false, wxT("wxSVGFILEDC::SetLogicalFunction Call implemented")); */
return;
};
void SetLogicalScale( double x, double y );
@ -292,12 +398,14 @@ class wxSVGFileDC : public wxDC
void SetUserScale( double xScale, double yScale );
bool StartDoc( const wxString& WXUNUSED (message) )
{ return false; };
{
return false;
};
void StartPage()
{ return ; };
{
return;
};
};
#ifdef __BORLANDC__