Main Page   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members

FXDC.h

Go to the documentation of this file.
00001 /********************************************************************************
00002 *                                                                               *
00003 *               D e v i c e   C o n t e x t   B a s e   C l a s s               *
00004 *                                                                               *
00005 *********************************************************************************
00006 * Copyright (C) 1999,2006 by Jeroen van der Zijp.   All Rights Reserved.        *
00007 *********************************************************************************
00008 * This library is free software; you can redistribute it and/or                 *
00009 * modify it under the terms of the GNU Lesser General Public                    *
00010 * License as published by the Free Software Foundation; either                  *
00011 * version 2.1 of the License, or (at your option) any later version.            *
00012 *                                                                               *
00013 * This library is distributed in the hope that it will be useful,               *
00014 * but WITHOUT ANY WARRANTY; without even the implied warranty of                *
00015 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU             *
00016 * Lesser General Public License for more details.                               *
00017 *                                                                               *
00018 * You should have received a copy of the GNU Lesser General Public              *
00019 * License along with this library; if not, write to the Free Software           *
00020 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA.    *
00021 *********************************************************************************
00022 * $Id: FXDC.h,v 1.37 2006/01/22 17:58:00 fox Exp $                              *
00023 ********************************************************************************/
00024 #ifndef FXDC_H
00025 #define FXDC_H
00026 
00027 namespace FX {
00028 
00029 /// Drawing (BITBLT) functions
00030 enum FXFunction {
00031   BLT_CLR,                        /// D := 0
00032   BLT_SRC_AND_DST,                /// D := S & D
00033   BLT_SRC_AND_NOT_DST,            /// D := S & ~D
00034   BLT_SRC,                        /// D := S
00035   BLT_NOT_SRC_AND_DST,            /// D := ~S & D
00036   BLT_DST,                        /// D := D
00037   BLT_SRC_XOR_DST,                /// D := S ^ D
00038   BLT_SRC_OR_DST,                 /// D := S | D
00039   BLT_NOT_SRC_AND_NOT_DST,        /// D := ~S & ~D  ==  D := ~(S | D)
00040   BLT_NOT_SRC_XOR_DST,            /// D := ~S ^ D
00041   BLT_NOT_DST,                    /// D := ~D
00042   BLT_SRC_OR_NOT_DST,             /// D := S | ~D
00043   BLT_NOT_SRC,                    /// D := ~S
00044   BLT_NOT_SRC_OR_DST,             /// D := ~S | D
00045   BLT_NOT_SRC_OR_NOT_DST,         /// D := ~S | ~D  ==  ~(S & D)
00046   BLT_SET                         /// D := 1
00047   };
00048 
00049 
00050 /// Line Styles
00051 enum FXLineStyle {
00052   LINE_SOLID,                     /// Solid lines
00053   LINE_ONOFF_DASH,                /// On-off dashed lines
00054   LINE_DOUBLE_DASH                /// Double dashed lines
00055   };
00056 
00057 
00058 /// Line Cap Styles
00059 enum FXCapStyle {
00060   CAP_NOT_LAST,                   /// Don't include last end cap
00061   CAP_BUTT,                       /// Butting line end caps
00062   CAP_ROUND,                      /// Round line end caps
00063   CAP_PROJECTING                  /// Projecting line end caps
00064   };
00065 
00066 
00067 /// Line Join Styles
00068 enum FXJoinStyle {
00069   JOIN_MITER,                     /// Mitered or pointy joints
00070   JOIN_ROUND,                     /// Round line joints
00071   JOIN_BEVEL                      /// Beveled or flat joints
00072   };
00073 
00074 
00075 /// Fill Styles
00076 enum FXFillStyle {
00077   FILL_SOLID,                     /// Fill with solid color
00078   FILL_TILED,                     /// Fill with tiled bitmap
00079   FILL_STIPPLED,                  /// Fill where stipple mask is 1
00080   FILL_OPAQUESTIPPLED             /// Fill with foreground where mask is 1, background otherwise
00081   };
00082 
00083 
00084 /// Fill Rules
00085 enum FXFillRule {
00086   RULE_EVEN_ODD,                  /// Even odd polygon filling
00087   RULE_WINDING                    /// Winding rule polygon filling
00088   };
00089 
00090 
00091 /// Stipple/dither patterns
00092 enum FXStipplePattern {
00093   STIPPLE_0         = 0,
00094   STIPPLE_NONE      = 0,
00095   STIPPLE_BLACK     = 0,            /// All ones
00096   STIPPLE_1         = 1,
00097   STIPPLE_2         = 2,
00098   STIPPLE_3         = 3,
00099   STIPPLE_4         = 4,
00100   STIPPLE_5         = 5,
00101   STIPPLE_6         = 6,
00102   STIPPLE_7         = 7,
00103   STIPPLE_8         = 8,
00104   STIPPLE_GRAY      = 8,            /// 50% gray
00105   STIPPLE_9         = 9,
00106   STIPPLE_10        = 10,
00107   STIPPLE_11        = 11,
00108   STIPPLE_12        = 12,
00109   STIPPLE_13        = 13,
00110   STIPPLE_14        = 14,
00111   STIPPLE_15        = 15,
00112   STIPPLE_16        = 16,
00113   STIPPLE_WHITE     = 16,           /// All zeroes
00114   STIPPLE_HORZ      = 17,           /// Horizontal hatch pattern
00115   STIPPLE_VERT      = 18,           /// Vertical hatch pattern
00116   STIPPLE_CROSS     = 19,           /// Cross-hatch pattern
00117   STIPPLE_DIAG      = 20,           /// Diagonal // hatch pattern
00118   STIPPLE_REVDIAG   = 21,           /// Reverse diagonal \\ hatch pattern
00119   STIPPLE_CROSSDIAG = 22            /// Cross-diagonal hatch pattern
00120   };
00121 
00122 
00123 /// Line segment
00124 struct FXSegment {
00125   FXshort x1,y1,x2,y2;
00126   };
00127 
00128 
00129 /// Arc
00130 struct FXArc {
00131   FXshort x,y,w,h,a,b;
00132   };
00133 
00134 
00135 class FXApp;
00136 class FXImage;
00137 class FXBitmap;
00138 class FXIcon;
00139 class FXFont;
00140 class FXDrawable;
00141 class FXRegion;
00142 
00143 
00144 /**
00145 * Abstract Device Context
00146 *
00147 * A Device Context is used to maintain the state of the graphics drawing system.
00148 * Defining your drawing code in terms of the Abstract Device Context allows the
00149 * drawing commands to be rendered on different types of surfaces, such as windows
00150 * and images (FXDCWindow), or on paper (FXDCPrint).
00151 * WYSYWYG may be obtained by using the same identical drawing code in your
00152 * application regardless of the actual device surface being utilized.
00153 */
00154 class FXAPI FXDC {
00155   friend class FXFont;
00156 private:
00157   FXApp           *app;         // Application
00158 protected:
00159   void            *ctx;         // Context handle
00160   FXFont          *font;        // Drawing font
00161   FXStipplePattern pattern;     // Stipple pattern
00162   FXBitmap        *stipple;     // Stipple bitmap
00163   FXImage         *tile;        // Tile image
00164   FXBitmap        *mask;        // Mask bitmap
00165   FXRectangle      clip;        // Clip rectangle
00166   FXColor          fg;          // Foreground color
00167   FXColor          bg;          // Background color
00168   FXuint           width;       // Line width
00169   FXCapStyle       cap;         // Line cap style
00170   FXJoinStyle      join;        // Line join style
00171   FXLineStyle      style;       // Line style
00172   FXFillStyle      fill;        // Fill style
00173   FXFillRule       rule;        // Fill rule
00174   FXFunction       rop;         // RasterOp
00175   FXchar           dashpat[32]; // Line dash pattern data
00176   FXuint           dashlen;     // Line dash pattern length
00177   FXuint           dashoff;     // Line dash pattern offset
00178   FXint            tx;          // Tile dx
00179   FXint            ty;          // Tile dy
00180   FXint            cx;          // Clip x
00181   FXint            cy;          // Clip y
00182 private:
00183   FXDC();
00184   FXDC(const FXDC&);
00185   FXDC &operator=(const FXDC&);
00186 public:
00187 
00188   /// Construct dummy DC
00189   FXDC(FXApp* a);
00190 
00191   /// Get application
00192   FXApp* getApp() const { return app; }
00193 
00194   /// Get context handle
00195   void* context() const { return ctx; }
00196 
00197   /// Read back pixel
00198   virtual FXColor readPixel(FXint x,FXint y);
00199 
00200   /// Draw points
00201   virtual void drawPoint(FXint x,FXint y);
00202   virtual void drawPoints(const FXPoint* points,FXuint npoints);
00203   virtual void drawPointsRel(const FXPoint* points,FXuint npoints);
00204 
00205   /// Draw lines
00206   virtual void drawLine(FXint x1,FXint y1,FXint x2,FXint y2);
00207   virtual void drawLines(const FXPoint* points,FXuint npoints);
00208   virtual void drawLinesRel(const FXPoint* points,FXuint npoints);
00209   virtual void drawLineSegments(const FXSegment* segments,FXuint nsegments);
00210 
00211   /// Draw rectangles
00212   virtual void drawRectangle(FXint x,FXint y,FXint w,FXint h);
00213   virtual void drawRectangles(const FXRectangle* rectangles,FXuint nrectangles);
00214 
00215   /// Draw rounded rectangle with ellipse with ew and ellips height eh
00216   virtual void drawRoundRectangle(FXint x,FXint y,FXint w,FXint h,FXint ew,FXint eh);
00217 
00218   /**
00219   * Draw arcs.
00220   * The argument ang1 specifies the start of the arc relative to the
00221   * three-o'clock position from the center, in units of degrees*64.
00222   * The argument ang2 specifies the path and extent of the arc relative
00223   * to the start of the arc, in units of degrees*64.
00224   * The arguments x,y,w,h specify the bounding rectangle.
00225   */
00226   virtual void drawArc(FXint x,FXint y,FXint w,FXint h,FXint ang1,FXint ang2);
00227   virtual void drawArcs(const FXArc* arcs,FXuint narcs);
00228 
00229   /// Draw ellipse
00230   virtual void drawEllipse(FXint x,FXint y,FXint w,FXint h);
00231 
00232   /// Filled rectangles
00233   virtual void fillRectangle(FXint x,FXint y,FXint w,FXint h);
00234   virtual void fillRectangles(const FXRectangle* rectangles,FXuint nrectangles);
00235 
00236   /// Filled rounded rectangle with ellipse with ew and ellips height eh
00237   virtual void fillRoundRectangle(FXint x,FXint y,FXint w,FXint h,FXint ew,FXint eh);
00238 
00239   /// Fill chord
00240   virtual void fillChord(FXint x,FXint y,FXint w,FXint h,FXint ang1,FXint ang2);
00241   virtual void fillChords(const FXArc* chords,FXuint nchords);
00242 
00243   /// Fill arcs
00244   virtual void fillArc(FXint x,FXint y,FXint w,FXint h,FXint ang1,FXint ang2);
00245   virtual void fillArcs(const FXArc* arcs,FXuint narcs);
00246 
00247   /// Fill ellipse
00248   virtual void fillEllipse(FXint x,FXint y,FXint w,FXint h);
00249 
00250   /// Filled polygon
00251   virtual void fillPolygon(const FXPoint* points,FXuint npoints);
00252   virtual void fillConcavePolygon(const FXPoint* points,FXuint npoints);
00253   virtual void fillComplexPolygon(const FXPoint* points,FXuint npoints);
00254 
00255   /// Filled polygon with relative points
00256   virtual void fillPolygonRel(const FXPoint* points,FXuint npoints);
00257   virtual void fillConcavePolygonRel(const FXPoint* points,FXuint npoints);
00258   virtual void fillComplexPolygonRel(const FXPoint* points,FXuint npoints);
00259 
00260   /// Draw hashed box
00261   virtual void drawHashBox(FXint x,FXint y,FXint w,FXint h,FXint b=1);
00262 
00263   /// Draw focus rectangle
00264   virtual void drawFocusRectangle(FXint x,FXint y,FXint w,FXint h);
00265 
00266   /// Draw area from source
00267   virtual void drawArea(const FXDrawable* source,FXint sx,FXint sy,FXint sw,FXint sh,FXint dx,FXint dy);
00268 
00269   /// Draw area stretched area from source
00270   virtual void drawArea(const FXDrawable* source,FXint sx,FXint sy,FXint sw,FXint sh,FXint dx,FXint dy,FXint dw,FXint dh);
00271 
00272   /// Draw image
00273   virtual void drawImage(const FXImage* image,FXint dx,FXint dy);
00274 
00275   /// Draw bitmap
00276   virtual void drawBitmap(const FXBitmap* bitmap,FXint dx,FXint dy);
00277 
00278   /// Draw icon
00279   virtual void drawIcon(const FXIcon* icon,FXint dx,FXint dy);
00280   virtual void drawIconShaded(const FXIcon* icon,FXint dx,FXint dy);
00281   virtual void drawIconSunken(const FXIcon* icon,FXint dx,FXint dy);
00282 
00283   /// Draw string with base line starting at x, y
00284   virtual void drawText(FXint x,FXint y,const FXString& string);
00285   virtual void drawText(FXint x,FXint y,const FXchar* string,FXuint length);
00286 
00287   /// Draw text starting at x, y over filled background
00288   virtual void drawImageText(FXint x,FXint y,const FXString& string);
00289   virtual void drawImageText(FXint x,FXint y,const FXchar* string,FXuint length);
00290 
00291   /// Set foreground drawing color
00292   virtual void setForeground(FXColor clr);
00293 
00294   /// Get foreground drawing color
00295   FXColor getForeground() const { return fg; }
00296 
00297   /// Set background drawing color
00298   virtual void setBackground(FXColor clr);
00299 
00300   /// Get background drawing color
00301   FXColor getBackground() const { return bg; }
00302 
00303   /**
00304   * Set dash pattern and dash offset.
00305   * A dash pattern of [1 2 3 4] is a repeating pattern of 1 foreground pixel,
00306   * 2 background pixels, 3 foreground pixels, and 4 background pixels.
00307   * The offset is where in the pattern the system will start counting.
00308   * The maximum length of the dash pattern is 32.
00309   */
00310   virtual void setDashes(FXuint dashoffset,const FXchar *dashpattern,FXuint dashlength);
00311 
00312   /// Get dash pattern
00313   const FXchar* getDashPattern() const { return dashpat; }
00314 
00315   /// Get dash offset
00316   FXuint getDashOffset() const { return dashoff; }
00317 
00318   /// Get dash length
00319   FXuint getDashLength() const { return dashlen; }
00320 
00321   /// Set line width:- 0 means thinnest/fastest possible
00322   virtual void setLineWidth(FXuint linewidth=0);
00323 
00324   /// Get line width
00325   FXuint getLineWidth() const { return width; }
00326 
00327   /// Set line cap style
00328   virtual void setLineCap(FXCapStyle capstyle=CAP_BUTT);
00329 
00330   /// Get line cap style
00331   FXCapStyle getLineCap() const { return cap; }
00332 
00333   /// Set line join style
00334   virtual void setLineJoin(FXJoinStyle joinstyle=JOIN_MITER);
00335 
00336   /// Get line join style
00337   FXJoinStyle getLineJoin() const { return join; }
00338 
00339   /// Set line style
00340   virtual void setLineStyle(FXLineStyle linestyle=LINE_SOLID);
00341 
00342   /// Get line style
00343   FXLineStyle getLineStyle() const { return style; }
00344 
00345   /// Set fill style
00346   virtual void setFillStyle(FXFillStyle fillstyle=FILL_SOLID);
00347 
00348   /// Get fill style
00349   FXFillStyle getFillStyle() const { return fill; }
00350 
00351   /// Set fill rule
00352   virtual void setFillRule(FXFillRule fillrule=RULE_EVEN_ODD);
00353 
00354   /// Get fill rule
00355   FXFillRule getFillRule() const { return rule; }
00356 
00357   /// Set rasterop function
00358   virtual void setFunction(FXFunction func=BLT_SRC);
00359 
00360   /// Get rasterop function
00361   FXFunction getFunction() const { return rop; }
00362 
00363   /// Set the tile image
00364   virtual void setTile(FXImage* image,FXint dx=0,FXint dy=0);
00365 
00366   /// Get the tile image
00367   FXImage *getTile() const { return tile; }
00368 
00369   /// Set the stipple pattern
00370   virtual void setStipple(FXBitmap *bitmap,FXint dx=0,FXint dy=0);
00371 
00372   /// Get stipple bitmap
00373   FXBitmap *getStippleBitmap() const { return stipple; }
00374 
00375   /// Set the stipple pattern
00376   virtual void setStipple(FXStipplePattern pat,FXint dx=0,FXint dy=0);
00377 
00378   /// Get pattern
00379   FXStipplePattern getStipplePattern() const { return pattern; }
00380 
00381   /// Set clip region
00382   virtual void setClipRegion(const FXRegion& region);
00383 
00384   /// Set clip rectangle
00385   virtual void setClipRectangle(FXint x,FXint y,FXint w,FXint h);
00386 
00387   /// Change clip rectangle
00388   virtual void setClipRectangle(const FXRectangle& rectangle);
00389 
00390   /// Return clip rectangle
00391   const FXRectangle& getClipRectangle() const { return clip; }
00392 
00393   /// Return clip x
00394   FXint getClipX() const { return clip.x; }
00395 
00396   /// Return clip y
00397   FXint getClipY() const { return clip.y; }
00398 
00399   /// Return clip width
00400   FXint getClipWidth() const { return clip.w; }
00401 
00402   /// Return clip height
00403   FXint getClipHeight() const { return clip.h; }
00404 
00405   /// Clear clipping
00406   virtual void clearClipRectangle();
00407 
00408   /// Set clip mask
00409   virtual void setClipMask(FXBitmap* bitmap,FXint dx=0,FXint dy=0);
00410 
00411   /// Clear clip mask
00412   virtual void clearClipMask();
00413 
00414   /// Set font to draw text with
00415   virtual void setFont(FXFont *fnt);
00416 
00417   /// Get text font
00418   FXFont* getFont() const { return font; }
00419 
00420   /// Clip against child windows
00421   virtual void clipChildren(FXbool yes);
00422 
00423   /// Destructor
00424   virtual ~FXDC();
00425   };
00426 
00427 }
00428 
00429 #endif

Copyright © 1997-2005 Jeroen van der Zijp