source: trunk/src/gdi32/oslibgpi.cpp@ 2802

Last change on this file since 2802 was 2802, checked in by sandervl, 26 years ago

Added new logging feature

File size: 9.0 KB
Line 
1/* $Id: oslibgpi.cpp,v 1.4 2000-02-16 14:18:11 sandervl Exp $ */
2
3/*
4 * GPI interface code
5 *
6 * Copyright 1999 Christoph Bratschi (cbratschi@datacomm.ch)
7 *
8 * Project Odin Software License can be found in LICENSE.TXT
9 *
10 */
11
12#define INCL_GPI
13#define INCL_WIN
14#include <os2wrap.h> //Odin32 OS/2 api wrappers
15#include <stdlib.h>
16#include <string.h>
17#include <math.h>
18#include "win32type.h"
19#include "oslibgpi.h"
20#include "dcdata.h"
21
22#define DBG_LOCALLOG DBG_oslibgpi
23#include "dbglocal.h"
24
25#define GetDCData(a) ((pDCData)a)
26
27LONG APIENTRY _GpiQueryTabbedTextExtent(HPS hps,LONG lCount,PCH pchString,LONG lTabCount,PULONG puTabStops);
28
29inline LONG GpiQueryTabbedTextExtent(HPS hps,LONG lCount,PCH pchString,LONG lTabCount,PULONG puTabStops)
30{
31 LONG yyrc;
32 USHORT sel = RestoreOS2FS();
33
34 yyrc = _GpiQueryTabbedTextExtent(hps,lCount,pchString,lTabCount,puTabStops);
35 SetFS(sel);
36
37 return yyrc;
38}
39
40LONG APIENTRY _GpiTabbedCharStringAt(HPS hps,PPOINTL pPtStart,PRECTL prclRect,ULONG flOptions,LONG lCount,PCH pchString,LONG lTabCount,PULONG puTabStops,LONG lTabOrigin);
41
42inline LONG GpiTabbedCharStringAt(HPS hps,PPOINTL pPtStart,PRECTL prclRect,ULONG flOptions,LONG lCount,PCH pchString,LONG lTabCount,PULONG puTabStops,LONG lTabOrigin)
43{
44 LONG yyrc;
45 USHORT sel = RestoreOS2FS();
46
47 yyrc = _GpiTabbedCharStringAt(hps,pPtStart,prclRect,flOptions,lCount,pchString,lTabCount,puTabStops,lTabOrigin);
48 SetFS(sel);
49
50 return yyrc;
51}
52
53void inline swap(LONG &a,LONG &b)
54{
55 LONG temp = a;
56
57 a = b;
58 b = temp;
59}
60
61void inline swap(int &a,int &b)
62{
63 int temp = a;
64
65 a = b;
66 b = temp;
67}
68
69void inline sortAscending(LONG &a,LONG &b)
70{
71 if (a > b) swap(a,b);
72}
73
74void inline sortAscending(int &a,int &b)
75{
76 if (a > b) swap(a,b);
77}
78
79void inline sortAscending(POINTLOS2 &a,POINTLOS2 &b)
80{
81 sortAscending(a.x,b.x);
82 sortAscending(a.y,b.y);
83}
84
85BOOL excludeBottomRightPoint(PVOID pHps,PPOINTLOS2 pptl)
86{
87 sortAscending(pptl[0],pptl[1]);
88
89 if (GetDCData(pHps)->graphicsMode != GM_COMPATIBLE_W)
90 {
91 return TRUE;
92 }
93
94 if (pptl[0].x == pptl[1].x || pptl[0].y == pptl[1].y)
95 {
96 return FALSE;
97 }
98
99 if (abs((int)GetDCData(pHps)->viewportXExt) <= abs((int)GetDCData(pHps)->windowExt.cx))
100 {
101 if (GetDCData(pHps)->isLeftLeft)
102 pptl[1].x -= abs(GetDCData(pHps)->worldXDeltaFor1Pixel);
103 else
104 pptl[0].x += abs(GetDCData(pHps)->worldXDeltaFor1Pixel);
105 }
106
107 if (abs((int)GetDCData(pHps)->viewportYExt) <= abs((int)GetDCData(pHps)->windowExt.cy))
108 {
109 if (GetDCData(pHps)->isTopTop)
110 pptl[1].y -= abs(GetDCData(pHps)->worldYDeltaFor1Pixel);
111 else
112 pptl[0].y += abs(GetDCData(pHps)->worldYDeltaFor1Pixel);
113 }
114
115 sortAscending(pptl[0], pptl[1]);
116
117 return TRUE;
118}
119
120BOOL getAlignUpdateCP(PVOID pHps)
121{
122 return GetDCData(pHps)->alignUpdateCP;
123}
124
125INT getWorldYDeltaFor1Pixel(PVOID pHps)
126{
127 return GetDCData(pHps)->worldYDeltaFor1Pixel;
128}
129
130INT getWorldXDeltaFor1Pixel(PVOID pHps)
131{
132 return GetDCData(pHps)->worldXDeltaFor1Pixel;
133}
134
135BOOL getInPath(PVOID pHps)
136{
137 return GetDCData(pHps)->inPath;
138}
139
140VOID setInPath(PVOID pHps,BOOL inPath)
141{
142 GetDCData(pHps)->inPath = inPath;
143}
144
145BOOL getIsWideLine(PVOID pHps)
146{
147 return GetDCData(pHps)->isWideLine;
148}
149
150BOOL getIsTopTop(PVOID pHps)
151{
152 return GetDCData(pHps)->isTopTop;
153}
154
155ULONG getMapMode(PVOID pHps)
156{
157 return GetDCData(pHps)->MapMode;
158}
159
160BOOL OSLibGpiQueryCurrentPosition(PVOID pHps,PPOINTLOS2 ptl)
161{
162 return GpiQueryCurrentPosition(GetDCData(pHps)->hps,(PPOINTL)ptl);
163}
164
165BOOL OSLibGpiSetCurrentPosition(PVOID pHps,PPOINTLOS2 ptl)
166{
167 return GpiSetCurrentPosition(GetDCData(pHps)->hps,(PPOINTL)ptl);
168}
169
170BOOL OSLibGpiCharStringPosAt(PVOID pHps,PPOINTLOS2 ptl,PRECTLOS2 rct,ULONG flOptions,LONG lCount,LPCSTR pchString,CONST INT *alAdx)
171{
172 return GpiCharStringPosAt(GetDCData(pHps)->hps,(PPOINTL)ptl,(PRECTL)rct,flOptions,lCount,(PCH)pchString,(PLONG)alAdx);
173}
174
175BOOL OSLibGpiQueryCharStringPosAt(PVOID pHps,PPOINTLOS2 ptl,ULONG flOptions,LONG lCount,LPCSTR pchString,CONST INT *alAdx,PPOINTLOS2 aptlPos)
176{
177 return GpiQueryCharStringPosAt(GetDCData(pHps)->hps,(PPOINTL)ptl,flOptions,lCount,(PCH)pchString,(PLONG)alAdx,(PPOINTL)aptlPos);
178}
179
180BOOL OSLibGpiSetTextAlignment(PVOID pHps,LONG lHoriz,LONG lVert)
181{
182 return GpiSetTextAlignment(GetDCData(pHps)->hps,lHoriz,lVert);
183}
184
185BOOL OSLibGpiQueryTextAlignment(PVOID pHps,PLONG plHoriz,PLONG plVert)
186{
187 return GpiQueryTextAlignment(GetDCData(pHps)->hps,plHoriz,plVert);
188}
189
190LONG OSLibGpiQueryTabbedTextExtent(PVOID pHps,INT lCount,LPCSTR pchString,INT lTabCount,PINT puTabStops)
191{
192 return GpiQueryTabbedTextExtent(GetDCData(pHps)->hps,lCount,(PCH)pchString,lTabCount,(PULONG)puTabStops);
193}
194
195LONG OSLibGpiTabbedCharStringAt(PVOID pHps,PPOINTLOS2 pPtStart,PRECTLOS2 prclRect,ULONG flOptions,INT lCount,LPCSTR pchString,INT lTabCount,PINT puTabStops,INT lTabOrigin)
196{
197 return GpiTabbedCharStringAt(GetDCData(pHps)->hps,(PPOINTL)pPtStart,(PRECTL)prclRect,flOptions,lCount,(PCH)pchString,lTabCount,(PULONG)puTabStops,lTabOrigin);
198}
199
200BOOL OSLibGpiQueryTextBox(PVOID pHps,LONG lCount1,LPCSTR pchString,LONG lCount2,PPOINTLOS2 aptlPoints)
201{
202 return GpiQueryTextBox(GetDCData(pHps)->hps,lCount1,(PCH)pchString,lCount2,(PPOINTL)aptlPoints);
203}
204
205VOID calcDimensions(POINTLOS2 box[],PPOINTLOS2 point)
206{
207 ULONG cx;
208 ULONG cy;
209
210 if (box[TXTBOX_BOTTOMLEFT].y == box[TXTBOX_BOTTOMRIGHT].y)
211 {
212 point->y = labs (box[TXTBOX_BOTTOMLEFT].y-box[TXTBOX_TOPLEFT].y);
213 point->x = labs (box[TXTBOX_CONCAT].x-box[TXTBOX_BOTTOMLEFT].x);
214
215 if (box[TXTBOX_BOTTOMLEFT].x != box[TXTBOX_TOPLEFT].x)
216 {
217 if (point->y < 25)
218 cx = 2;
219 else
220 cx = ((point->y*10)+50)/100;
221 point->x += cx;
222 }
223 } else
224 {
225 cx = labs (box[TXTBOX_BOTTOMLEFT].x-box[TXTBOX_TOPLEFT].x);
226 cy = labs (box[TXTBOX_BOTTOMLEFT].y-box[TXTBOX_TOPLEFT].y);
227 point->y = (ULONG)hypot(cx,cy);
228
229 cx = labs (box[TXTBOX_TOPRIGHT].x-box[TXTBOX_TOPLEFT].x);
230 cy = labs (box[TXTBOX_TOPRIGHT].y-box[TXTBOX_TOPLEFT].y);
231 point->x = (ULONG)hypot(cx,cy);
232 }
233}
234
235LONG OSLibGpiQueryBackMix(PVOID pHps)
236{
237 return GpiQueryBackMix(GetDCData(pHps)->hps);
238}
239
240BOOL doesYAxisGrowNorth(PVOID pHps)
241{
242 if ((GetDCData(pHps)->windowExt.cy < 0 && GetDCData(pHps)->viewportYExt > 0.0) ||
243 (GetDCData(pHps)->windowExt.cy > 0 && GetDCData(pHps)->viewportYExt < 0.0))
244 {
245 if (GetDCData(pHps)->graphicsMode == GM_COMPATIBLE_W ||
246 (GetDCData(pHps)->graphicsMode == GM_ADVANCED_W && GetDCData(pHps)->xform.eM22 >= 0.0))
247 return TRUE;
248 } else
249 {
250 if (GetDCData(pHps)->graphicsMode == GM_ADVANCED_W && GetDCData(pHps)->xform.eM22 < 0.0)
251 return TRUE;
252 }
253
254 return FALSE;
255}
256
257LONG OSLibWinDrawTabbedText(PVOID pHps,LONG cchText,LONG lTabs,LPCSTR lpchText,PVOID prcl,LONG clrFore,LONG clrBack,ULONG flCmd)
258{
259 //return WinDraw
260 //undocumented
261 return 0;
262}
263
264BOOL OSLibGpiMove(PVOID pHps,PPOINTLOS2 pptlPoint)
265{
266 return GpiMove(GetDCData(pHps)->hps,(PPOINTL)pptlPoint);
267}
268
269LONG OSLibGpiLine(PVOID pHps,PPOINTLOS2 pptlEndPoint)
270{
271 return GpiLine(GetDCData(pHps)->hps,(PPOINTL)pptlEndPoint);
272}
273
274#define FSP_ENDPATH 0x00000010
275#define FSP_FILL 0x00000020
276#define FSP_CLOSEPATH 0x00000040
277
278BOOL APIENTRY _PaxStrokeAndFillPath(HPS hPS,ULONG ulAction,ULONG ulStrokeAttrs,PAREABUNDLE pPenStroke);
279
280inline BOOL PaxStrokeAndFillPath(HPS hPS,ULONG ulAction,ULONG ulStrokeAttrs,PAREABUNDLE pPenStroke)
281{
282 BOOL yyrc;
283 USHORT sel = RestoreOS2FS();
284
285 yyrc = _PaxStrokeAndFillPath(hPS,ulAction,ulStrokeAttrs,pPenStroke);
286 SetFS(sel);
287
288 return yyrc;
289}
290
291BOOL OSLibGpiEndPath(PVOID pHps)
292{
293 return GpiEndPath(GetDCData(pHps)->hps);
294}
295
296BOOL drawLinePointCircle(PVOID pHps,INT width,INT height,LONG color)
297{
298 ARCPARAMS arcp;
299 BOOL rc = TRUE;
300
301 arcp.lP = 1;
302 arcp.lQ = 1;
303 arcp.lR = 0;
304 arcp.lS = 0;
305 if (!GpiSetArcParams(GetDCData(pHps)->hps,&arcp))
306 return FALSE;
307
308 AREABUNDLE newAreaBundle, oldAreaBundle;
309 LINEBUNDLE lineBundle;
310
311 GpiQueryAttrs(GetDCData(pHps)->hps,PRIM_AREA,ABB_COLOR | ABB_MIX_MODE | ABB_SET | ABB_SYMBOL,(PBUNDLE)&oldAreaBundle);
312 GpiQueryAttrs(GetDCData(pHps)->hps,PRIM_LINE,LBB_MIX_MODE, (PBUNDLE)&lineBundle);
313
314 newAreaBundle = oldAreaBundle;
315 newAreaBundle.lColor = color;
316 newAreaBundle.usMixMode = lineBundle.usMixMode;
317 newAreaBundle.usSet = LCID_DEFAULT;
318 newAreaBundle.usSymbol = PATSYM_SOLID;
319
320 if (!GpiSetAttrs(GetDCData(pHps)->hps,PRIM_AREA,ABB_COLOR | ABB_MIX_MODE | ABB_SET | ABB_SYMBOL,0,(PBUNDLE)&newAreaBundle))
321 return FALSE;
322
323 if (GpiFullArc(GetDCData(pHps)->hps,DRO_FILL,MAKEFIXED((width-1)>>1,0)) == GPI_ERROR)
324 rc = FALSE;
325 GpiSetAttrs(GetDCData(pHps)->hps,PRIM_AREA,ABB_COLOR | ABB_MIX_MODE | ABB_SET | ABB_SYMBOL,0,(PBUNDLE)&oldAreaBundle);
326
327 return rc;
328}
329
330BOOL drawLinePoint(PVOID pHps,PPOINTLOS2 pt,LONG color)
331{
332 LINEBUNDLE lbOld, lbNew;
333 LONG defaults = GpiQueryAttrs(GetDCData(pHps)->hps, PRIM_LINE, LBB_COLOR, &lbOld);
334
335 lbNew.lColor = color;
336 BOOL rc = GpiSetAttrs(GetDCData(pHps)->hps,PRIM_LINE,LBB_COLOR,0,&lbNew) && GpiSetPel(GetDCData(pHps)->hps,(PPOINTL)pt) != GPI_ERROR;
337
338 GpiSetAttrs(GetDCData(pHps)->hps,PRIM_LINE,LBB_COLOR,defaults,&lbOld);
339
340 return rc;
341}
342
343ULONG OSLibGpiQueryCp(HDC hdc)
344{
345 return GpiQueryCp(hdc);
346}
347
348BOOL OSLibGpiSetCp(HDC hdc, ULONG codepage)
349{
350 return GpiSetCp(hdc, codepage);
351}
352
Note: See TracBrowser for help on using the repository browser.