X-Git-Url: http://git.kpe.io/?p=ctsim.git;a=blobdiff_plain;f=include%2Fsgp.h;h=2d83b2ed6b2eaac7ca02497a530461e6023551e8;hp=62407526e47f75efe1c439429086382400c57a12;hb=c00c639073653fac7463a88f2b000f263236550d;hpb=1e88cf0f7fa4f690ea9f110e8ed3f2b5338d0a10 diff --git a/include/sgp.h b/include/sgp.h index 6240752..2d83b2e 100644 --- a/include/sgp.h +++ b/include/sgp.h @@ -9,7 +9,7 @@ ** This is part of the CTSim program ** Copyright (C) 1983-2000 Kevin Rosenberg ** -** $Id: sgp.h,v 1.14 2000/08/25 15:59:13 kevin Exp $ +** $Id: sgp.h,v 1.24 2001/01/02 16:02:13 kevin Exp $ ** ** This program is free software; you can redistribute it and/or modify ** it under the terms of the GNU General Public License (version 2) as @@ -36,6 +36,7 @@ #ifdef HAVE_WXWINDOWS #include +#include #endif #if HAVE_G2_H @@ -47,12 +48,11 @@ extern "C" { #include - class SGPDriver { private: int m_iPhysicalXSize; int m_iPhysicalYSize; - string m_sWindowTitle; + std::string m_sWindowTitle; int m_idDriver; #ifdef HAVE_WXWINDOWS @@ -72,7 +72,7 @@ public: #endif SGPDriver (const char* szWinTitle = "", int xsize = 640, int ysize = 480); - + ~SGPDriver (); int getPhysicalXSize () const @@ -81,14 +81,14 @@ public: int getPhysicalYSize () const { return m_iPhysicalYSize; } - const string& getWindowTitle () const + const std::string& getWindowTitle () const { return m_sWindowTitle; } bool isWX () const - { return (m_idDriver & SGPDRIVER_WXWINDOWS); } + { return (m_idDriver & SGPDRIVER_WXWINDOWS ? true : false); } bool isG2 () const - { return (m_idDriver & SGPDRIVER_G2); } + { return (m_idDriver & SGPDRIVER_G2 ? true : false); } int idG2 () const { return m_idG2; } @@ -96,6 +96,9 @@ public: #ifdef HAVE_WXWINDOWS wxDC* idWX () const { return m_pDC; } + + void setDC (wxDC* dc) + { m_pDC = dc; } #endif }; @@ -105,7 +108,7 @@ class SGP { private: int m_iPhysicalXSize; // Physical Window size int m_iPhysicalYSize; - const SGPDriver m_driver; + SGPDriver m_driver; double xw_min; // Window extents double yw_min; @@ -123,6 +126,8 @@ private: double m_dCurrentWorldY; double m_dTextAngle; bool m_bRecalcTransform; + double m_dPointsPerPixel; // points (72pt/in) per screen pixel; + int m_iLinestyle; // Master coordinates are coordinates before CTM transformation // World coordinates are coordinates defined by setWindow() @@ -138,7 +143,8 @@ private: static int s_iRGBColorCount; #if HAVE_WXWINDOWS - wxPen* m_pPen; + wxPen m_pen; + wxFont* m_pFont; #endif public: @@ -165,20 +171,21 @@ public: MARK_BSQUARE = 9, // big open square MARK_BDIAMOND = 10, // big open diamond }; - static const int MARK_COUNT = 11; + enum { MARK_COUNT = 11, }; static const unsigned char MARKER_BITMAP[MARK_COUNT][5]; SGP (const SGPDriver& driver); + ~SGP(); void drawCircle (const double r); - void drawArc (double start, double stop, const double r); + void drawArc (const double r, double start, double stop); void drawRect (double xmin, double ymin, double xmax, double ymax); void lineAbs(double x, double y); void moveAbs(double x, double y); void lineRel(double x, double y); void moveRel(double x, double y); void drawText(const char *szMessage); - void drawText(const string& rsMessage); + void drawText(const std::string& rsMessage); void polylineAbs(double x[], double y[], int n); void markerAbs (double x, double y); void markerRel(double x, double y); @@ -193,11 +200,22 @@ public: void setColor (int icol); void setLineStyle (int style); void setTextSize (double height); + void setTextNDCSize (double height); + void setTextPointSize (double height); void setTextAngle (double angle); void setTextColor (int iFGcolor, int iBGcolor); + void setPenWidth (int width); void setMarker (int idMarker, int color); void setRasterOp (int ro); + void getWindow (double& xmin, double& ymin, double& xmax, double& ymax); + void getViewport (double& xmin, double& ymin, double& xmax, double& ymax); + void getTextExtent (const char *szText, double* x, double* y); + double getCharHeight (); + double getCharWidth (); + SGPDriver& getDriver() {return m_driver;} + const SGPDriver& getDriver() const {return m_driver;} + void ctmClear (); void ctmSet (const TransformationMatrix2D& m); void preTranslate (double x, double y); @@ -215,6 +233,10 @@ public: void stylusNDC (double x, double y, bool beam); void pointNDC (double x, double y); void markerNDC (double x, double y); + +#if HAVE_WXWINDOWS + void setDC (wxDC* pDC); +#endif };