3 <TITLE>DisplayDriver.htm
</TITLE>
4 <style type=
"text/css">
6 .Default {background-color: rgb
(255,255,255); color: rgb
(0,0,0); font-family: 'Dutch801 Rm BT'; font-size: 12pt}
7 .OBOS-Function-Def {background-color: rgb
(255,255,255); color: rgb
(0,0,0); font-family: 'Dutch801 Rm BT'; font-size: 16pt}
8 .OBOS-Title {background-color: rgb
(255,255,255); color: rgb
(0,128,0); font-family: 'Dutch801 Rm BT'; font-size: 24pt}
9 .Text-Background {background-color: rgb
(255,255,255)}
14 .WP-Default {text-align: left
; text-indent: 0px; margin-left: 0px; margin-right: 0px}
18 <BODY BGCOLOR=
"#ffffff">
19 <DIV class=
"sheet" id=
"Sheet 1">
20 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Title">DisplayDriver class
</span><span style=
"color: rgb(0,0,0); font-size: 24pt"></span></P>
21 <P class=
"Body" style=
"margin: 0px"><BR>
23 <P class=
"Body" style=
"margin: 0px">The DisplayDriver class is not a useful class unto itself. It is to provide a consistent interface for the rest of the app_server to whatever rendering context it is utilizing, whether it be a remote screen, a ServerBitmap, installed graphics hardware, or whatever. Documentation below will describe the role of each function.
</P>
24 <P class=
"Body" style=
"margin: 0px">
27 <P class=
"Body" style=
"margin: 0px">Member Functions
</P>
28 <P class=
"Body" style=
"margin: 0px"><BR>
30 <TABLE WIDTH=
464 HEIGHT=
474 BORDER=
1 CELLPADDING=
1 CELLSPACING=
2>
32 <TD WIDTH=
224 HEIGHT=
17>
33 <P class=
"Body" style=
"margin: 0px">DisplayDriver(void)
</P>
35 <TD WIDTH=
240 HEIGHT=
17>
36 <P class=
"Body" style=
"margin: 0px">~DisplayDriver(void)
</P>
40 <TD WIDTH=
224 HEIGHT=
17>
41 <P class=
"Body" style=
"margin: 0px">bool Initialize(void)
</P>
43 <TD WIDTH=
240 HEIGHT=
17>
44 <P class=
"Body" style=
"margin: 0px">void Shutdown(void)
</P>
48 <TD WIDTH=
224 HEIGHT=
32>
49 <P class=
"Body" style=
"margin: 0px">void DrawBitmap(ServerBitmap *bmp, BRect src, BRect dest)
</P>
51 <TD WIDTH=
240 HEIGHT=
32>
52 <P class=
"Body" style=
"margin: 0px">void DrawChar(char c, BPoint pt)
</P>
56 <TD WIDTH=
224 HEIGHT=
47>
57 <P class=
"Body" style=
"margin: 0px">void DrawString(const char *string, int32 length, BPoint pt, escapement_delta *delta=NULL)
</P>
59 <TD WIDTH=
240 HEIGHT=
47>
60 <P class=
"Body" style=
"margin: 0px">void Stroke/FillBezier(BPoint *pts, layerdata *d, int8 *pat)
</P>
64 <TD WIDTH=
224 HEIGHT=
32>
65 <P class=
"Body" style=
"margin: 0px">void Stroke/FillEllipse(BRect r, layerdata *d, int8 *pattern)
</P>
67 <TD WIDTH=
240 HEIGHT=
32>
68 <P class=
"Body" style=
"margin: 0px">void Stroke/FillArc(BRect r, float angle, float span, layerdata *d, int8 *pattern)
</P>
72 <TD WIDTH=
224 HEIGHT=
47>
73 <P class=
"Body" style=
"margin: 0px">void StrokeLine(BPoint start, BPoint end, layerdata *d, int8 *pattern)
</P>
75 <TD WIDTH=
240 HEIGHT=
47>
76 <P class=
"Body" style=
"margin: 0px">void StrokePolygon(BPoint *ptlist, int32 numpts, BRect rect, layerdata *d, int8 *pattern, bool is_closed=true)
</P>
80 <TD WIDTH=
224 HEIGHT=
47>
81 <P class=
"Body" style=
"margin: 0px">void FillPolygon(BPoint *ptlist, int32 numpts, BRect rect, layerdata *d, int8 *pattern)
</P>
83 <TD WIDTH=
240 HEIGHT=
47>
84 <P class=
"Body" style=
"margin: 0px">void Stroke/FillRect(BRect r, layerdata *d, int8 *pattern)
</P>
88 <TD WIDTH=
224 HEIGHT=
47>
89 <P class=
"Body" style=
"margin: 0px">void Stroke/FillRoundRect(BRect r, float xrad, float yrad, layerdata *d, int8 *pattern)
</P>
91 <TD WIDTH=
240 HEIGHT=
47>
92 <P class=
"Body" style=
"margin: 0px">void Stroke/FillShape(SShape *sh, layerdata *d, int8 *pattern)
</P>
96 <TD WIDTH=
224 HEIGHT=
32>
97 <P class=
"Body" style=
"margin: 0px">void Stroke/FillTriangle(BPoints *pts, BRect r, layerdata *d, int8 *pattern)
</P>
99 <TD WIDTH=
240 HEIGHT=
32>
100 <P class=
"Body" style=
"margin: 0px">void StrokeLineArray(BPoint *pts, int32 numlines, rgb_color *colors, layerdata *d)
</P>
104 <TD WIDTH=
224 HEIGHT=
22>
105 <P class=
"Body" style=
"margin: 0px">void DrawPicture(SPicture *pic, BPoint pt)
</P>
107 <TD WIDTH=
240 HEIGHT=
22>
108 <P class=
"Body" style=
"margin: 0px">void CopyBits(BRect src, BRect dest)
</P>
112 <TD WIDTH=
224 HEIGHT=
17>
113 <P class=
"Body" style=
"margin: 0px">void InvertRect(BRect r)
</P>
115 <TD WIDTH=
240 HEIGHT=
17>
116 <P class=
"Body" style=
"margin: 0px">uint8 GetDepth(void)
</P>
120 <TD WIDTH=
224 HEIGHT=
17>
121 <P class=
"Body" style=
"margin: 0px">uint16 GetHeight(void)
</P>
123 <TD WIDTH=
240 HEIGHT=
17>
124 <P class=
"Body" style=
"margin: 0px">uint16 GetWidth(void)
</P>
128 <TD WIDTH=
224 HEIGHT=
17>
129 <P class=
"Body" style=
"margin: 0px">screen_mode GetMode(void)
</P>
131 <TD WIDTH=
240 HEIGHT=
17>
132 <P class=
"Body" style=
"margin: 0px">void SetMode(screen_mode mode)
</P>
136 <TD WIDTH=
224 HEIGHT=
17>
137 <P class=
"Body" style=
"margin: 0px">bool DumpToFile(const char *path)
</P>
139 <TD WIDTH=
240 HEIGHT=
17>
140 <P class=
"Body" style=
"margin: 0px">void ShowCursor(void)
</P>
144 <TD WIDTH=
224 HEIGHT=
17>
145 <P class=
"Body" style=
"margin: 0px">void HideCursor(void)
</P>
147 <TD WIDTH=
240 HEIGHT=
17>
148 <P class=
"Body" style=
"margin: 0px">void ObscureCursor(void)
</P>
152 <TD WIDTH=
224 HEIGHT=
17>
153 <P class=
"Body" style=
"margin: 0px">bool IsCursorHidden(void)
</P>
155 <TD WIDTH=
240 HEIGHT=
17>
156 <P class=
"Body" style=
"margin: 0px">void SetCursor(ServerCursor *csr)
</P>
160 <TD WIDTH=
224 HEIGHT=
32>
161 <P class=
"Body" style=
"margin: 0px">virtual float StringWidth(const char *string, int32 length, LayerData *d)
</P>
163 <TD WIDTH=
240 HEIGHT=
32>
164 <P class=
"Body" style=
"margin: 0px">virtual float StringHeight(const char *string, int32 length, LayerData *d)
</P>
168 <P class=
"Body" style=
"margin: 0px"><BR>
170 Protected Functions
</P>
171 <P class=
"Body" style=
"margin: 0px"><BR>
173 <TABLE WIDTH=
533 HEIGHT=
90 BORDER=
1 CELLPADDING=
1 CELLSPACING=
2>
175 <TD WIDTH=
200 HEIGHT=
17>
176 <P class=
"Body" style=
"margin: 0px">void Lock(void)
</P>
178 <TD WIDTH=
200 HEIGHT=
17>
179 <P class=
"Body" style=
"margin: 0px">void Unlock(void)
</P>
183 <TD WIDTH=
200 HEIGHT=
17>
184 <P class=
"Body" style=
"margin: 0px">void SetDepth(void)
</P>
186 <TD WIDTH=
200 HEIGHT=
17>
187 <P class=
"Body" style=
"margin: 0px">void SetHeight(void)
</P>
191 <TD WIDTH=
200 HEIGHT=
17>
192 <P class=
"Body" style=
"margin: 0px">void SetWidth(void)
</P>
194 <TD WIDTH=
200 HEIGHT=
17>
195 <P class=
"Body" style=
"margin: 0px">void SetMode(void)
</P>
199 <TD WIDTH=
200 HEIGHT=
17>
200 <P class=
"Body" style=
"margin: 0px">void SetCursorHidden(void)
</P>
202 <TD WIDTH=
200 HEIGHT=
17>
203 <P class=
"Body" style=
"margin: 0px">void SetCursorObscured(void)
</P>
207 <P class=
"Body" style=
"margin: 0px"><BR>
211 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">DisplayDriver(void)
</span></P>
212 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">~DisplayDriver(void)
</span></P>
213 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">bool Initialize(void)
</span></P>
214 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void Shutdown(void)
</span></P>
215 <P class=
"Body" style=
"margin: 0px"><BR>
216 These four are for general start and stop procedures. The constructor and destructor concern themselves with the internal members common to all drivers, such as the current cursor and the access semaphore. Subclasses will probably end up using these to handle memory allocation-related issues, but likely not much else. Initialize() and Shutdown() are for general setup internal to the module. Note that if Initialize() returns false, the server will not use the module, call Shutdown(), and then delete it as accordingly.
</P>
217 <P class=
"Body" style=
"margin: 0px"><BR>
218 <span class=
"OBOS-Function-Def">void CopyBits(BRect src, BRect dest)
</span></P>
219 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void InvertRect(BRect r)
</span></P>
220 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void DrawBitmap(ServerBitmap *bmp, BRect src, BRect dest, render_mode mode)
</span></P>
221 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void DrawPicture(SPicture *pic, BPoint pt)
</span></P>
222 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void DrawChar(char c, BPoint pt)
</span></P>
223 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void DrawString(const char *string, int32 length, BPoint pt, escapement_delta *delta=NULL)
</span></P>
224 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def"><BR>
225 void StrokeArc(BRect r, float angle, float span, layerdata *d, int8 *pattern)
</span></P>
226 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void FillArc(BRect r, float angle, float span, layerdata *d, int8 *pattern)
</span></P>
227 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void StrokeBezier(BPoint *pts, layerdata *d, int8 *pat)
</span></P>
228 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void FillBezier(BPoint *pts, layerdata *d, int8 *pat)
</span></P>
229 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void StrokeEllipse(BRect r, layerdata *d, int8 *pattern)
</span></P>
230 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void FillEllipse(BRect r, layerdata *d, int8 *pattern)
</span></P>
231 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void StrokeLine(BPoint start, BPoint end, layerdata *d, int8 *pattern)
</span></P>
232 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void StrokeLineArray(BPoint *pts, int32 numlines, rgb_color *colors, layerdata *d)
</span></P>
233 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void StrokePolygon(BPoint *ptlist, int32 numpts, BRect rect, layerdata *d, int8 *pattern, bool is_closed=true)
</span></P>
234 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void FillPolygon(BPoint *ptlist, int32 numpts, BRect rect, layerdata *d, int8 *pattern)
</span></P>
235 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void StrokeRect(BRect r, layerdata *d, int8 *pattern)
</span></P>
236 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void FillRect(BRect r, layerdata *d, int8 *pattern)
</span></P>
237 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void StrokeRoundRect(BRect r, float xrad, float yrad, layerdata *d, int8 *pattern)
</span></P>
238 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void FillRoundRect(BRect r, float xrad, float yrad, layerdata *d, int8 *pattern)
</span></P>
239 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void StrokeShape(SShape *sh, layerdata *d, int8 *pattern)
</span></P>
240 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void FillShape(SShape *sh, layerdata *d, int8 *pattern)
</span></P>
241 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void StrokeTriangle(BPoints *pts, BRect r, layerdata *d, int8 *pattern)
</span></P>
242 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void FillTriangle(BPoints *pts, BRect r, layerdata *d, int8 *pattern)
</span></P>
243 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void ShowCursor(void)
</span></P>
244 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void HideCursor(void)
</span></P>
245 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void ObscureCursor(void)
</span></P>
246 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">bool IsCursorHidden(void)
</span></P>
247 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void SetCursor(ServerCursor *csr)
</span></P>
248 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">float StringWidth(const char *string, int32 length, LayerData *d)
</span></P>
249 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">float StringHeight(const char *string, int32 length, LayerData *d)
</span></P>
250 <P class=
"Body" style=
"margin: 0px"><BR>
251 These drawing functions are the meat and potatoes of the graphics module. Defining any or all of them is completely optional. However, the default versions of these functions will do nothing. Thus, implementing them is likely a good idea, even if not required.
</P>
252 <P class=
"Body" style=
"margin: 0px"><BR>
254 <span class=
"OBOS-Function-Def">uint8 GetDepth(void)
</span></P>
255 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">uint16 GetHeight(void)
</span></P>
256 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">uint16 GetWidth(void)
</span></P>
257 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">screen_mode GetMode(void)
</span></P>
258 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void SetMode(screen_mode mode)
</span></P>
259 <P class=
"Body" style=
"margin: 0px"><BR>
260 These five functions are called internally in order to get information about the current state of the buffer in the module. GetDepth should return
8,
16, or
32, in any event because the server handles RGB color spaces of these depths only.
</P>
261 <P class=
"Body" style=
"margin: 0px"><BR>
262 <span class=
"OBOS-Function-Def">bool DumpToFile(const char *path)
</span></P>
263 <P class=
"Body" style=
"margin: 0px"><BR>
264 DumpToFile is completely optional, providing a hook which allows screenshots to be taken. The default version does nothing but return false. If a screenshot is successful, return true.
</P>
265 <P class=
"Body" style=
"margin: 0px"><BR>
267 <span class=
"OBOS-Function-Def">void Lock(void)
</span></P>
268 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void Unlock(void)
</span></P>
269 <P class=
"Body" style=
"margin: 0px"><BR>
270 These two functions provide a locking scheme for the driver in order to easily make it thread safe. Note that it is not publicly callable.
</P>
271 <P class=
"Body" style=
"margin: 0px"><BR>
273 <span class=
"OBOS-Function-Def">void SetDepthInternal(uint8 d)
</span></P>
274 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void SetHeightInternal(uint16 h)
</span></P>
275 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void SetWidthInternal(uint16 w)
</span></P>
276 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void SetModeInternal(int32 m)
</span></P>
277 <P class=
"Body" style=
"margin: 0px"><BR>
278 These four functions set the internal state variables for height, width, etc. If the driver reimplements the public members SetDepth(), etc, be sure to call the respective internal call so that calls to GetDepth(), etc. return the proper values.
</P>
279 <P class=
"Body" style=
"margin: 0px"><BR>
281 <span class=
"OBOS-Function-Def">void SetCursorHidden(bool state)
</span></P>
282 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">void SetCursorObscured(bool state)
</span></P>
283 <P class=
"Body" style=
"margin: 0px"><span class=
"OBOS-Function-Def">bool IsCursorObscured(void)
</span></P>
284 <P class=
"Body" style=
"margin: 0px"><BR>
285 These calls handle internal state tracking so that subclasses don't have to.
</P>
286 <DIV class=
"layer" id=
"Layer 1">