Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

485 lines
17 KiB

  1. /***
  2. *graph.h - declare constants, functions, and macros for graphics library
  3. *
  4. * Copyright (c) 1987 - 1992, Microsoft Corporation. All rights reserved.
  5. *
  6. *Purpose:
  7. * This file declares the graphics library functions and the
  8. * structures and manifest constants that are used with them.
  9. *
  10. ***************************************************************************/
  11. #ifndef _WINDOWS
  12. /* Force graphics.lib to be linked in if graph.h used */
  13. #pragma comment(lib,"graphics.lib")
  14. #endif
  15. #ifdef __cplusplus
  16. extern "C" { /* allow use with C++ */
  17. #endif
  18. #if (_MSC_VER <= 600)
  19. #define __cdecl _cdecl
  20. #define __far _far
  21. #define __huge _huge
  22. #endif
  23. /* force word packing to avoid possible -Zp override */
  24. #pragma pack(2)
  25. /* user-visible declarations for Quick-C Graphics Library */
  26. #ifndef _VIDEOCONFIG_DEFINED
  27. /* structure for _getvideoconfig() as visible to user */
  28. struct _videoconfig {
  29. short numxpixels; /* number of pixels on X axis */
  30. short numypixels; /* number of pixels on Y axis */
  31. short numtextcols; /* number of text columns available */
  32. short numtextrows; /* number of text rows available */
  33. short numcolors; /* number of actual colors */
  34. short bitsperpixel; /* number of bits per pixel */
  35. short numvideopages; /* number of available video pages */
  36. short mode; /* current video mode */
  37. short adapter; /* active display adapter */
  38. short monitor; /* active display monitor */
  39. short memory; /* adapter video memory in K bytes */
  40. };
  41. #define _VIDEOCONFIG_DEFINED
  42. #endif
  43. #ifndef _XYCOORD_DEFINED
  44. /* return value of _setvieworg(), etc. */
  45. struct _xycoord {
  46. short xcoord;
  47. short ycoord;
  48. };
  49. #define _XYCOORD_DEFINED
  50. #endif
  51. /* structure for text position */
  52. #ifndef _RCCOORD_DEFINED
  53. struct _rccoord {
  54. short row;
  55. short col;
  56. };
  57. #define _RCCOORD_DEFINED
  58. #endif
  59. #ifndef __STDC__
  60. /* Non-ANSI names for compatibility */
  61. #define videoconfig _videoconfig
  62. #define xycoord _xycoord
  63. #define rccoord _rccoord
  64. #endif
  65. /* ERROR HANDLING */
  66. short __far __cdecl _grstatus(void);
  67. /* Error Status Information returned by _grstatus() */
  68. /* successful */
  69. #define _GROK 0
  70. /* errors */
  71. #define _GRERROR (-1)
  72. #define _GRMODENOTSUPPORTED (-2)
  73. #define _GRNOTINPROPERMODE (-3)
  74. #define _GRINVALIDPARAMETER (-4)
  75. #define _GRFONTFILENOTFOUND (-5)
  76. #define _GRINVALIDFONTFILE (-6)
  77. #define _GRCORRUPTEDFONTFILE (-7)
  78. #define _GRINSUFFICIENTMEMORY (-8)
  79. #define _GRINVALIDIMAGEBUFFER (-9)
  80. /* warnings */
  81. #define _GRNOOUTPUT 1
  82. #define _GRCLIPPED 2
  83. #define _GRPARAMETERALTERED 3
  84. #define _GRTEXTNOTSUPPORTED 4
  85. /* SETUP AND CONFIGURATION */
  86. short __far __cdecl _setvideomode(short);
  87. short __far __cdecl _setvideomoderows(short,short); /* return rows; 0 if error */
  88. /* arguments to _setvideomode() */
  89. #define _MAXRESMODE (-3) /* graphics mode with highest resolution */
  90. #define _MAXCOLORMODE (-2) /* graphics mode with most colors */
  91. #define _DEFAULTMODE (-1) /* restore screen to original mode */
  92. #define _TEXTBW40 0 /* 40-column text, 16 grey */
  93. #define _TEXTC40 1 /* 40-column text, 16/8 color */
  94. #define _TEXTBW80 2 /* 80-column text, 16 grey */
  95. #define _TEXTC80 3 /* 80-column text, 16/8 color */
  96. #define _MRES4COLOR 4 /* 320 x 200, 4 color */
  97. #define _MRESNOCOLOR 5 /* 320 x 200, 4 grey */
  98. #define _HRESBW 6 /* 640 x 200, BW */
  99. #define _TEXTMONO 7 /* 80-column text, BW */
  100. #define _HERCMONO 8 /* 720 x 348, BW for HGC */
  101. #define _MRES16COLOR 13 /* 320 x 200, 16 color */
  102. #define _HRES16COLOR 14 /* 640 x 200, 16 color */
  103. #define _ERESNOCOLOR 15 /* 640 x 350, BW */
  104. #define _ERESCOLOR 16 /* 640 x 350, 4 or 16 color */
  105. #define _VRES2COLOR 17 /* 640 x 480, BW */
  106. #define _VRES16COLOR 18 /* 640 x 480, 16 color */
  107. #define _MRES256COLOR 19 /* 320 x 200, 256 color */
  108. #define _ORESCOLOR 64 /* 640 x 400, 1 of 16 colors (Olivetti only) */
  109. /* the following 8 modes require VESA SuperVGA BIOS extensions */
  110. #define _ORES256COLOR 0x0100 /* 640 x 400, 256 color */
  111. #define _VRES256COLOR 0x0101 /* 640 x 480, 256 color */
  112. /* WARNING: DO NOT attempt to set the following modes without ensuring that
  113. your monitor can safely handle that resolution. Otherwise, you may risk
  114. damaging your display monitor! Consult your owner's manual for details.
  115. Note: _MAXRESMODE and _MAXCOLORMODE never select SRES, XRES, or ZRES modes */
  116. /* requires NEC MultiSync 3D or equivalent, or better */
  117. #define _SRES16COLOR 0x0102 /* 800 x 600, 16 color */
  118. #define _SRES256COLOR 0x0103 /* 800 x 600, 256 color */
  119. /* requires NEC MultiSync 4D or equivalent, or better */
  120. #define _XRES16COLOR 0x0104 /* 1024 x 768, 16 color */
  121. #define _XRES256COLOR 0x0105 /* 1024 x 768, 256 color */
  122. /* requires NEC MultiSync 5D or equivalent, or better */
  123. #define _ZRES16COLOR 0x0106 /* 1280 x 1024, 16 color */
  124. #define _ZRES256COLOR 0x0107 /* 1280 x 1024, 256 color */
  125. short __far __cdecl _setactivepage(short);
  126. short __far __cdecl _setvisualpage(short);
  127. short __far __cdecl _getactivepage(void);
  128. short __far __cdecl _getvisualpage(void);
  129. /* _videoconfig adapter values */
  130. /* these manifest constants can be used to determine the type of the active */
  131. /* adapter, using either simple comparisons or the bitwise-AND operator (&) */
  132. #define _MDPA 0x0001 /* Monochrome Display Adapter (MDPA) */
  133. #define _CGA 0x0002 /* Color Graphics Adapter (CGA) */
  134. #define _EGA 0x0004 /* Enhanced Graphics Adapter (EGA) */
  135. #define _VGA 0x0008 /* Video Graphics Array (VGA) */
  136. #define _MCGA 0x0010 /* MultiColor Graphics Array (MCGA) */
  137. #define _HGC 0x0020 /* Hercules Graphics Card (HGC) */
  138. #define _OCGA 0x0042 /* Olivetti Color Graphics Adapter (OCGA) */
  139. #define _OEGA 0x0044 /* Olivetti Enhanced Graphics Adapter (OEGA) */
  140. #define _OVGA 0x0048 /* Olivetti Video Graphics Array (OVGA) */
  141. #define _SVGA 0x0088 /* Super VGA with VESA BIOS support (SVGA) */
  142. /* _videoconfig monitor values */
  143. /* these manifest constants can be used to determine the type of monitor in */
  144. /* use, using either simple comparisons or the bitwise-AND operator (&) */
  145. #define _MONO 0x0001 /* Monochrome */
  146. #define _COLOR 0x0002 /* Color (or Enhanced emulating color) */
  147. #define _ENHCOLOR 0x0004 /* Enhanced Color */
  148. #define _ANALOGMONO 0x0008 /* Analog Monochrome only */
  149. #define _ANALOGCOLOR 0x0010 /* Analog Color only */
  150. #define _ANALOG 0x0018 /* Analog Monochrome and Color modes */
  151. struct _videoconfig __far * __far __cdecl _getvideoconfig(struct _videoconfig __far *);
  152. /* COORDINATE SYSTEMS */
  153. struct _xycoord __far __cdecl _setvieworg(short, short);
  154. #define _setlogorg _setvieworg /* obsolescent */
  155. struct _xycoord __far __cdecl _getviewcoord(short, short);
  156. #define _getlogcoord _getviewcoord /* obsolescent */
  157. struct _xycoord __far __cdecl _getphyscoord(short, short);
  158. void __far __cdecl _setcliprgn(short, short, short, short);
  159. void __far __cdecl _setviewport(short, short, short, short);
  160. /* OUTPUT ROUTINES */
  161. /* control parameters for _ellipse, _rectangle, _pie and _polygon */
  162. #define _GBORDER 2 /* draw outline only */
  163. #define _GFILLINTERIOR 3 /* fill using current fill mask */
  164. /* parameters for _clearscreen */
  165. #define _GCLEARSCREEN 0
  166. #define _GVIEWPORT 1
  167. #define _GWINDOW 2
  168. void __far __cdecl _clearscreen(short);
  169. struct _xycoord __far __cdecl _moveto(short, short);
  170. struct _xycoord __far __cdecl _getcurrentposition(void);
  171. short __far __cdecl _lineto(short, short);
  172. short __far __cdecl _rectangle(short, short, short, short, short);
  173. short __far __cdecl _polygon(short, const struct _xycoord __far *, short);
  174. short __far __cdecl _arc(short, short, short, short, short, short, short, short);
  175. short __far __cdecl _ellipse(short, short, short, short, short);
  176. short __far __cdecl _pie(short, short, short, short, short, short, short, short, short);
  177. short __far __cdecl _getarcinfo(struct _xycoord __far *, struct _xycoord __far *, struct _xycoord __far *);
  178. short __far __cdecl _setpixel(short, short);
  179. short __far __cdecl _getpixel(short, short);
  180. short __far __cdecl _floodfill(short, short, short);
  181. /* PEN COLOR, LINE STYLE, WRITE MODE, FILL PATTERN */
  182. short __far __cdecl _setcolor(short);
  183. short __far __cdecl _getcolor(void);
  184. void __far __cdecl _setlinestyle(unsigned short);
  185. unsigned short __far __cdecl _getlinestyle(void);
  186. short __far __cdecl _setwritemode(short);
  187. short __far __cdecl _getwritemode(void);
  188. void __far __cdecl _setfillmask(const unsigned char __far *);
  189. unsigned char __far * __far __cdecl _getfillmask(unsigned char __far *);
  190. /* COLOR SELECTION */
  191. long __far __cdecl _setbkcolor(long);
  192. long __far __cdecl _getbkcolor(void);
  193. long __far __cdecl _remappalette(short, long);
  194. short __far __cdecl _remapallpalette(const long __far *);
  195. short __far __cdecl _selectpalette(short);
  196. /* TEXT */
  197. /* parameters for _displaycursor */
  198. #define _GCURSOROFF 0
  199. #define _GCURSORON 1
  200. /* parameters for _wrapon */
  201. #define _GWRAPOFF 0
  202. #define _GWRAPON 1
  203. /* direction parameters for _scrolltextwindow */
  204. #define _GSCROLLUP 1
  205. #define _GSCROLLDOWN (-1)
  206. /* request maximum number of rows in _settextrows and _setvideomoderows */
  207. #define _MAXTEXTROWS (-1)
  208. short __far __cdecl _settextrows(short); /* returns # rows set; 0 if error */
  209. void __far __cdecl _settextwindow(short, short, short, short);
  210. void __far __cdecl _gettextwindow(short __far *, short __far *, short __far *, short __far *);
  211. void __far __cdecl _scrolltextwindow(short);
  212. void __far __cdecl _outmem(const char __far *, short);
  213. void __far __cdecl _outtext(const char __far *);
  214. short __far __cdecl _inchar(void);
  215. short __far __cdecl _wrapon(short);
  216. short __far __cdecl _displaycursor(short);
  217. short __far __cdecl _settextcursor(short);
  218. short __far __cdecl _gettextcursor(void);
  219. struct _rccoord __far __cdecl _settextposition(short, short);
  220. struct _rccoord __far __cdecl _gettextposition(void);
  221. short __far __cdecl _settextcolor(short);
  222. short __far __cdecl _gettextcolor(void);
  223. /* SCREEN IMAGES */
  224. void __far __cdecl _getimage(short, short, short, short, char __huge *);
  225. void __far __cdecl _putimage(short, short, char __huge *, short);
  226. long __far __cdecl _imagesize(short, short, short, short);
  227. /* "action verbs" for _putimage() and _setwritemode() */
  228. #define _GPSET 3
  229. #define _GPRESET 2
  230. #define _GAND 1
  231. #define _GOR 0
  232. #define _GXOR 4
  233. /* Color values are used with _setbkcolor in graphics modes and also by
  234. _remappalette and _remapallpalette. Also known as palette colors.
  235. Not to be confused with color indices (aka. color attributes). */
  236. /* universal color values (all color modes): */
  237. #define _BLACK 0x000000L
  238. #define _BLUE 0x2a0000L
  239. #define _GREEN 0x002a00L
  240. #define _CYAN 0x2a2a00L
  241. #define _RED 0x00002aL
  242. #define _MAGENTA 0x2a002aL
  243. #define _BROWN 0x00152aL
  244. #define _WHITE 0x2a2a2aL
  245. #define _GRAY 0x151515L
  246. #define _LIGHTBLUE 0x3F1515L
  247. #define _LIGHTGREEN 0x153f15L
  248. #define _LIGHTCYAN 0x3f3f15L
  249. #define _LIGHTRED 0x15153fL
  250. #define _LIGHTMAGENTA 0x3f153fL
  251. #define _YELLOW 0x153f3fL
  252. #define _BRIGHTWHITE 0x3f3f3fL
  253. /* the following is obsolescent and defined only for backward compatibility */
  254. #define _LIGHTYELLOW _YELLOW
  255. /* mono mode F (_ERESNOCOLOR) color values: */
  256. #define _MODEFOFF 0L
  257. #define _MODEFOFFTOON 1L
  258. #define _MODEFOFFTOHI 2L
  259. #define _MODEFONTOOFF 3L
  260. #define _MODEFON 4L
  261. #define _MODEFONTOHI 5L
  262. #define _MODEFHITOOFF 6L
  263. #define _MODEFHITOON 7L
  264. #define _MODEFHI 8L
  265. /* mono mode 7 (_TEXTMONO) color values: */
  266. #define _MODE7OFF 0L
  267. #define _MODE7ON 1L
  268. #define _MODE7HI 2L
  269. /* Warning: these '_xy' entrypoints are undocumented.
  270. They may or may not be supported in future versions. */
  271. struct _xycoord __far __cdecl _moveto_xy(struct _xycoord);
  272. short __far __cdecl _lineto_xy(struct _xycoord);
  273. short __far __cdecl _rectangle_xy(short,struct _xycoord,struct _xycoord);
  274. short __far __cdecl _arc_xy(struct _xycoord, struct _xycoord, struct _xycoord, struct _xycoord);
  275. short __far __cdecl _ellipse_xy(short, struct _xycoord, struct _xycoord);
  276. short __far __cdecl _pie_xy(short, struct _xycoord, struct _xycoord, struct _xycoord, struct _xycoord);
  277. short __far __cdecl _getpixel_xy(struct _xycoord);
  278. short __far __cdecl _setpixel_xy(struct _xycoord);
  279. short __far __cdecl _floodfill_xy(struct _xycoord, short);
  280. void __far __cdecl _getimage_xy(struct _xycoord,struct _xycoord, char __huge *);
  281. long __far __cdecl _imagesize_xy(struct _xycoord,struct _xycoord);
  282. void __far __cdecl _putimage_xy(struct _xycoord, char __huge *, short);
  283. /* WINDOW COORDINATE SYSTEM */
  284. #ifndef _WXYCOORD_DEFINED
  285. /* structure for window coordinate pair */
  286. struct _wxycoord {
  287. double wx; /* window x coordinate */
  288. double wy; /* window y coordinate */
  289. };
  290. #define _WXYCOORD_DEFINED
  291. #endif
  292. /* define real coordinate window - returns non-zero if successful */
  293. short __far __cdecl _setwindow(short,double,double,double,double);
  294. /* convert from view to window coordinates */
  295. struct _wxycoord __far __cdecl _getwindowcoord(short,short);
  296. struct _wxycoord __far __cdecl _getwindowcoord_xy(struct _xycoord);
  297. /* convert from window to view coordinates */
  298. struct _xycoord __far __cdecl _getviewcoord_w(double,double);
  299. struct _xycoord __far __cdecl _getviewcoord_wxy(const struct _wxycoord __far *);
  300. /* return the window coordinates of the current graphics output
  301. position as an _wxycoord structure. no error return. */
  302. struct _wxycoord __far __cdecl _getcurrentposition_w(void);
  303. /* window coordinate entry points for graphics output routines */
  304. /* returns nonzero if successful; otherwise 0 */
  305. short __far __cdecl _arc_w(double, double, double, double, double, double, double, double);
  306. short __far __cdecl _arc_wxy(const struct _wxycoord __far *, const struct _wxycoord __far *, const struct _wxycoord __far *, const struct _wxycoord __far *);
  307. /* returns nonzero if successful; otherwise 0 */
  308. short __far __cdecl _ellipse_w(short, double, double, double, double);
  309. short __far __cdecl _ellipse_wxy(short, const struct _wxycoord __far *, const struct _wxycoord __far *);
  310. /* returns nonzero if successful; otherwise 0 */
  311. short __far __cdecl _floodfill_w(double, double, short);
  312. /* returns pixel value at given point; -1 if unsuccessful. */
  313. short __far __cdecl _getpixel_w(double, double);
  314. /* returns nonzero if successful; otherwise 0 */
  315. short __far __cdecl _lineto_w(double, double);
  316. /* returns the view coordinates of the previous output
  317. position as a _wxycoord structure. no error return */
  318. struct _wxycoord __far __cdecl _moveto_w(double, double);
  319. /* returns nonzero if successful; otherwise 0 */
  320. short __far __cdecl _pie_w(short, double, double, double, double, double, double, double, double);
  321. short __far __cdecl _pie_wxy(short, const struct _wxycoord __far *, const struct _wxycoord __far *, const struct _wxycoord __far *, const struct _wxycoord __far *);
  322. /* returns nonzero if successful; otherwise 0 */
  323. short __far __cdecl _rectangle_w(short, double, double, double, double);
  324. short __far __cdecl _rectangle_wxy(short, const struct _wxycoord __far *, const struct _wxycoord __far *);
  325. /* returns nonzero if successful; otherwise 0 */
  326. short __far __cdecl _polygon_w(short, const double __far *, short);
  327. short __far __cdecl _polygon_wxy(short, const struct _wxycoord __far *, short);
  328. /* returns previous color; -1 if unsuccessful */
  329. short __far __cdecl _setpixel_w(double, double);
  330. /* window coordinate image routines */
  331. /* no return value */
  332. void __far __cdecl _getimage_w(double, double, double, double, char __huge *);
  333. void __far __cdecl _getimage_wxy(const struct _wxycoord __far *, const struct _wxycoord __far *, char __huge *);
  334. /* returns the image's storage size in bytes */
  335. long __far __cdecl _imagesize_w(double, double, double, double);
  336. long __far __cdecl _imagesize_wxy(const struct _wxycoord __far *, const struct _wxycoord __far *);
  337. /* no return value */
  338. void __far __cdecl _putimage_w(double, double ,char __huge * ,short);
  339. /* FONTS */
  340. #ifndef _FONTINFO_DEFINED
  341. /* structure for _getfontinfo() */
  342. struct _fontinfo {
  343. int type; /* b0 set = vector,clear = bit map */
  344. int ascent; /* pix dist from top to baseline */
  345. int pixwidth; /* character width in pixels, 0=prop */
  346. int pixheight; /* character height in pixels */
  347. int avgwidth; /* average character width in pixels */
  348. char filename[81]; /* file name including path */
  349. char facename[32]; /* font name */
  350. };
  351. #define _FONTINFO_DEFINED
  352. #endif
  353. /* font function prototypes */
  354. short __far __cdecl _registerfonts( const char __far *);
  355. void __far __cdecl _unregisterfonts( void );
  356. short __far __cdecl _setfont( const char __far * );
  357. short __far __cdecl _getfontinfo( struct _fontinfo __far * );
  358. void __far __cdecl _outgtext( const char __far * );
  359. short __far __cdecl _getgtextextent( const char __far * );
  360. struct _xycoord __far __cdecl _setgtextvector( short, short );
  361. struct _xycoord __far __cdecl _getgtextvector(void);
  362. #ifdef _WINDOWS
  363. /* QuickWin graphics extension prototypes */
  364. int __far __cdecl _wgclose( int );
  365. int __far __cdecl _wggetactive( void );
  366. int __far __cdecl _wgopen( char __far * );
  367. int __far __cdecl _wgsetactive( int );
  368. #endif
  369. /* restore default packing */
  370. #pragma pack()
  371. #ifdef __cplusplus
  372. }
  373. #endif