Mercurial > dwindows
annotate win/dw.c @ 14:176cee043f1b
Lots of Windows and Unix bug fixes.
author | bsmith@81767d24-ef19-dc11-ae90-00e081727c95 |
---|---|
date | Wed, 11 Jul 2001 21:57:56 +0000 |
parents | 26e2130135b9 |
children | 81833f25b1aa |
rev | line source |
---|---|
3 | 1 /* |
2 * Dynamic Windows: | |
3 * A GTK like implementation of the Win32 GUI | |
4 * | |
5 * (C) 2000,2001 Brian Smith <dbsoft@technologist.com> | |
6 * | |
7 */ | |
8 #define _WIN32_IE 0x0500 | |
9 #define WINVER 0x400 | |
10 #include <windows.h> | |
11 #include <windowsx.h> | |
12 #include <commctrl.h> | |
13 #include <stdlib.h> | |
14 #include <string.h> | |
15 #include <stdio.h> | |
16 #include <process.h> | |
17 #include "dw.h" | |
18 | |
19 /* this is the callback handle for the window procedure */ | |
20 /* make sure you always match the calling convention! */ | |
21 int (*filterfunc)(HWND, UINT, WPARAM, LPARAM) = 0L; | |
22 | |
23 HWND hwndBubble = (HWND)NULL, hwndBubbleLast, DW_HWND_OBJECT = (HWND)NULL; | |
24 | |
25 HINSTANCE DWInstance = NULL; | |
26 | |
27 DWORD dwVersion = 0; | |
28 | |
29 /* I should probably check the actual file version, but this will do for now */ | |
30 #define IS_WIN98PLUS (LOBYTE(LOWORD(dwVersion)) > 4 || \ | |
31 (LOBYTE(LOWORD(dwVersion)) == 4 && HIBYTE(LOWORD(dwVersion)) > 0)) | |
32 | |
33 char monthlist[][4] = { "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", | |
34 "Sep", "Oct", "Nov", "Dec" }; | |
35 | |
36 int main(int argc, char *argv[]); | |
37 | |
38 #define ICON_INDEX_LIMIT 200 | |
39 HICON lookup[200]; | |
40 HIMAGELIST hSmall, hLarge; | |
41 | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
42 #define THREAD_LIMIT 128 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
43 COLORREF _foreground[THREAD_LIMIT]; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
44 COLORREF _background[THREAD_LIMIT]; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
45 HPEN _hPen[THREAD_LIMIT]; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
46 HBRUSH _hBrush[THREAD_LIMIT]; |
3 | 47 |
48 #ifdef DWDEBUG | |
49 FILE *f; | |
50 | |
51 void reopen(void) | |
52 { | |
53 fclose(f); | |
54 f = fopen("dw.log", "at"); | |
55 } | |
56 #endif | |
57 | |
58 BYTE _red[] = { 0x00, 0xbb, 0x00, 0xaa, 0x00, 0xbb, 0x00, 0xaa, 0x77, | |
59 0xff, 0x00, 0xee, 0x00, 0xff, 0x00, 0xff, 0xaa, 0x00 }; | |
60 BYTE _green[] = { 0x00, 0x00, 0xbb, 0xaa, 0x00, 0x00, 0xbb, 0xaa, 0x77, | |
61 0x00, 0xff, 0xee, 0x00, 0x00, 0xee, 0xff, 0xaa, 0x00 }; | |
62 BYTE _blue[] = { 0x00, 0x00, 0x00, 0x00, 0xcc, 0xbb, 0xbb, 0xaa, 0x77, | |
63 0x00, 0x00, 0x00, 0xff, 0xff, 0xee, 0xff, 0xaa, 0x00}; | |
64 | |
65 HBRUSH _colors[18]; | |
66 | |
67 static LONG lColor[SPLITBAR_WIDTH] = | |
68 { | |
69 DW_CLR_BLACK, | |
70 DW_CLR_PALEGRAY, | |
71 DW_CLR_WHITE | |
72 }; | |
73 | |
74 void _resize_notebook_page(HWND handle, int pageid); | |
75 | |
76 #ifdef NO_SIGNALS | |
77 #define USE_FILTER | |
78 #else | |
79 typedef struct _sighandler | |
80 { | |
81 struct _sighandler *next; | |
82 ULONG message; | |
83 HWND window; | |
84 void *signalfunction; | |
85 void *data; | |
86 | |
87 } SignalHandler; | |
88 | |
89 SignalHandler *Root = NULL; | |
90 int _index; | |
91 | |
92 typedef struct | |
93 { | |
94 ULONG message; | |
95 char name[30]; | |
96 | |
97 } SignalList; | |
98 | |
99 /* List of signals and their equivilent Win32 message */ | |
14
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
100 #define SIGNALMAX 12 |
3 | 101 |
102 SignalList SignalTranslate[SIGNALMAX] = { | |
103 { WM_SIZE, "configure_event" }, | |
104 { WM_CHAR, "key_press_event" }, | |
105 { WM_LBUTTONDOWN, "button_press_event" }, | |
106 { WM_LBUTTONUP, "button_release_event" }, | |
107 { WM_MOUSEMOVE, "motion_notify_event" }, | |
108 { WM_CLOSE, "delete_event" }, | |
109 { WM_PAINT, "expose_event" }, | |
110 { WM_COMMAND, "clicked" }, | |
111 { NM_DBLCLK, "container-select" }, | |
112 { NM_RCLICK, "container-context" }, | |
14
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
113 { LBN_SELCHANGE, "item-select" }, |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
114 { WM_SETFOCUS, "set-focus" } |
3 | 115 }; |
116 | |
117 #ifdef BUILD_DLL | |
118 void Win32_Set_Instance(HINSTANCE hInstance) | |
119 { | |
120 DWInstance = hInstance; | |
121 } | |
122 #else | |
123 char **_convertargs(int *count, char *start) | |
124 { | |
125 char *tmp, *argstart, **argv; | |
126 int loc = 0, inquotes = 0; | |
127 | |
128 (*count) = 1; | |
129 | |
130 tmp = start; | |
131 | |
132 /* Count the number of entries */ | |
133 if(*start) | |
134 { | |
135 (*count)++; | |
136 | |
137 while(*tmp) | |
138 { | |
139 if(*tmp == '"' && inquotes) | |
140 inquotes = 0; | |
141 else if(*tmp == '"' && !inquotes) | |
142 inquotes = 1; | |
143 else if(*tmp == ' ' && !inquotes) | |
144 { | |
145 /* Push past any white space */ | |
146 while(*(tmp+1) == ' ') | |
147 tmp++; | |
148 /* If we aren't at the end of the command | |
149 * line increment the count. | |
150 */ | |
151 if(*(tmp+1)) | |
152 (*count)++; | |
153 } | |
154 tmp++; | |
155 } | |
156 } | |
157 | |
158 argv = (char **)malloc(sizeof(char *) * ((*count)+1)); | |
159 argv[0] = malloc(260); | |
160 GetModuleFileName(DWInstance, argv[0], 260); | |
161 | |
162 argstart = tmp = start; | |
163 | |
164 if(*start) | |
165 { | |
166 loc = 1; | |
167 | |
168 while(*tmp) | |
169 { | |
170 if(*tmp == '"' && inquotes) | |
171 { | |
172 *tmp = 0; | |
173 inquotes = 0; | |
174 } | |
175 else if(*tmp == '"' && !inquotes) | |
176 { | |
177 argstart = tmp+1; | |
178 inquotes = 1; | |
179 } | |
180 else if(*tmp == ' ' && !inquotes) | |
181 { | |
182 *tmp = 0; | |
183 argv[loc] = strdup(argstart); | |
184 | |
185 /* Push past any white space */ | |
186 while(*(tmp+1) == ' ') | |
187 tmp++; | |
188 | |
189 /* Move the start pointer */ | |
190 argstart = tmp+1; | |
191 | |
192 /* If we aren't at the end of the command | |
193 * line increment the count. | |
194 */ | |
195 if(*(tmp+1)) | |
196 loc++; | |
197 } | |
198 tmp++; | |
199 } | |
200 if(*argstart) | |
201 argv[loc] = strdup(argstart); | |
202 } | |
203 argv[loc+1] = NULL; | |
204 return argv; | |
205 } | |
206 | |
207 /* Ok this is a really big hack but what the hell ;) */ | |
208 int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow) | |
209 { | |
210 char **argv; | |
211 int argc; | |
212 | |
213 DWInstance = hInstance; | |
214 | |
215 argv = _convertargs(&argc, lpCmdLine); | |
216 | |
217 return main(argc, argv); | |
218 } | |
219 #endif | |
220 | |
221 /* This function adds a signal handler callback into the linked list. | |
222 */ | |
223 void _new_signal(ULONG message, HWND window, void *signalfunction, void *data) | |
224 { | |
225 SignalHandler *new = malloc(sizeof(SignalHandler)); | |
226 | |
227 new->message = message; | |
228 new->window = window; | |
229 new->signalfunction = signalfunction; | |
230 new->data = data; | |
231 new->next = NULL; | |
232 | |
233 if (!Root) | |
234 Root = new; | |
235 else | |
236 { | |
237 SignalHandler *prev = NULL, *tmp = Root; | |
238 while(tmp) | |
239 { | |
240 prev = tmp; | |
241 tmp = tmp->next; | |
242 } | |
243 if(prev) | |
244 prev->next = new; | |
245 else | |
246 Root = new; | |
247 } | |
248 } | |
249 | |
250 /* Finds the message number for a given signal name */ | |
251 ULONG _findsigmessage(char *signame) | |
252 { | |
253 int z; | |
254 | |
255 for(z=0;z<SIGNALMAX;z++) | |
256 { | |
257 if(stricmp(signame, SignalTranslate[z].name) == 0) | |
258 return SignalTranslate[z].message; | |
259 } | |
260 return 0L; | |
261 } | |
262 #endif | |
263 | |
264 /* This function removes and handlers on windows and frees | |
265 * the user memory allocated to it. | |
266 */ | |
267 BOOL CALLBACK _free_window_memory(HWND handle, LPARAM lParam) | |
268 { | |
269 void *ptr = (void *)GetWindowLong(handle, GWL_USERDATA); | |
270 | |
271 #ifndef NO_SIGNALS | |
272 dw_signal_disconnect_by_window(handle); | |
273 #endif | |
274 | |
275 if(ptr) | |
276 { | |
277 SetWindowLong(handle, GWL_USERDATA, 0); | |
278 free(ptr); | |
279 } | |
280 return TRUE; | |
281 } | |
282 | |
283 /* This function returns 1 if the window (widget) handle | |
284 * passed to it is a valid window that can gain input focus. | |
285 */ | |
286 int _validate_focus(HWND handle) | |
287 { | |
288 char tmpbuf[100]; | |
289 | |
290 if(!handle) | |
291 return 0; | |
292 | |
293 GetClassName(handle, tmpbuf, 99); | |
294 | |
295 /* These are the window classes which can | |
296 * obtain input focus. | |
297 */ | |
298 if(strnicmp(tmpbuf, EDITCLASSNAME, strlen(EDITCLASSNAME))==0 || /* Entryfield */ | |
299 strnicmp(tmpbuf, BUTTONCLASSNAME, strlen(BUTTONCLASSNAME))==0 || /* Button */ | |
300 strnicmp(tmpbuf, COMBOBOXCLASSNAME, strlen(COMBOBOXCLASSNAME))==0 || /* Combobox */ | |
301 strnicmp(tmpbuf, LISTBOXCLASSNAME, strlen(LISTBOXCLASSNAME))==0 || /* List box */ | |
302 strnicmp(tmpbuf, UPDOWN_CLASS, strlen(UPDOWN_CLASS))==0 || /* Spinbutton */ | |
303 strnicmp(tmpbuf, WC_LISTVIEW, strlen(WC_LISTVIEW))== 0) /* Container */ | |
304 return 1; | |
305 return 0; | |
306 } | |
307 | |
308 HWND _normalize_handle(HWND handle) | |
309 { | |
310 char tmpbuf[100] = ""; | |
311 | |
312 GetClassName(handle, tmpbuf, 99); | |
313 if(strnicmp(tmpbuf, UPDOWN_CLASS, strlen(UPDOWN_CLASS))==0) /* Spinner */ | |
314 { | |
315 ColorInfo *cinfo = (ColorInfo *)GetWindowLong(handle, GWL_USERDATA); | |
316 | |
317 if(cinfo && cinfo->buddy) | |
318 return cinfo->buddy; | |
319 } | |
320 return handle; | |
321 } | |
322 | |
323 int _focus_check_box(Box *box, HWND handle, int start) | |
324 { | |
325 int z; | |
326 static HWND lasthwnd, firsthwnd; | |
327 static int finish_searching; | |
328 | |
329 /* Start is 2 when we have cycled completely and | |
330 * need to set the focus to the last widget we found | |
331 * that was valid. | |
332 */ | |
333 if(start == 2) | |
334 { | |
335 if(lasthwnd) | |
336 SetFocus(lasthwnd); | |
337 return 0; | |
338 } | |
339 | |
340 /* Start is 1 when we are entering the function | |
341 * for the first time, it is zero when entering | |
342 * the function recursively. | |
343 */ | |
344 if(start == 1) | |
345 { | |
346 lasthwnd = handle; | |
347 finish_searching = 0; | |
348 firsthwnd = 0; | |
349 } | |
350 | |
351 for(z=box->count-1;z>-1;z--) | |
352 { | |
353 if(box->items[z].type == TYPEBOX) | |
354 { | |
355 Box *thisbox = (Box *)GetWindowLong(box->items[z].hwnd, GWL_USERDATA); | |
356 | |
357 if(thisbox && _focus_check_box(thisbox, handle, start == 3 ? 3 : 0)) | |
358 return 1; | |
359 } | |
360 else | |
361 { | |
362 if(box->items[z].hwnd == handle) | |
363 { | |
364 if(lasthwnd == handle && firsthwnd) | |
365 SetFocus(firsthwnd); | |
366 else if(lasthwnd == handle && !firsthwnd) | |
367 finish_searching = 1; | |
368 else | |
369 SetFocus(lasthwnd); | |
370 | |
371 /* If we aren't looking for the last handle, | |
372 * return immediately. | |
373 */ | |
374 if(!finish_searching) | |
375 return 1; | |
376 } | |
377 if(_validate_focus(box->items[z].hwnd)) | |
378 { | |
379 /* Start is 3 when we are looking for the | |
380 * first valid item in the layout. | |
381 */ | |
382 if(start == 3) | |
383 { | |
384 SetFocus(_normalize_handle(box->items[z].hwnd)); | |
385 return 1; | |
386 } | |
387 | |
388 if(!firsthwnd) | |
389 firsthwnd = _normalize_handle(box->items[z].hwnd); | |
390 | |
391 lasthwnd = _normalize_handle(box->items[z].hwnd); | |
392 } | |
393 else | |
394 { | |
395 char tmpbuf[100] = ""; | |
396 | |
397 GetClassName(box->items[z].hwnd, tmpbuf, 99); | |
398 | |
399 if(strnicmp(tmpbuf, WC_TABCONTROL, strlen(WC_TABCONTROL))==0) /* Notebook */ | |
400 { | |
401 NotebookPage **array = (NotebookPage **)GetWindowLong(box->items[z].hwnd, GWL_USERDATA); | |
402 int pageid = TabCtrl_GetCurSel(box->items[z].hwnd); | |
403 | |
404 if(pageid > -1 && array && array[pageid]) | |
405 { | |
406 Box *notebox; | |
407 | |
408 if(array[pageid]->hwnd) | |
409 { | |
410 notebox = (Box *)GetWindowLong(array[pageid]->hwnd, GWL_USERDATA); | |
411 | |
412 if(notebox && _focus_check_box(notebox, handle, start == 3 ? 3 : 0)) | |
413 return 1; | |
414 } | |
415 } | |
416 } | |
417 } | |
418 } | |
419 } | |
420 return 0; | |
421 } | |
422 | |
423 /* This function finds the first widget in the | |
424 * layout and moves the current focus to it. | |
425 */ | |
426 void _initial_focus(HWND handle) | |
427 { | |
428 Box *thisbox; | |
429 | |
430 if(handle) | |
431 thisbox = (Box *)GetWindowLong(handle, GWL_USERDATA); | |
432 | |
433 if(thisbox) | |
434 { | |
435 _focus_check_box(thisbox, handle, 3); | |
436 } | |
437 } | |
438 | |
439 /* This function finds the current widget in the | |
440 * layout and moves the current focus to the next item. | |
441 */ | |
442 void _shift_focus(HWND handle) | |
443 { | |
444 Box *thisbox; | |
445 | |
446 HWND box, lastbox = GetParent(handle); | |
447 | |
448 /* Find the toplevel window */ | |
449 while((box = GetParent(lastbox))) | |
450 { | |
451 lastbox = box; | |
452 } | |
453 | |
454 thisbox = (Box *)GetWindowLong(lastbox, GWL_USERDATA); | |
455 if(thisbox) | |
456 { | |
457 if(_focus_check_box(thisbox, handle, 1) == 0) | |
458 _focus_check_box(thisbox, handle, 2); | |
459 } | |
460 } | |
461 | |
462 /* ResetWindow: | |
463 * Resizes window to the exact same size to trigger | |
464 * recalculation of frame. | |
465 */ | |
466 void _ResetWindow(HWND hwndFrame) | |
467 { | |
468 RECT rcl; | |
469 | |
470 GetWindowRect(hwndFrame, &rcl); | |
471 SetWindowPos(hwndFrame, HWND_TOP, 0, 0, rcl.right - rcl.left, | |
472 rcl.bottom - rcl.top - 1, SWP_NOMOVE | SWP_NOZORDER); | |
473 SetWindowPos(hwndFrame, HWND_TOP, 0, 0, rcl.right - rcl.left, | |
474 rcl.bottom - rcl.top, SWP_NOMOVE | SWP_NOZORDER); | |
475 } | |
476 | |
477 /* Function: TrackRectangle | |
478 * Abstract: Tracks given rectangle. | |
479 * | |
480 * If rclBounds is NULL, then track rectangle on entire desktop. | |
481 * rclTrack is in window coorditates and will be mapped to | |
482 * desktop. | |
483 */ | |
484 | |
485 BOOL _TrackRectangle(HWND hwndBase, RECTL* rclTrack, RECTL* rclBounds) | |
486 { | |
487 ULONG rc = 0; | |
488 #if 0 | |
489 TRACKINFO track; | |
490 | |
491 track.cxBorder = 1; | |
492 track.cyBorder = 1; | |
493 track.cxGrid = 1; | |
494 track.cyGrid = 1; | |
495 track.cxKeyboard = 8; | |
496 track.cyKeyboard = 8; | |
497 | |
498 if(!rclTrack) | |
499 return FALSE; | |
500 | |
501 if(rclBounds) | |
502 { | |
503 track.rclBoundary = *rclBounds; | |
504 } | |
505 else | |
506 { | |
507 track.rclBoundary.yTop = | |
508 track.rclBoundary.xRight = 3000; | |
509 track.rclBoundary.yBottom = | |
510 track.rclBoundary.xLeft = -3000; | |
511 } | |
512 | |
513 track.rclTrack = *rclTrack; | |
514 | |
515 MapWindowPoints(hwndBase, | |
516 HWND_DESKTOP, | |
517 (PPOINT)&track.rclTrack, | |
518 2); | |
519 | |
520 track.ptlMinTrackSize.x = track.rclTrack.xRight | |
521 - track.rclTrack.xLeft; | |
522 track.ptlMinTrackSize.y = track.rclTrack.yTop | |
523 - track.rclTrack.yBottom; | |
524 track.ptlMaxTrackSize.x = track.rclTrack.xRight | |
525 - track.rclTrack.xLeft; | |
526 track.ptlMaxTrackSize.y = track.rclTrack.yTop | |
527 - track.rclTrack.yBottom; | |
528 | |
529 track.fs = TF_MOVE | TF_ALLINBOUNDARY; | |
530 | |
531 rc = WinTrackRect(HWND_DESKTOP, 0, &track); | |
532 | |
533 if(rc) | |
534 *rclTrack = track.rclTrack; | |
535 | |
536 #endif | |
537 return rc; | |
538 } | |
539 | |
540 /* This function calculates how much space the widgets and boxes require | |
541 * and does expansion as necessary. | |
542 */ | |
543 int _resize_box(Box *thisbox, int *depth, int x, int y, int *usedx, int *usedy, | |
544 int pass, int *usedpadx, int *usedpady) | |
545 { | |
546 int z, currentx = 0, currenty = 0; | |
547 int uymax = 0, uxmax = 0; | |
548 int upymax = 0, upxmax = 0; | |
549 /* Used for the SIZEEXPAND */ | |
550 int nux = *usedx, nuy = *usedy; | |
551 int nupx = *usedpadx, nupy = *usedpady; | |
552 | |
553 (*usedx) += (thisbox->pad * 2); | |
554 (*usedy) += (thisbox->pad * 2); | |
555 | |
556 for(z=0;z<thisbox->count;z++) | |
557 { | |
558 if(thisbox->items[z].type == TYPEBOX) | |
559 { | |
560 int initialx, initialy; | |
561 Box *tmp = (Box *)GetWindowLong(thisbox->items[z].hwnd, GWL_USERDATA); | |
562 | |
563 initialx = x - (*usedx); | |
564 initialy = y - (*usedy); | |
565 | |
566 if(tmp) | |
567 { | |
568 int newx, newy; | |
569 int nux = *usedx, nuy = *usedy; | |
570 int upx = *usedpadx + (tmp->pad*2), upy = *usedpady + (tmp->pad*2); | |
571 | |
572 /* On the second pass we know how big the box needs to be and how | |
573 * much space we have, so we can calculate a ratio for the new box. | |
574 */ | |
575 if(pass == 2) | |
576 { | |
577 int deep = *depth + 1; | |
578 | |
579 _resize_box(tmp, &deep, x, y, &nux, &nuy, 1, &upx, &upy); | |
580 | |
581 tmp->upx = upx - *usedpadx; | |
582 tmp->upy = upy - *usedpady; | |
583 | |
584 newx = x - nux; | |
585 newy = y - nuy; | |
586 | |
587 tmp->width = thisbox->items[z].width = initialx - newx; | |
588 tmp->height = thisbox->items[z].height = initialy - newy; | |
589 | |
590 tmp->parentxratio = thisbox->xratio; | |
591 tmp->parentyratio = thisbox->yratio; | |
592 | |
593 tmp->parentpad = tmp->pad; | |
594 | |
595 /* Just in case */ | |
596 tmp->xratio = thisbox->xratio; | |
597 tmp->yratio = thisbox->yratio; | |
598 | |
599 #ifdef DWDEBUG | |
600 if(pass > 1) | |
601 { | |
602 fprintf(f, "FARK! depth %d\r\nwidth = %d, height = %d, nux = %d, nuy = %d, upx = %d, upy = %d xratio = %f, yratio = %f\r\n\r\n", | |
603 *depth, thisbox->items[z].width, thisbox->items[z].height, nux, nuy, tmp->upx, tmp->upy, tmp->xratio, tmp->yratio); | |
604 reopen(); | |
605 } | |
606 #endif | |
607 if(thisbox->type == BOXVERT) | |
608 { | |
609 if((thisbox->items[z].width-((thisbox->items[z].pad*2)+(tmp->pad*2)))!=0) | |
610 tmp->xratio = ((float)((thisbox->items[z].width * thisbox->xratio)-((thisbox->items[z].pad*2)+(tmp->pad*2))))/((float)(thisbox->items[z].width-((thisbox->items[z].pad*2)+(tmp->pad*2)))); | |
611 } | |
612 else | |
613 { | |
614 if((thisbox->items[z].width-tmp->upx)!=0) | |
615 tmp->xratio = ((float)((thisbox->items[z].width * thisbox->xratio)-tmp->upx))/((float)(thisbox->items[z].width-tmp->upx)); | |
616 } | |
617 if(thisbox->type == BOXHORZ) | |
618 { | |
619 if((thisbox->items[z].height-((thisbox->items[z].pad*2)+(tmp->pad*2)))!=0) | |
620 tmp->yratio = ((float)((thisbox->items[z].height * thisbox->yratio)-((thisbox->items[z].pad*2)+(tmp->pad*2))))/((float)(thisbox->items[z].height-((thisbox->items[z].pad*2)+(tmp->pad*2)))); | |
621 } | |
622 else | |
623 { | |
624 if((thisbox->items[z].height-tmp->upy)!=0) | |
625 tmp->yratio = ((float)((thisbox->items[z].height * thisbox->yratio)-tmp->upy))/((float)(thisbox->items[z].height-tmp->upy)); | |
626 } | |
627 | |
628 nux = *usedx; nuy = *usedy; | |
629 upx = *usedpadx + (tmp->pad*2); upy = *usedpady + (tmp->pad*2); | |
630 } | |
631 | |
632 (*depth)++; | |
633 | |
634 #ifdef DWDEBUG | |
635 if(pass > 1) | |
636 { | |
637 fprintf(f, "Before Resize Box depth %d\r\nx = %d, y = %d, usedx = %d, usedy = %d, usedpadx = %d, usedpady = %d xratio = %f, yratio = %f\r\n\r\n", | |
638 *depth, x, y, *usedx, *usedy, *usedpadx, *usedpady, tmp->xratio, tmp->yratio); | |
639 reopen(); | |
640 } | |
641 #endif | |
642 | |
643 _resize_box(tmp, depth, x, y, &nux, &nuy, pass, &upx, &upy); | |
644 | |
645 (*depth)--; | |
646 | |
647 newx = x - nux; | |
648 newy = y - nuy; | |
649 | |
650 tmp->minwidth = thisbox->items[z].width = initialx - newx; | |
651 tmp->minheight = thisbox->items[z].height = initialy - newy; | |
652 | |
653 #ifdef DWDEBUG | |
654 if(pass > 1) | |
655 { | |
656 fprintf(f, "After Resize Box depth %d\r\nx = %d, y = %d, usedx = %d, usedy = %d, usedpadx = %d, usedpady = %d width = %d, height = %d\r\n\r\n", | |
657 *depth, x, y, *usedx, *usedy, *usedpadx, *usedpady, thisbox->items[z].width, thisbox->items[z].height); | |
658 reopen(); | |
659 } | |
660 #endif | |
661 } | |
662 } | |
663 | |
664 if(pass > 1 && *depth > 0) | |
665 { | |
666 if(thisbox->type == BOXVERT) | |
667 thisbox->items[z].xratio = ((float)((thisbox->width * thisbox->parentxratio)-((thisbox->items[z].pad*2)+(thisbox->parentpad*2))))/((float)(thisbox->minwidth-((thisbox->items[z].pad*2)+(thisbox->parentpad*2)))); | |
668 else | |
669 thisbox->items[z].xratio = ((float)((thisbox->width * thisbox->parentxratio)-thisbox->upx))/((float)(thisbox->minwidth-thisbox->upx)); | |
670 | |
671 if(thisbox->type == BOXHORZ) | |
672 thisbox->items[z].yratio = ((float)((thisbox->height * thisbox->parentyratio)-((thisbox->items[z].pad*2)+(thisbox->parentpad*2))))/((float)(thisbox->minheight-((thisbox->items[z].pad*2)+(thisbox->parentpad*2)))); | |
673 else | |
674 thisbox->items[z].yratio = ((float)((thisbox->height * thisbox->parentyratio)-thisbox->upy))/((float)(thisbox->minheight-thisbox->upy)); | |
675 #ifdef DWDEBUG | |
676 fprintf(f, "RATIO- xratio = %f, yratio = %f, width = %d, height = %d, pad = %d, box xratio = %f, box yratio = %f, parent xratio = %f, parent yratio = %f, minwidth = %d, minheight = %d, width = %d, height = %d, upx = %d, upy = %d\r\n\r\n", | |
677 thisbox->items[z].xratio, thisbox->items[z].yratio, thisbox->items[z].width, thisbox->items[z].height, thisbox->items[z].pad, thisbox->xratio, thisbox->yratio, thisbox->parentxratio, thisbox->parentyratio, thisbox->minwidth, thisbox->minheight, thisbox->width, thisbox->height, thisbox->upx, thisbox->upy); | |
678 reopen(); | |
679 #endif | |
680 } | |
681 else | |
682 { | |
683 thisbox->items[z].xratio = thisbox->xratio; | |
684 thisbox->items[z].yratio = thisbox->yratio; | |
685 } | |
686 | |
687 if(thisbox->type == BOXVERT) | |
688 { | |
689 if((thisbox->items[z].width + (thisbox->items[z].pad*2)) > uxmax) | |
690 uxmax = (thisbox->items[z].width + (thisbox->items[z].pad*2)); | |
691 if(thisbox->items[z].hsize != SIZEEXPAND) | |
692 { | |
693 if(((thisbox->items[z].pad*2) + thisbox->items[z].width) > upxmax) | |
694 upxmax = (thisbox->items[z].pad*2) + thisbox->items[z].width; | |
695 } | |
696 else | |
697 { | |
698 if(thisbox->items[z].pad*2 > upxmax) | |
699 upxmax = thisbox->items[z].pad*2; | |
700 } | |
701 } | |
702 else | |
703 { | |
704 if(thisbox->items[z].width == -1) | |
705 { | |
706 /* figure out how much space this item requires */ | |
707 /* thisbox->items[z].width = */ | |
708 } | |
709 else | |
710 { | |
711 (*usedx) += thisbox->items[z].width + (thisbox->items[z].pad*2); | |
712 if(thisbox->items[z].hsize != SIZEEXPAND) | |
713 (*usedpadx) += (thisbox->items[z].pad*2) + thisbox->items[z].width; | |
714 else | |
715 (*usedpadx) += thisbox->items[z].pad*2; | |
716 } | |
717 } | |
718 if(thisbox->type == BOXHORZ) | |
719 { | |
720 if((thisbox->items[z].height + (thisbox->items[z].pad*2)) > uymax) | |
721 uymax = (thisbox->items[z].height + (thisbox->items[z].pad*2)); | |
722 if(thisbox->items[z].vsize != SIZEEXPAND) | |
723 { | |
724 if(((thisbox->items[z].pad*2) + thisbox->items[z].height) > upymax) | |
725 upymax = (thisbox->items[z].pad*2) + thisbox->items[z].height; | |
726 } | |
727 else | |
728 { | |
729 if(thisbox->items[z].pad*2 > upymax) | |
730 upymax = thisbox->items[z].pad*2; | |
731 } | |
732 } | |
733 else | |
734 { | |
735 if(thisbox->items[z].height == -1) | |
736 { | |
737 /* figure out how much space this item requires */ | |
738 /* thisbox->items[z].height = */ | |
739 } | |
740 else | |
741 { | |
742 (*usedy) += thisbox->items[z].height + (thisbox->items[z].pad*2); | |
743 if(thisbox->items[z].vsize != SIZEEXPAND) | |
744 (*usedpady) += (thisbox->items[z].pad*2) + thisbox->items[z].height; | |
745 else | |
746 (*usedpady) += thisbox->items[z].pad*2; | |
747 } | |
748 } | |
749 } | |
750 | |
751 (*usedx) += uxmax; | |
752 (*usedy) += uymax; | |
753 (*usedpadx) += upxmax; | |
754 (*usedpady) += upymax; | |
755 | |
756 currentx += thisbox->pad; | |
757 currenty += thisbox->pad; | |
758 | |
759 #ifdef DWDEBUG | |
760 fprintf(f, "Done Calc depth %d\r\nusedx = %d, usedy = %d, usedpadx = %d, usedpady = %d, currentx = %d, currenty = %d, uxmax = %d, uymax = %d\r\n\r\n", | |
761 *depth, *usedx, *usedy, *usedpadx, *usedpady, currentx, currenty, uxmax, uymax); | |
762 reopen(); | |
763 #endif | |
764 | |
765 /* The second pass is for expansion and actual placement. */ | |
766 if(pass > 1) | |
767 { | |
768 /* Any SIZEEXPAND items should be set to uxmax/uymax */ | |
769 for(z=0;z<thisbox->count;z++) | |
770 { | |
771 if(thisbox->items[z].hsize == SIZEEXPAND && thisbox->type == BOXVERT) | |
772 thisbox->items[z].width = uxmax-(thisbox->items[z].pad*2); | |
773 if(thisbox->items[z].vsize == SIZEEXPAND && thisbox->type == BOXHORZ) | |
774 thisbox->items[z].height = uymax-(thisbox->items[z].pad*2); | |
775 /* Run this code segment again to finalize the sized after setting uxmax/uymax values. */ | |
776 if(thisbox->items[z].type == TYPEBOX) | |
777 { | |
778 Box *tmp = (Box *)GetWindowLong(thisbox->items[z].hwnd, GWL_USERDATA); | |
779 | |
780 if(tmp) | |
781 { | |
782 if(*depth > 0) | |
783 { | |
784 if(thisbox->type == BOXVERT) | |
785 { | |
786 tmp->xratio = ((float)((thisbox->items[z].width * thisbox->xratio)-((thisbox->items[z].pad*2)+(thisbox->pad*2))))/((float)(tmp->minwidth-((thisbox->items[z].pad*2)+(thisbox->pad*2)))); | |
787 tmp->width = thisbox->items[z].width; | |
788 } | |
789 if(thisbox->type == BOXHORZ) | |
790 { | |
791 tmp->yratio = ((float)((thisbox->items[z].height * thisbox->yratio)-((thisbox->items[z].pad*2)+(thisbox->pad*2))))/((float)(tmp->minheight-((thisbox->items[z].pad*2)+(thisbox->pad*2)))); | |
792 tmp->height = thisbox->items[z].height; | |
793 } | |
794 } | |
795 | |
796 (*depth)++; | |
797 | |
798 /*tmp->xratio = ((float)((thisbox->items[z].width * thisbox->xratio)-tmp->upx) )/((float)(tmp->minwidth-tmp->upx)); | |
799 tmp->yratio = ((float)((thisbox->items[z].height * thisbox->yratio)-tmp->upy))/((float)(tmp->minheight-tmp->upy));*/ | |
800 | |
801 #ifdef DWDEBUG | |
802 fprintf(f, "2- Resize Box depth %d\r\nx = %d, y = %d, usedx = %d, usedy = %d, usedpadx = %d, usedpady = %d xratio = %f, yratio = %f,\r\nupx = %d, upy = %d, width = %d, height = %d, minwidth = %d, minheight = %d, box xratio = %f, box yratio = %f\r\n\r\n", | |
803 *depth, x, y, *usedx, *usedy, *usedpadx, *usedpady, tmp->xratio, tmp->yratio, tmp->upx, tmp->upy, thisbox->items[z].width, thisbox->items[z].height, tmp->minwidth, tmp->minheight, thisbox->xratio, thisbox->yratio); | |
804 reopen(); | |
805 #endif | |
806 | |
807 _resize_box(tmp, depth, x, y, &nux, &nuy, 3, &nupx, &nupy); | |
808 | |
809 (*depth)--; | |
810 | |
811 } | |
812 } | |
813 } | |
814 | |
815 for(z=0;z<(thisbox->count);z++) | |
816 { | |
817 int height = thisbox->items[z].height; | |
818 int width = thisbox->items[z].width; | |
819 int pad = thisbox->items[z].pad; | |
820 HWND handle = thisbox->items[z].hwnd; | |
821 int vectorx, vectory; | |
822 | |
823 /* When upxmax != pad*2 then ratios are incorrect. */ | |
824 vectorx = (int)((width*thisbox->items[z].xratio)-width); | |
825 vectory = (int)((height*thisbox->items[z].yratio)-height); | |
826 | |
827 if(width > 0 && height > 0) | |
828 { | |
829 char tmpbuf[100]; | |
830 /* This is a hack to fix rounding of the sizing */ | |
831 if(*depth == 0) | |
832 { | |
833 vectorx++; | |
834 vectory++; | |
835 } | |
836 | |
837 /* If this item isn't going to expand... reset the vectors to 0 */ | |
838 if(thisbox->items[z].vsize != SIZEEXPAND) | |
839 vectory = 0; | |
840 if(thisbox->items[z].hsize != SIZEEXPAND) | |
841 vectorx = 0; | |
842 | |
843 GetClassName(handle, tmpbuf, 99); | |
844 | |
845 if(strnicmp(tmpbuf, COMBOBOXCLASSNAME, strlen(COMBOBOXCLASSNAME))==0) | |
846 { | |
847 /* Handle special case Combobox */ | |
848 SetWindowPos(handle, HWND_TOP, currentx + pad, currenty + pad, | |
849 width + vectorx, (height + vectory) + 400, 0); | |
850 } | |
851 else if(strnicmp(tmpbuf, UPDOWN_CLASS, strlen(UPDOWN_CLASS))==0) | |
852 { | |
853 /* Handle special case Spinbutton */ | |
854 ColorInfo *cinfo = (ColorInfo *)GetWindowLong(handle, GWL_USERDATA); | |
855 | |
856 SetWindowPos(handle, HWND_TOP, currentx + pad + ((width + vectorx) - 20), currenty + pad, | |
857 20, height + vectory, 0); | |
858 | |
859 if(cinfo) | |
860 { | |
861 SetWindowPos(cinfo->buddy, HWND_TOP, currentx + pad, currenty + pad, | |
862 (width + vectorx) - 20, height + vectory, 0); | |
863 } | |
864 } | |
865 else | |
866 { | |
867 /* Everything else */ | |
868 SetWindowPos(handle, HWND_TOP, currentx + pad, currenty + pad, | |
869 width + vectorx, height + vectory, 0); | |
870 if(thisbox->items[z].type == TYPEBOX) | |
871 { | |
872 Box *boxinfo = (Box *)GetWindowLong(handle, GWL_USERDATA); | |
873 | |
874 if(boxinfo && boxinfo->grouphwnd) | |
875 SetWindowPos(boxinfo->grouphwnd, HWND_TOP, 0, 0, | |
876 width + vectorx, height + vectory, 0); | |
877 | |
878 } | |
879 } | |
880 | |
881 /* Notebook dialog requires additional processing */ | |
882 if(strncmp(tmpbuf, WC_TABCONTROL, strlen(WC_TABCONTROL))==0) | |
883 { | |
884 RECT rect; | |
885 NotebookPage **array = (NotebookPage **)GetWindowLong(handle, GWL_USERDATA); | |
886 int pageid = TabCtrl_GetCurSel(handle); | |
887 | |
888 if(pageid > -1 && array && array[pageid]) | |
889 { | |
890 GetClientRect(handle,&rect); | |
891 TabCtrl_AdjustRect(handle,FALSE,&rect); | |
892 MoveWindow(array[pageid]->hwnd,rect.left,rect.top, | |
893 rect.right - rect.left,rect.bottom-rect.top, | |
894 TRUE); | |
895 ShowWindow(array[pageid]->hwnd,SW_SHOWNORMAL); | |
896 } | |
897 } | |
898 | |
899 #ifdef DWDEBUG | |
900 fprintf(f, "Window Pos depth %d\r\ncurrentx = %d, currenty = %d, pad = %d, width = %d, height = %d, vectorx = %d, vectory = %d, Box type = %s\r\n\r\n", | |
901 *depth, currentx, currenty, pad, width, height, vectorx, vectory,thisbox->type == BOXHORZ ? "Horizontal" : "Vertical"); | |
902 reopen(); | |
903 #endif | |
904 | |
905 if(thisbox->type == BOXHORZ) | |
906 currentx += width + vectorx + (pad * 2); | |
907 if(thisbox->type == BOXVERT) | |
908 currenty += height + vectory + (pad * 2); | |
909 } | |
910 } | |
911 } | |
912 return 0; | |
913 } | |
914 | |
915 void _do_resize(Box *thisbox, int x, int y) | |
916 { | |
917 if(x != 0 && y != 0) { | |
918 if(thisbox) | |
919 { | |
920 int usedx = 0, usedy = 0, depth = 0, usedpadx = 0, usedpady = 0; | |
921 | |
922 _resize_box(thisbox, &depth, x, y, &usedx, &usedy, 1, &usedpadx, &usedpady); | |
923 | |
924 thisbox->xratio = ((float)(x-usedpadx))/((float)(usedx-usedpadx)); | |
925 thisbox->yratio = ((float)(y-usedpady))/((float)(usedy-usedpady)); | |
926 | |
927 #ifdef DWDEBUG | |
928 fprintf(f, "WM_SIZE Resize Box Pass 1\r\nx = %d, y = %d, usedx = %d, usedy = %d, usedpadx = %d, usedpady = %d xratio = %f, yratio = %f\r\n\r\n", | |
929 x, y, usedx, usedy, usedpadx, usedpady, thisbox->xratio, thisbox->yratio); | |
930 reopen(); | |
931 #endif | |
932 | |
933 usedpadx = usedpady = usedx = usedy = depth = 0; | |
934 | |
935 _resize_box(thisbox, &depth, x, y, &usedx, &usedy, 2, &usedpadx, &usedpady); | |
936 #ifdef DWDEBUG | |
937 fprintf(f, "WM_SIZE Resize Box Pass 2\r\nx = %d, y = %d, usedx = %d, usedy = %d, usedpadx = %d, usedpady = %d\r\n", | |
938 x, y, usedx, usedy, usedpadx, usedpady); | |
939 reopen(); | |
940 #endif | |
941 } | |
942 } | |
943 } | |
944 | |
945 /* The main window procedure for Dynamic Windows, all the resizing code is done here. */ | |
946 BOOL CALLBACK _wndproc(HWND hWnd, UINT msg, WPARAM mp1, LPARAM mp2) | |
947 { | |
948 int result = -1; | |
949 static int command_active = 0; | |
950 #ifndef NO_SIGNALS | |
951 SignalHandler *tmp = Root; | |
952 #endif | |
953 void (* windowfunc)(PVOID); | |
954 ULONG origmsg = msg; | |
955 | |
956 if(msg == WM_RBUTTONDOWN || msg == WM_MBUTTONDOWN) | |
957 msg = WM_LBUTTONDOWN; | |
958 if(msg == WM_RBUTTONUP || msg == WM_MBUTTONUP) | |
959 msg = WM_LBUTTONUP; | |
960 | |
961 if(filterfunc) | |
962 result = filterfunc(hWnd, msg, mp1, mp2); | |
963 | |
964 #ifndef NO_SIGNALS | |
965 if(result == -1) | |
966 { | |
967 /* Avoid infinite recursion */ | |
968 command_active = 1; | |
969 | |
970 /* Find any callbacks for this function */ | |
971 while(tmp) | |
972 { | |
973 if(tmp->message == msg || msg == WM_COMMAND) | |
974 { | |
975 switch(msg) | |
976 { | |
14
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
977 case WM_SETFOCUS: |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
978 { |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
979 int (*setfocusfunc)(HWND, void *) = (int (*)(HWND, void *))tmp->signalfunction; |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
980 |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
981 if(hWnd == tmp->window) |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
982 { |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
983 result = setfocusfunc(tmp->window, tmp->data); |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
984 tmp = NULL; |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
985 } |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
986 } |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
987 break; |
3 | 988 case WM_SIZE: |
989 { | |
990 int (*sizefunc)(HWND, int, int, void *) = tmp->signalfunction; | |
991 | |
992 if(hWnd == tmp->window) | |
993 { | |
994 result = sizefunc(tmp->window, LOWORD(mp2), HIWORD(mp2), tmp->data); | |
995 tmp = NULL; | |
996 } | |
997 } | |
998 break; | |
999 case WM_LBUTTONDOWN: | |
1000 { | |
1001 POINTS pts = MAKEPOINTS(mp2); | |
1002 int (*buttonfunc)(HWND, int, int, int, void *) = (int (*)(HWND, int, int, int, void *))tmp->signalfunction; | |
1003 | |
1004 if(hWnd == tmp->window) | |
1005 { | |
1006 int button; | |
1007 | |
1008 switch(origmsg) | |
1009 { | |
1010 case WM_LBUTTONDOWN: | |
1011 button = 1; | |
1012 break; | |
1013 case WM_RBUTTONDOWN: | |
1014 button = 2; | |
1015 break; | |
1016 case WM_MBUTTONDOWN: | |
1017 button = 3; | |
1018 break; | |
1019 } | |
1020 result = buttonfunc(tmp->window, pts.x, pts.y, button, tmp->data); | |
1021 tmp = NULL; | |
1022 } | |
1023 } | |
1024 break; | |
1025 case WM_LBUTTONUP: | |
1026 { | |
1027 POINTS pts = MAKEPOINTS(mp2); | |
1028 int (*buttonfunc)(HWND, int, int, int, void *) = (int (*)(HWND, int, int, int, void *))tmp->signalfunction; | |
1029 | |
1030 if(hWnd == tmp->window) | |
1031 { | |
1032 int button; | |
1033 | |
1034 switch(origmsg) | |
1035 { | |
1036 case WM_LBUTTONUP: | |
1037 button = 1; | |
1038 break; | |
1039 case WM_RBUTTONUP: | |
1040 button = 2; | |
1041 break; | |
1042 case WM_MBUTTONUP: | |
1043 button = 3; | |
1044 break; | |
1045 } | |
1046 result = buttonfunc(tmp->window, pts.x, pts.y, button, tmp->data); | |
1047 tmp = NULL; | |
1048 } | |
1049 } | |
1050 break; | |
1051 case WM_MOUSEMOVE: | |
1052 { | |
1053 POINTS pts = MAKEPOINTS(mp2); | |
1054 int (*motionfunc)(HWND, int, int, int, void *) = (int (*)(HWND, int, int, int, void *))tmp->signalfunction; | |
1055 | |
1056 if(hWnd == tmp->window) | |
1057 { | |
1058 int keys = 0; | |
1059 | |
1060 if (mp1 & MK_LBUTTON) | |
1061 keys = DW_BUTTON1_MASK; | |
1062 if (mp1 & MK_RBUTTON) | |
1063 keys |= DW_BUTTON2_MASK; | |
1064 if (mp1 & MK_MBUTTON) | |
1065 keys |= DW_BUTTON3_MASK; | |
1066 | |
1067 result = motionfunc(tmp->window, pts.x, pts.y, keys, tmp->data); | |
1068 tmp = NULL; | |
1069 } | |
1070 } | |
1071 break; | |
1072 case WM_CHAR: | |
1073 { | |
1074 int (*keypressfunc)(HWND, int, void *) = tmp->signalfunction; | |
1075 | |
1076 if(hWnd == tmp->window) | |
1077 { | |
1078 result = keypressfunc(tmp->window, LOWORD(mp2), tmp->data); | |
1079 tmp = NULL; | |
1080 } | |
1081 } | |
1082 break; | |
1083 case WM_CLOSE: | |
1084 { | |
1085 int (*closefunc)(HWND, void *) = tmp->signalfunction; | |
1086 | |
1087 if(hWnd == tmp->window) | |
1088 { | |
1089 result = closefunc(tmp->window, tmp->data); | |
1090 tmp = NULL; | |
1091 } | |
1092 } | |
1093 break; | |
1094 case WM_PAINT: | |
1095 { | |
1096 PAINTSTRUCT ps; | |
1097 DWExpose exp; | |
1098 int (*exposefunc)(HWND, DWExpose *, void *) = tmp->signalfunction; | |
1099 | |
1100 if(hWnd == tmp->window) | |
1101 { | |
1102 BeginPaint(hWnd, &ps); | |
1103 exp.x = ps.rcPaint.left; | |
1104 exp.y = ps.rcPaint.top; | |
1105 exp.width = ps.rcPaint.right - ps.rcPaint.left; | |
1106 exp.height = ps.rcPaint.bottom - ps.rcPaint.top; | |
1107 result = exposefunc(hWnd, &exp, tmp->data); | |
1108 EndPaint(hWnd, &ps); | |
1109 } | |
1110 } | |
1111 break; | |
1112 case WM_COMMAND: | |
1113 { | |
1114 int (*clickfunc)(HWND, void *) = tmp->signalfunction; | |
1115 HWND command; | |
1116 ULONG passthru = (ULONG)LOWORD(mp1); | |
1117 ULONG message = HIWORD(mp1); | |
1118 | |
1119 command = (HWND)passthru; | |
1120 | |
1121 if(message == LBN_SELCHANGE || message == CBN_SELCHANGE) | |
1122 { | |
1123 int (*listboxselectfunc)(HWND, int, void *) = tmp->signalfunction; | |
1124 | |
1125 if(tmp->message == LBN_SELCHANGE && tmp->window == (HWND)mp2) | |
1126 { | |
1127 result = listboxselectfunc(tmp->window, dw_listbox_selected(tmp->window), tmp->data); | |
1128 tmp = NULL; | |
1129 } | |
1130 } /* Make sure it's the right window, and the right ID */ | |
1131 else if(tmp->window < (HWND)65536 && command == tmp->window) | |
1132 { | |
1133 result = clickfunc(tmp->window, tmp->data); | |
1134 tmp = NULL; | |
1135 } | |
1136 } | |
1137 break; | |
1138 } | |
1139 } | |
1140 if(tmp) | |
1141 tmp = tmp->next; | |
1142 } | |
1143 command_active = 0; | |
1144 } | |
1145 #endif | |
1146 | |
1147 /* Now that any handlers are done... do normal processing */ | |
1148 switch( msg ) | |
1149 { | |
1150 case WM_PAINT: | |
1151 { | |
1152 PAINTSTRUCT ps; | |
1153 | |
1154 BeginPaint(hWnd, &ps); | |
1155 EndPaint(hWnd, &ps); | |
1156 } | |
1157 break; | |
1158 case WM_SIZE: | |
1159 { | |
1160 static int lastx = -1, lasty = -1; | |
1161 static HWND lasthwnd = 0; | |
1162 | |
1163 if(lastx != LOWORD(mp2) || lasty != HIWORD(mp2) || lasthwnd != hWnd) | |
1164 { | |
1165 Box *mybox = (Box *)GetWindowLong(hWnd, GWL_USERDATA); | |
1166 | |
1167 lastx = LOWORD(mp2); | |
1168 lasty = HIWORD(mp2); | |
1169 lasthwnd = hWnd; | |
1170 | |
1171 _do_resize(mybox,LOWORD(mp2),HIWORD(mp2)); | |
1172 } | |
1173 } | |
1174 break; | |
1175 case WM_CHAR: | |
1176 if(LOWORD(mp1) == '\t') | |
1177 { | |
1178 _shift_focus(hWnd); | |
1179 return TRUE; | |
1180 } | |
1181 break; | |
1182 case WM_USER: | |
1183 windowfunc = (void *)mp1; | |
1184 | |
1185 if(windowfunc) | |
1186 windowfunc((void *)mp2); | |
1187 break; | |
1188 case WM_NOTIFY: | |
1189 { | |
1190 NMHDR FAR *tem=(NMHDR FAR *)mp2; | |
1191 | |
1192 if(tem->code == TCN_SELCHANGING) | |
1193 { | |
1194 int num=TabCtrl_GetCurSel(tem->hwndFrom); | |
1195 NotebookPage **array = (NotebookPage **)GetWindowLong(tem->hwndFrom, GWL_USERDATA); | |
1196 | |
1197 if(num > -1 && array && array[num]) | |
1198 SetParent(array[num]->hwnd, DW_HWND_OBJECT); | |
1199 | |
1200 } | |
1201 else if(tem->code == TCN_SELCHANGE) | |
1202 { | |
1203 int num=TabCtrl_GetCurSel(tem->hwndFrom); | |
1204 NotebookPage **array = (NotebookPage **)GetWindowLong(tem->hwndFrom, GWL_USERDATA); | |
1205 | |
1206 if(num > -1 && array && array[num]) | |
1207 SetParent(array[num]->hwnd, tem->hwndFrom); | |
1208 | |
1209 _resize_notebook_page(tem->hwndFrom, num); | |
1210 } | |
1211 } | |
1212 break; | |
1213 case WM_GETMINMAXINFO: | |
1214 { | |
1215 MINMAXINFO *info = (MINMAXINFO *)mp2; | |
1216 info->ptMinTrackSize.x = 8; | |
1217 info->ptMinTrackSize.y = 8; | |
1218 return 0; | |
1219 } | |
1220 break; | |
1221 case WM_DESTROY: | |
1222 /* Free memory before destroying */ | |
1223 #if 0 | |
1224 /* Is this the right message? I seem to be | |
1225 * getting WM_DESTROY on windows that aren't | |
1226 * being destroyed. | |
1227 */ | |
1228 _free_window_memory(hWnd, 0); | |
1229 EnumChildWindows(hWnd, _free_window_memory, 0); | |
1230 #endif | |
1231 break; | |
1232 } | |
1233 if(filterfunc && result != -1) | |
1234 return result; | |
1235 else | |
1236 return DefWindowProc(hWnd, msg, mp1, mp2); | |
1237 } | |
1238 | |
1239 BOOL CALLBACK _framewndproc(HWND hWnd, UINT msg, WPARAM mp1, LPARAM mp2) | |
1240 { | |
1241 switch( msg ) | |
1242 { | |
1243 case WM_LBUTTONDOWN: | |
1244 case WM_MBUTTONDOWN: | |
1245 case WM_RBUTTONDOWN: | |
1246 SetActiveWindow(hWnd); | |
1247 break; | |
1248 case WM_COMMAND: | |
1249 case WM_NOTIFY: | |
1250 _wndproc(hWnd, msg, mp1, mp2); | |
1251 break; | |
1252 } | |
1253 return DefWindowProc(hWnd, msg, mp1, mp2); | |
1254 } | |
1255 | |
1256 BOOL CALLBACK _rendwndproc(HWND hWnd, UINT msg, WPARAM mp1, LPARAM mp2) | |
1257 { | |
1258 switch( msg ) | |
1259 { | |
1260 case WM_LBUTTONDOWN: | |
1261 case WM_MBUTTONDOWN: | |
1262 case WM_RBUTTONDOWN: | |
1263 SetActiveWindow(hWnd); | |
1264 _wndproc(hWnd, msg, mp1, mp2); | |
1265 break; | |
1266 case WM_LBUTTONUP: | |
1267 case WM_MBUTTONUP: | |
1268 case WM_RBUTTONUP: | |
1269 case WM_MOUSEMOVE: | |
1270 case WM_PAINT: | |
1271 case WM_SIZE: | |
1272 case WM_COMMAND: | |
1273 _wndproc(hWnd, msg, mp1, mp2); | |
1274 break; | |
1275 } | |
1276 return DefWindowProc(hWnd, msg, mp1, mp2); | |
1277 } | |
1278 | |
1279 BOOL CALLBACK _spinnerwndproc(HWND hWnd, UINT msg, WPARAM mp1, LPARAM mp2) | |
1280 { | |
1281 ColorInfo *cinfo; | |
1282 | |
1283 cinfo = (ColorInfo *)GetWindowLong(hWnd, GWL_USERDATA); | |
1284 | |
1285 if(cinfo) | |
1286 { | |
1287 switch( msg ) | |
1288 { | |
1289 case WM_LBUTTONDOWN: | |
1290 case WM_MBUTTONDOWN: | |
1291 case WM_RBUTTONDOWN: | |
1292 case WM_CHAR: | |
1293 { | |
1294 BOOL ret; | |
1295 | |
1296 if(!cinfo || !cinfo->pOldProc) | |
1297 ret = DefWindowProc(hWnd, msg, mp1, mp2); | |
1298 ret = CallWindowProc(cinfo->pOldProc, hWnd, msg, mp1, mp2); | |
1299 | |
1300 /* Tell the edit control that a buttonpress has | |
1301 * occured and to update it's window title. | |
1302 */ | |
1303 if(cinfo->buddy) | |
1304 SendMessage(cinfo->buddy, WM_USER+10, 0, 0); | |
1305 | |
1306 return ret; | |
1307 } | |
1308 break; | |
1309 case WM_USER+10: | |
1310 { | |
1311 if(cinfo->buddy) | |
1312 { | |
1313 char tempbuf[100] = ""; | |
1314 long position; | |
1315 | |
1316 GetWindowText(cinfo->buddy, tempbuf, 99); | |
1317 | |
1318 position = atol(tempbuf); | |
1319 | |
1320 if(IS_WIN98PLUS) | |
1321 SendMessage(hWnd, UDM_SETPOS32, 0, (LPARAM)position); | |
1322 else | |
1323 SendMessage(hWnd, UDM_SETPOS, 0, (LPARAM)MAKELONG((short)position, 0)); | |
1324 } | |
1325 } | |
1326 break; | |
1327 } | |
1328 } | |
1329 | |
1330 if(!cinfo || !cinfo->pOldProc) | |
1331 return DefWindowProc(hWnd, msg, mp1, mp2); | |
1332 return CallWindowProc(cinfo->pOldProc, hWnd, msg, mp1, mp2); | |
1333 } | |
1334 | |
1335 BOOL CALLBACK _colorwndproc(HWND hWnd, UINT msg, WPARAM mp1, LPARAM mp2) | |
1336 { | |
1337 ColorInfo *cinfo; | |
1338 char tmpbuf[100]; | |
1339 | |
1340 cinfo = (ColorInfo *)GetWindowLong(hWnd, GWL_USERDATA); | |
1341 | |
1342 GetClassName(hWnd, tmpbuf, 99); | |
1343 if(strcmp(tmpbuf, FRAMECLASSNAME) == 0) | |
1344 cinfo = &(((Box *)cinfo)->cinfo); | |
1345 | |
1346 if(cinfo) | |
1347 { | |
1348 switch( msg ) | |
1349 { | |
1350 case WM_CHAR: | |
1351 if(LOWORD(mp1) == '\t') | |
1352 { | |
1353 if(cinfo->buddy) | |
1354 _shift_focus(cinfo->buddy); | |
1355 else | |
1356 _shift_focus(hWnd); | |
1357 return FALSE; | |
1358 } | |
1359 /* Tell the spinner control that a keypress has | |
1360 * occured and to update it's internal value. | |
1361 */ | |
1362 if(cinfo->buddy) | |
1363 SendMessage(cinfo->buddy, WM_USER+10, 0, 0); | |
1364 break; | |
1365 case WM_USER+10: | |
1366 { | |
1367 if(cinfo->buddy) | |
1368 { | |
1369 long val, position; | |
1370 char tmpbuf[100] = ""; | |
1371 | |
1372 GetWindowText(cinfo->buddy, tmpbuf, 99); | |
1373 | |
1374 position = atol(tmpbuf); | |
1375 | |
1376 if(IS_WIN98PLUS) | |
1377 val = (long)SendMessage(cinfo->buddy, UDM_GETPOS32, 0, 0); | |
1378 else | |
1379 val = (long)SendMessage(cinfo->buddy, UDM_GETPOS, 0, 0); | |
1380 | |
1381 if(val != position) | |
1382 { | |
1383 sprintf(tmpbuf, "%d", val); | |
1384 SetWindowText(hWnd, tmpbuf); | |
1385 } | |
1386 } | |
1387 } | |
1388 break; | |
1389 case WM_KEYUP: | |
1390 { | |
1391 if(mp1 == VK_UP || mp1 == VK_DOWN) | |
1392 { | |
1393 if(cinfo->buddy) | |
1394 PostMessage(hWnd, WM_USER+10, 0, 0); | |
1395 } | |
1396 } | |
1397 break; | |
1398 case WM_CTLCOLORSTATIC: | |
1399 case WM_CTLCOLORLISTBOX: | |
1400 case WM_CTLCOLORBTN: | |
1401 case WM_CTLCOLOREDIT: | |
1402 case WM_CTLCOLORMSGBOX: | |
1403 case WM_CTLCOLORSCROLLBAR: | |
1404 { | |
1405 ColorInfo *thiscinfo = (ColorInfo *)GetWindowLong((HWND)mp2, GWL_USERDATA); | |
1406 if(thiscinfo && thiscinfo->fore != -1 && thiscinfo->back != -1) | |
1407 { | |
1408 if(thiscinfo->fore > -1 && thiscinfo->back > -1 && | |
1409 thiscinfo->fore < 18 && thiscinfo->back < 18) | |
1410 { | |
1411 SetTextColor((HDC)mp1, RGB(_red[thiscinfo->fore], | |
1412 _green[thiscinfo->fore], | |
1413 _blue[thiscinfo->fore])); | |
1414 SetBkColor((HDC)mp1, RGB(_red[thiscinfo->back], | |
1415 _green[thiscinfo->back], | |
1416 _blue[thiscinfo->back])); | |
1417 SelectObject((HDC)mp1, _colors[thiscinfo->back]); | |
1418 return (LRESULT)_colors[thiscinfo->back]; | |
1419 } | |
1420 if((thiscinfo->fore & DW_RGB_COLOR) == DW_RGB_COLOR && (thiscinfo->back & DW_RGB_COLOR) == DW_RGB_COLOR) | |
1421 { | |
1422 SetTextColor((HDC)mp1, RGB(DW_RED_VALUE(thiscinfo->fore), | |
1423 DW_GREEN_VALUE(thiscinfo->fore), | |
1424 DW_BLUE_VALUE(thiscinfo->fore))); | |
1425 SetBkColor((HDC)mp1, RGB(DW_RED_VALUE(thiscinfo->back), | |
1426 DW_GREEN_VALUE(thiscinfo->back), | |
1427 DW_BLUE_VALUE(thiscinfo->back))); | |
1428 DeleteObject(thiscinfo->hbrush); | |
1429 thiscinfo->hbrush = CreateSolidBrush(RGB(DW_RED_VALUE(thiscinfo->back), | |
1430 DW_GREEN_VALUE(thiscinfo->back), | |
1431 DW_BLUE_VALUE(thiscinfo->back))); | |
1432 return (LRESULT)thiscinfo->hbrush; | |
1433 } | |
1434 } | |
1435 | |
1436 } | |
1437 break; | |
1438 } | |
1439 } | |
1440 | |
1441 if(!cinfo || !cinfo->pOldProc) | |
1442 return DefWindowProc(hWnd, msg, mp1, mp2); | |
1443 return CallWindowProc(cinfo->pOldProc, hWnd, msg, mp1, mp2); | |
1444 } | |
1445 | |
1446 BOOL CALLBACK _containerwndproc(HWND hWnd, UINT msg, WPARAM mp1, LPARAM mp2) | |
1447 { | |
1448 ContainerInfo *cinfo; | |
1449 | |
1450 cinfo = (ContainerInfo *)GetWindowLong(hWnd, GWL_USERDATA); | |
1451 | |
1452 switch( msg ) | |
1453 { | |
1454 case WM_COMMAND: | |
1455 case WM_NOTIFY: | |
1456 _wndproc(hWnd, msg, mp1, mp2); | |
1457 break; | |
1458 #ifndef NO_SIGNALS | |
1459 case WM_LBUTTONDBLCLK: | |
1460 case WM_CHAR: | |
1461 { | |
1462 LV_ITEM lvi; | |
1463 int iItem; | |
1464 | |
1465 if(LOWORD(mp1) == '\t') | |
1466 { | |
1467 _shift_focus(hWnd); | |
1468 return FALSE; | |
1469 } | |
1470 | |
1471 if(msg == WM_CHAR && (char)mp1 != '\r') | |
1472 break; | |
1473 | |
1474 iItem = ListView_GetNextItem(hWnd, -1, LVNI_FOCUSED); | |
1475 | |
1476 if(iItem > -1) | |
1477 { | |
1478 lvi.iItem = iItem; | |
1479 lvi.mask = LVIF_PARAM; | |
1480 | |
1481 ListView_GetItem(hWnd, &lvi); | |
1482 } | |
1483 else | |
1484 lvi.lParam = (LPARAM)NULL; | |
1485 | |
1486 { | |
1487 SignalHandler *tmp = Root; | |
1488 | |
1489 while(tmp) | |
1490 { | |
1491 if(tmp->message == NM_DBLCLK && tmp->window == hWnd) | |
1492 { | |
1493 int (*containerselectfunc)(HWND, char *, void *) = tmp->signalfunction; | |
1494 | |
1495 /* Seems to be having lParam as 1 which really sucks */ | |
1496 if(lvi.lParam < 100) | |
1497 lvi.lParam = 0; | |
1498 | |
1499 containerselectfunc(tmp->window, (char *)lvi.lParam, tmp->data); | |
1500 tmp = NULL; | |
1501 } | |
1502 if(tmp) | |
1503 tmp = tmp->next; | |
1504 } | |
1505 } | |
1506 } | |
1507 break; | |
1508 case WM_CONTEXTMENU: | |
1509 { | |
1510 LONG x,y; | |
1511 LV_ITEM lvi; | |
1512 int iItem; | |
1513 | |
1514 iItem = ListView_GetNextItem(hWnd, -1, LVNI_FOCUSED); | |
1515 | |
1516 if(iItem > -1) | |
1517 { | |
1518 lvi.iItem = iItem; | |
1519 lvi.mask = LVIF_PARAM; | |
1520 | |
1521 ListView_GetItem(hWnd, &lvi); | |
1522 } | |
1523 else | |
1524 lvi.lParam = (LPARAM)NULL; | |
1525 | |
1526 dw_pointer_query_pos(&x, &y); | |
1527 | |
1528 { | |
1529 SignalHandler *tmp = Root; | |
1530 | |
1531 while(tmp) | |
1532 { | |
1533 if(tmp->message == NM_RCLICK && tmp->window == hWnd) | |
1534 { | |
1535 int (*containercontextfunc)(HWND, char *, int, int, void *) = tmp->signalfunction; | |
1536 | |
1537 /* Seems to be having lParam as 1 which really sucks */ | |
1538 if(lvi.lParam < 100) | |
1539 lvi.lParam = 0; | |
1540 | |
1541 containercontextfunc(tmp->window, (char *)lvi.lParam, x, y, tmp->data); | |
1542 tmp = NULL; | |
1543 } | |
1544 if(tmp) | |
1545 tmp = tmp->next; | |
1546 } | |
1547 } | |
1548 } | |
1549 break; | |
1550 #else | |
1551 case WM_CHAR: | |
1552 if(LOWORD(mp1) == '\t') | |
1553 { | |
1554 _shift_focus(hWnd); | |
1555 return FALSE; | |
1556 } | |
1557 break; | |
1558 #endif | |
1559 } | |
1560 | |
1561 if(!cinfo || !cinfo->pOldProc) | |
1562 return DefWindowProc(hWnd, msg, mp1, mp2); | |
1563 return CallWindowProc(cinfo->pOldProc, hWnd, msg, mp1, mp2); | |
1564 } | |
1565 | |
1566 void _changebox(Box *thisbox, int percent, int type) | |
1567 { | |
1568 int z; | |
1569 | |
1570 for(z=0;z<thisbox->count;z++) | |
1571 { | |
1572 if(thisbox->items[z].type == TYPEBOX) | |
1573 { | |
1574 Box *tmp = (Box*)GetWindowLong(thisbox->items[z].hwnd, GWL_USERDATA); | |
1575 _changebox(tmp, percent, type); | |
1576 } | |
1577 else | |
1578 { | |
1579 if(type == BOXHORZ) | |
1580 { | |
1581 if(thisbox->items[z].hsize == SIZEEXPAND) | |
1582 thisbox->items[z].width = (int)(((float)thisbox->items[z].origwidth) * (((float)percent)/((float)100.0))); | |
1583 } | |
1584 else | |
1585 { | |
1586 if(thisbox->items[z].vsize == SIZEEXPAND) | |
1587 thisbox->items[z].height = (int)(((float)thisbox->items[z].origheight) * (((float)percent)/((float)100.0))); | |
1588 } | |
1589 } | |
1590 } | |
1591 } | |
1592 | |
1593 /* This handles any activity on the splitbars (sizers) */ | |
1594 BOOL CALLBACK _splitwndproc(HWND hwnd, UINT msg, WPARAM mp1, LPARAM mp2) | |
1595 { | |
1596 HWND hwndFrame = 0; | |
1597 Box *thisbox = 0; | |
1598 | |
1599 hwndFrame = GetParent(hwnd); | |
1600 if(hwndFrame) | |
1601 thisbox = (Box *)GetWindowLong(hwndFrame, GWL_USERDATA); | |
1602 | |
1603 switch (msg) | |
1604 { | |
1605 case WM_ACTIVATE: | |
1606 case WM_SETFOCUS: | |
1607 return FALSE; | |
1608 | |
1609 case WM_PAINT: | |
1610 { | |
1611 HDC hdcPaint; | |
1612 PAINTSTRUCT ps; | |
1613 POINT ptlStart[SPLITBAR_WIDTH]; | |
1614 POINT ptlEnd[SPLITBAR_WIDTH]; | |
1615 RECT rcPaint; | |
1616 USHORT i; | |
1617 | |
1618 hdcPaint = BeginPaint(hwnd, &ps); | |
1619 GetWindowRect(hwnd, &rcPaint); | |
1620 | |
1621 if(thisbox->type == BOXHORZ) | |
1622 { | |
1623 for(i = 0; i < SPLITBAR_WIDTH; i++) | |
1624 { | |
1625 ptlStart[i].x = i; | |
1626 ptlStart[i].y = 0; | |
1627 | |
1628 ptlEnd[i].x = i; | |
1629 ptlEnd[i].y = rcPaint.bottom - rcPaint.top; | |
1630 } | |
1631 } | |
1632 else | |
1633 { | |
1634 for(i = 0; i < SPLITBAR_WIDTH; i++) | |
1635 { | |
1636 ptlStart[i].x = 0; | |
1637 ptlStart[i].y = i; | |
1638 | |
1639 ptlEnd[i].x = rcPaint.right - rcPaint.left; | |
1640 ptlEnd[i].y = i; | |
1641 } | |
1642 } | |
1643 | |
1644 for(i = 0; i < SPLITBAR_WIDTH; i++) | |
1645 { | |
1646 HPEN hPen; | |
1647 HPEN hOldPen; | |
1648 | |
1649 hPen = CreatePen(PS_SOLID, 1, RGB (_red[lColor[i]], _green[lColor[i]], _blue[lColor[i]])); | |
1650 hOldPen = (HPEN)SelectObject(hdcPaint, hPen); | |
1651 MoveToEx(hdcPaint, ptlStart[i].x, ptlStart[i].y, NULL); | |
1652 LineTo(hdcPaint, ptlEnd[i].x, ptlEnd[i].y); | |
1653 SelectObject(hdcPaint, hOldPen); | |
1654 DeleteObject(hPen); | |
1655 } | |
1656 EndPaint(hwnd, &ps); | |
1657 } | |
1658 return FALSE; | |
1659 case WM_MOUSEMOVE: | |
1660 { | |
1661 if(thisbox->type == BOXHORZ) | |
1662 SetCursor(LoadCursor(NULL, IDC_SIZEWE)); | |
1663 else | |
1664 SetCursor(LoadCursor(NULL, IDC_SIZENS)); | |
1665 } | |
1666 return FALSE; | |
1667 #if 0 | |
1668 case WM_BUTTON1DOWN: | |
1669 { | |
1670 ULONG rc; | |
1671 RECTL rclFrame; | |
1672 RECTL rclBounds; | |
1673 RECTL rclStart; | |
1674 USHORT startSize, orig, actual; | |
1675 | |
1676 GetWindowRect(hwnd, &rclFrame); | |
1677 GetWindowRect(hwnd, &rclStart); | |
1678 | |
1679 GetWindowRect(hwndFrame, &rclBounds); | |
1680 | |
1681 WinMapWindowPoints(hwndFrame, HWND_DESKTOP, | |
1682 (PPOINTL)&rclBounds, 2); | |
1683 WinMapWindowPoints(hwnd, HWND_DESKTOP, | |
1684 (PPOINTL)&rclStart, 2); | |
1685 | |
1686 if(thisbox->type == BOXHORZ) | |
1687 { | |
1688 orig = thisbox->items[0].origwidth; | |
1689 actual = thisbox->items[0].width; | |
1690 | |
1691 startSize = (rclStart.xLeft - rclBounds.xLeft) | |
1692 * (((float)orig)/((float)actual)); | |
1693 } | |
1694 else | |
1695 { | |
1696 orig = thisbox->items[0].origheight; | |
1697 actual = thisbox->items[0].height; | |
1698 | |
1699 startSize = (rclStart.yBottom - rclBounds.yBottom) | |
1700 * (((float)actual)/((float)orig)); | |
1701 } | |
1702 | |
1703 rc = _TrackRectangle(hwnd, &rclFrame, &rclBounds); | |
1704 | |
1705 if(rc == TRUE) | |
1706 { | |
1707 USHORT usNewRB; | |
1708 USHORT usSize; | |
1709 USHORT percent; | |
1710 int z; | |
1711 | |
1712 if(thisbox->type == BOXHORZ) | |
1713 { | |
1714 usNewRB = rclFrame.xLeft | |
1715 - rclBounds.xLeft; | |
1716 usSize = rclBounds.xRight | |
1717 - rclBounds.xLeft; | |
1718 } | |
1719 else | |
1720 { | |
1721 usNewRB = rclFrame.yBottom | |
1722 - rclBounds.yBottom; | |
1723 usSize = rclBounds.yTop | |
1724 - rclBounds.yBottom; | |
1725 } | |
1726 | |
1727 percent = (usNewRB*100)/startSize; | |
1728 | |
1729 for(z=0;z<thisbox->count;z++) | |
1730 { | |
1731 if(thisbox->items[z].type == TYPEBOX) | |
1732 { | |
1733 Box *tmp = (Box *)GetWindowLong(thisbox->items[z].hwnd, GWL_USERDATA); | |
1734 _changebox(tmp, percent, thisbox->type); | |
1735 } | |
1736 else | |
1737 { | |
1738 if(thisbox->items[z].hwnd == hwnd) | |
1739 percent = (startSize*100)/usNewRB; | |
1740 | |
1741 if(thisbox->type == BOXHORZ) | |
1742 { | |
1743 if(thisbox->items[z].hsize == SIZEEXPAND) | |
1744 thisbox->items[z].width = (int)(((float)thisbox->items[z].origwidth) * (((float)percent)/((float)100.0))); | |
1745 } | |
1746 else | |
1747 { | |
1748 if(thisbox->items[z].vsize == SIZEEXPAND) | |
1749 thisbox->items[z].height = (int)(((float)thisbox->items[z].origheight) * (((float)percent)/((float)100.0))); | |
1750 } | |
1751 } | |
1752 } | |
1753 | |
1754 _ResetWindow(GetWindow(hwnd, GW_OWNER)); | |
1755 } | |
1756 } | |
1757 return MRFROMSHORT(FALSE); | |
1758 #endif | |
1759 } | |
1760 return DefWindowProc(hwnd, msg, mp1, mp2); | |
1761 } | |
1762 | |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1763 /* This handles drawing the status text areas */ |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1764 BOOL CALLBACK _statuswndproc(HWND hwnd, UINT msg, WPARAM mp1, LPARAM mp2) |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1765 { |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1766 switch (msg) |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1767 { |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1768 case WM_SETTEXT: |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1769 { |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1770 /* Make sure the control redraws when there is a text change */ |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1771 int ret = (int)DefWindowProc(hwnd, msg, mp1, mp2); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1772 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1773 InvalidateRgn(hwnd, NULL, TRUE); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1774 return ret; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1775 } |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1776 case WM_PAINT: |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1777 { |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1778 HDC hdcPaint; |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1779 PAINTSTRUCT ps; |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1780 RECT rc; |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1781 HFONT hFont; |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1782 HBRUSH oldBrush; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1783 HPEN oldPen; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1784 unsigned long cx, cy; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1785 int threadid = dw_thread_id(); |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1786 char tempbuf[1024] = ""; |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1787 |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1788 if(threadid < 0 || threadid >= THREAD_LIMIT) |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1789 threadid = 0; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1790 |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1791 hdcPaint = BeginPaint(hwnd, &ps); |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1792 EndPaint(hwnd, &ps); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1793 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1794 hdcPaint = GetDC(hwnd); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1795 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1796 oldBrush = _hBrush[threadid]; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1797 oldPen = _hPen[threadid]; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1798 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1799 dw_window_get_pos_size(hwnd, NULL, NULL, &cx, &cy); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1800 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1801 _hBrush[threadid] = GetStockObject(LTGRAY_BRUSH); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1802 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1803 dw_draw_rect(hwnd, 0, TRUE, 0, 0, cx, cy); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1804 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1805 _hPen[threadid] = CreatePen(PS_SOLID, 1, RGB(_red[DW_CLR_DARKGRAY], |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1806 _green[DW_CLR_DARKGRAY], |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1807 _blue[DW_CLR_DARKGRAY])); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1808 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1809 dw_draw_line(hwnd, 0, 0, 0, cx, 0); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1810 dw_draw_line(hwnd, 0, 0, 0, 0, cy); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1811 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1812 DeleteObject(_hPen[threadid]); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1813 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1814 _hPen[threadid] = GetStockObject(WHITE_PEN); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1815 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1816 dw_draw_line(hwnd, 0, cx - 1, cy - 1, cx - 1, 0); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1817 dw_draw_line(hwnd, 0, cx - 1, cy - 1, 0, cy - 1); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1818 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1819 rc.left = 3; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1820 rc.top = 1; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1821 rc.bottom = cy - 1; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1822 rc.right = cx - 1; |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1823 |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1824 GetWindowText(hwnd, tempbuf, 1024); |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1825 |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1826 hFont = (HFONT)SelectObject(hdcPaint, GetStockObject(DEFAULT_GUI_FONT)); |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1827 |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1828 SetTextColor(hdcPaint, RGB(0,0,0)); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1829 SetBkMode(hdcPaint, TRANSPARENT); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1830 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1831 ExtTextOut(hdcPaint, 3, 1, ETO_CLIPPED, &rc, tempbuf, strlen(tempbuf), NULL); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1832 |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1833 SelectObject(hdcPaint, hFont); |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1834 |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1835 _hBrush[threadid] = oldBrush; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1836 _hPen[threadid] = oldPen; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
1837 ReleaseDC(hwnd, hdcPaint); |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1838 } |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1839 return FALSE; |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1840 } |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1841 return DefWindowProc(hwnd, msg, mp1, mp2); |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1842 } |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
1843 |
3 | 1844 /* Function: _BtProc |
1845 * Abstract: Subclass procedure for buttons | |
1846 */ | |
1847 | |
1848 BOOL CALLBACK _BtProc(HWND hwnd, ULONG msg, WPARAM mp1, LPARAM mp2) | |
1849 { | |
1850 BubbleButton *bubble; | |
1851 static int bMouseOver = 0; | |
1852 POINT point; | |
1853 RECT rect; | |
1854 | |
1855 bubble = (BubbleButton *)GetWindowLong(hwnd, GWL_USERDATA); | |
1856 | |
1857 if(!bubble) | |
1858 return DefWindowProc(hwnd, msg, mp1, mp2); | |
1859 | |
1860 switch(msg) | |
1861 { | |
1862 #ifndef NO_SIGNALS | |
1863 case WM_LBUTTONUP: | |
1864 { | |
1865 SignalHandler *tmp = Root; | |
1866 | |
1867 /* Find any callbacks for this function */ | |
1868 while(tmp) | |
1869 { | |
1870 if(tmp->message == WM_COMMAND) | |
1871 { | |
1872 int (*clickfunc)(HWND, void *) = tmp->signalfunction; | |
1873 | |
1874 /* Make sure it's the right window, and the right ID */ | |
1875 if(tmp->window == hwnd) | |
1876 { | |
1877 clickfunc(tmp->window, tmp->data); | |
1878 tmp = NULL; | |
1879 } | |
1880 } | |
1881 if(tmp) | |
1882 tmp= tmp->next; | |
1883 } | |
1884 } | |
1885 break; | |
1886 #endif | |
1887 case WM_CHAR: | |
1888 { | |
1889 #ifndef NO_SIGNALS | |
1890 /* A button press should also occur for an ENTER or SPACE press | |
1891 * while the button has the active input focus. | |
1892 */ | |
1893 if(LOWORD(mp1) == '\r' || LOWORD(mp1) == ' ') | |
1894 { | |
1895 SignalHandler *tmp = Root; | |
1896 | |
1897 /* Find any callbacks for this function */ | |
1898 while(tmp) | |
1899 { | |
1900 if(tmp->message == WM_COMMAND) | |
1901 { | |
1902 int (*clickfunc)(HWND, void *) = tmp->signalfunction; | |
1903 | |
1904 /* Make sure it's the right window, and the right ID */ | |
1905 if(tmp->window == hwnd) | |
1906 { | |
1907 clickfunc(tmp->window, tmp->data); | |
1908 tmp = NULL; | |
1909 } | |
1910 } | |
1911 if(tmp) | |
1912 tmp= tmp->next; | |
1913 } | |
1914 } | |
1915 #endif | |
1916 if(LOWORD(mp1) == '\t') | |
1917 { | |
1918 _shift_focus(hwnd); | |
1919 return FALSE; | |
1920 } | |
1921 } | |
1922 break; | |
1923 case WM_TIMER: | |
1924 if (hwndBubble) | |
1925 { | |
1926 DestroyWindow(hwndBubble); | |
1927 hwndBubble = 0; | |
1928 KillTimer(hwnd, 1); | |
1929 } | |
1930 break; | |
1931 | |
1932 case WM_MOUSEMOVE: | |
1933 GetCursorPos(&point); | |
1934 GetWindowRect(hwnd, &rect); | |
1935 | |
1936 if(PtInRect(&rect, point)){ | |
1937 if(hwnd != GetCapture()){ | |
1938 SetCapture(hwnd); | |
1939 } | |
1940 if(!bMouseOver){ | |
1941 bMouseOver = 1; | |
1942 if(!*bubble->bubbletext) | |
1943 break; | |
1944 | |
1945 if(hwndBubble) | |
1946 { | |
1947 DestroyWindow(hwndBubble); | |
1948 hwndBubble = 0; | |
1949 KillTimer(hwndBubbleLast, 1); | |
1950 } | |
1951 | |
1952 if(!hwndBubble) | |
1953 { | |
1954 POINTL ptlWork = {0,0}; | |
1955 ULONG ulColor = DW_CLR_YELLOW; | |
1956 SIZE size; | |
1957 HDC hdc; | |
1958 RECT rect; | |
1959 void *oldproc; | |
1960 | |
1961 /* Use the WS_EX_TOOLWINDOW extended style | |
1962 * so the window doesn't get listed in the | |
1963 * taskbar. | |
1964 */ | |
1965 hwndBubble = CreateWindowEx(WS_EX_TOOLWINDOW, | |
1966 STATICCLASSNAME, | |
1967 bubble->bubbletext, | |
1968 BS_TEXT | WS_POPUP | | |
1969 WS_BORDER | | |
1970 SS_CENTER, | |
1971 0,0,50,20, | |
1972 HWND_DESKTOP, | |
1973 NULL, | |
1974 NULL, | |
1975 NULL); | |
1976 | |
1977 dw_window_set_font(hwndBubble, DefaultFont); | |
1978 dw_window_set_color(hwndBubble, DW_CLR_BLACK, DW_CLR_YELLOW); | |
1979 | |
1980 hwndBubbleLast = hwnd; | |
1981 | |
1982 SetTimer(hwnd, 1, 3000, NULL); | |
1983 | |
1984 hdc = GetDC(hwndBubble); | |
1985 | |
1986 GetTextExtentPoint(hdc, bubble->bubbletext, strlen(bubble->bubbletext), &size); | |
1987 | |
1988 MapWindowPoints(hwnd, HWND_DESKTOP, (LPPOINT)&ptlWork, 1); | |
1989 | |
1990 GetWindowRect(hwnd, &rect); | |
1991 | |
1992 SetWindowPos(hwndBubble, | |
1993 HWND_TOP, | |
1994 ptlWork.x, | |
1995 ptlWork.y + (rect.bottom-rect.top) + 1, | |
1996 size.cx + 2, | |
1997 size.cy + 2, | |
1998 SWP_NOACTIVATE | SWP_SHOWWINDOW); | |
1999 | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2000 ReleaseDC(hwndBubble, hdc); |
3 | 2001 } |
2002 } | |
2003 } | |
2004 else{ | |
2005 /* Calling ReleaseCapture in Win95 also causes WM_CAPTURECHANGED | |
2006 * to be sent. Be sure to account for that. | |
2007 */ | |
2008 ReleaseCapture(); | |
2009 | |
2010 if(bMouseOver){ | |
2011 bMouseOver = 0; | |
2012 DestroyWindow(hwndBubble); | |
2013 hwndBubble = 0; | |
2014 KillTimer(hwndBubbleLast, 1); | |
2015 } | |
2016 } | |
2017 break; | |
2018 case WM_CAPTURECHANGED: | |
2019 /* This message means we are losing the capture for some reason | |
2020 * Either because we intentionally lost it or another window | |
2021 * stole it | |
2022 */ | |
2023 if(bMouseOver){ | |
2024 bMouseOver = 0; | |
2025 DestroyWindow(hwndBubble); | |
2026 hwndBubble = 0; | |
2027 KillTimer(hwndBubbleLast, 1); | |
2028 } | |
2029 break; | |
2030 } | |
2031 | |
2032 if(!bubble->pOldProc) | |
2033 return DefWindowProc(hwnd, msg, mp1, mp2); | |
2034 return CallWindowProc(bubble->pOldProc, hwnd, msg, mp1, mp2); | |
2035 } | |
2036 | |
2037 void _resize_notebook_page(HWND handle, int pageid) | |
2038 { | |
2039 RECT rect; | |
2040 NotebookPage **array = (NotebookPage **)GetWindowLong(handle, GWL_USERDATA); | |
2041 | |
2042 if(array && array[pageid]) | |
2043 { | |
2044 Box *box = (Box *)GetWindowLong(array[pageid]->hwnd, GWL_USERDATA); | |
2045 | |
2046 GetClientRect(handle,&rect); | |
2047 TabCtrl_AdjustRect(handle,FALSE,&rect); | |
2048 MoveWindow(array[pageid]->hwnd,rect.left,rect.top, | |
2049 rect.right - rect.left,rect.bottom-rect.top, | |
2050 TRUE); | |
2051 if(box) | |
2052 _do_resize(box, rect.right - rect.left, rect.bottom - rect.top); | |
2053 | |
2054 ShowWindow(array[pageid]->hwnd,SW_SHOWNORMAL); | |
2055 } | |
2056 } | |
2057 | |
2058 /* | |
2059 * Initializes the Dynamic Windows engine. | |
2060 * Parameters: | |
2061 * newthread: True if this is the only thread. | |
2062 * False if there is already a message loop running. | |
2063 */ | |
14
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2064 int dw_init(int newthread, int argc, char *argv[]) |
3 | 2065 { |
2066 WNDCLASS wc; | |
2067 int z; | |
2068 INITCOMMONCONTROLSEX icc; | |
2069 | |
2070 icc.dwSize = sizeof(INITCOMMONCONTROLSEX); | |
2071 icc.dwICC = ICC_WIN95_CLASSES; | |
2072 | |
2073 InitCommonControlsEx(&icc); | |
2074 | |
2075 memset(lookup, 0, sizeof(HICON) * ICON_INDEX_LIMIT); | |
2076 | |
2077 memset(&wc, 0, sizeof(WNDCLASS)); | |
2078 wc.style = CS_DBLCLKS /*| CS_HREDRAW | CS_VREDRAW*/; | |
2079 wc.lpfnWndProc = (WNDPROC)_wndproc; | |
2080 wc.cbClsExtra = 0; | |
2081 wc.cbWndExtra = 32; | |
2082 wc.hbrBackground = NULL; | |
2083 wc.lpszMenuName = NULL; | |
2084 wc.lpszClassName = ClassName; | |
2085 | |
2086 RegisterClass(&wc); | |
2087 | |
2088 memset(&wc, 0, sizeof(WNDCLASS)); | |
2089 wc.style = CS_DBLCLKS | CS_HREDRAW | CS_VREDRAW; | |
2090 wc.lpfnWndProc = (WNDPROC)_splitwndproc; | |
2091 wc.cbClsExtra = 0; | |
2092 wc.cbWndExtra = 0; | |
2093 wc.hbrBackground = NULL; | |
2094 wc.lpszMenuName = NULL; | |
2095 wc.lpszClassName = SplitbarClassName; | |
2096 | |
2097 RegisterClass(&wc); | |
2098 | |
2099 memset(&wc, 0, sizeof(WNDCLASS)); | |
2100 wc.style = CS_DBLCLKS /*| CS_HREDRAW | CS_VREDRAW*/; | |
2101 wc.lpfnWndProc = (WNDPROC)_framewndproc; | |
2102 wc.cbClsExtra = 0; | |
2103 wc.cbWndExtra = 32; | |
2104 wc.hbrBackground = (HBRUSH)COLOR_WINDOW; | |
2105 wc.hCursor = LoadCursor(NULL, IDC_ARROW); | |
2106 wc.lpszMenuName = NULL; | |
2107 wc.lpszClassName = FRAMECLASSNAME; | |
2108 | |
2109 for(z=0;z<18;z++) | |
2110 _colors[z] = CreateSolidBrush(RGB(_red[z],_green[z],_blue[z])); | |
2111 | |
2112 RegisterClass(&wc); | |
2113 | |
2114 memset(&wc, 0, sizeof(WNDCLASS)); | |
2115 wc.style = 0; | |
2116 wc.lpfnWndProc = (WNDPROC)_wndproc; | |
2117 wc.cbClsExtra = 0; | |
2118 wc.cbWndExtra = 0; | |
2119 wc.hbrBackground = NULL; | |
2120 wc.hCursor = LoadCursor(NULL, IDC_ARROW); | |
2121 wc.lpszMenuName = NULL; | |
2122 wc.lpszClassName = ObjectClassName; | |
2123 | |
2124 RegisterClass(&wc); | |
2125 | |
2126 /* Since Windows 95/98/NT don't have a HWND_OBJECT class | |
2127 * also known as a input only window, I will create a | |
2128 * temporary window that isn't visible and really does nothing | |
2129 * except temporarily hold the child windows before they are | |
2130 * packed into their correct parent. | |
2131 */ | |
2132 | |
2133 DW_HWND_OBJECT = CreateWindow(ObjectClassName, "", 0, 0, 0, | |
2134 0, 0, HWND_DESKTOP, NULL, NULL, NULL); | |
2135 | |
2136 if(!DW_HWND_OBJECT) | |
2137 { | |
2138 dw_messagebox("Dynamic Windows", "Could not initialize the object window. error code %d", GetLastError()); | |
2139 exit(1); | |
2140 } | |
2141 | |
2142 #ifdef DWDEBUG | |
2143 f = fopen("dw.log", "wt"); | |
2144 #endif | |
2145 /* We need the version to check capability like up-down controls */ | |
2146 dwVersion = GetVersion(); | |
2147 | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2148 for(z=0;z<THREAD_LIMIT;z++) |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2149 { |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2150 _foreground[z] = RGB(128,128,128); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2151 _background[z] = 0; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2152 _hPen[z] = CreatePen(PS_SOLID, 1, _foreground[z]); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2153 _hBrush[z] = CreateSolidBrush(_foreground[z]); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2154 } |
3 | 2155 |
2156 return 0; | |
2157 } | |
2158 | |
2159 /* | |
2160 * Runs a message loop for Dynamic Windows. | |
2161 * Parameters: | |
2162 * currenthab: The handle to the current anchor block | |
2163 * or NULL if this DW is handling the message loop. | |
2164 * func: Function pointer to the message filter function. | |
2165 */ | |
2166 void dw_main(HAB currenthab, void *func) | |
2167 { | |
2168 MSG msg; | |
2169 | |
2170 /* Setup the filter function */ | |
2171 filterfunc = func; | |
2172 | |
2173 while (GetMessage(&msg,NULL,0,0)) { | |
2174 TranslateMessage(&msg); | |
2175 DispatchMessage(&msg); | |
2176 } | |
2177 | |
2178 #ifdef DWDEBUG | |
2179 fclose(f); | |
2180 #endif | |
2181 } | |
2182 | |
2183 /* | |
2184 * Free's memory allocated by dynamic windows. | |
2185 * Parameters: | |
2186 * ptr: Pointer to dynamic windows allocated | |
2187 * memory to be free()'d. | |
2188 */ | |
2189 void dw_free(void *ptr) | |
2190 { | |
2191 free(ptr); | |
2192 } | |
2193 | |
2194 /* | |
2195 * Allocates and initializes a dialog struct. | |
2196 * Parameters: | |
2197 * data: User defined data to be passed to functions. | |
2198 */ | |
2199 DWDialog *dw_dialog_new(void *data) | |
2200 { | |
2201 DWDialog *tmp = malloc(sizeof(DWDialog)); | |
2202 | |
2203 tmp->eve = dw_event_new(); | |
2204 dw_event_reset(tmp->eve); | |
2205 tmp->data = data; | |
2206 tmp->done = FALSE; | |
2207 tmp->result = NULL; | |
2208 | |
2209 return tmp; | |
2210 } | |
2211 | |
2212 /* | |
2213 * Accepts a dialog struct and returns the given data to the | |
2214 * initial called of dw_dialog_wait(). | |
2215 * Parameters: | |
2216 * dialog: Pointer to a dialog struct aquired by dw_dialog_new). | |
2217 * result: Data to be returned by dw_dialog_wait(). | |
2218 */ | |
2219 int dw_dialog_dismiss(DWDialog *dialog, void *result) | |
2220 { | |
2221 dialog->result = result; | |
2222 dw_event_post(dialog->eve); | |
2223 dialog->done = TRUE; | |
2224 return 0; | |
2225 } | |
2226 | |
2227 /* | |
2228 * Accepts a dialog struct waits for dw_dialog_dismiss() to be | |
2229 * called by a signal handler with the given dialog struct. | |
2230 * Parameters: | |
2231 * dialog: Pointer to a dialog struct aquired by dw_dialog_new). | |
2232 */ | |
2233 void *dw_dialog_wait(DWDialog *dialog) | |
2234 { | |
2235 MSG msg; | |
2236 void *tmp; | |
2237 | |
2238 while (GetMessage(&msg,NULL,0,0)) | |
2239 { | |
2240 TranslateMessage(&msg); | |
2241 DispatchMessage(&msg); | |
2242 if(dialog->done) | |
2243 break; | |
2244 } | |
2245 dw_event_close(&dialog->eve); | |
2246 tmp = dialog->result; | |
2247 free(dialog); | |
2248 return tmp; | |
2249 } | |
2250 | |
2251 /* | |
2252 * Displays a Message Box with given text and title.. | |
2253 * Parameters: | |
2254 * title: The title of the message box. | |
2255 * format: printf style format string. | |
2256 * ...: Additional variables for use in the format. | |
2257 */ | |
2258 int dw_messagebox(char *title, char *format, ...) | |
2259 { | |
2260 va_list args; | |
2261 char outbuf[256]; | |
2262 | |
2263 va_start(args, format); | |
2264 vsprintf(outbuf, format, args); | |
2265 va_end(args); | |
2266 | |
2267 MessageBox(HWND_DESKTOP, outbuf, title, MB_OK); | |
2268 | |
2269 return strlen(outbuf); | |
2270 } | |
2271 | |
2272 /* | |
2273 * Displays a Message Box with given text and title.. | |
2274 * Parameters: | |
2275 * title: The title of the message box. | |
2276 * text: The text to display in the box. | |
2277 * Returns: | |
2278 * True if YES False of NO. | |
2279 */ | |
2280 int dw_yesno(char *title, char *text) | |
2281 { | |
2282 if(MessageBox(HWND_DESKTOP, text, title, MB_YESNO)==IDYES) | |
2283 return TRUE; | |
2284 return FALSE; | |
2285 } | |
2286 | |
2287 /* | |
14
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2288 * Minimizes or Iconifies a top-level window. |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2289 * Parameters: |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2290 * handle: The window handle to minimize. |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2291 */ |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2292 int dw_window_minimize(HWND handle) |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2293 { |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2294 return ShowWindow(handle, SW_MINIMIZE); |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2295 } |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2296 |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2297 /* |
3 | 2298 * Makes the window visible. |
2299 * Parameters: | |
2300 * handle: The window handle to make visible. | |
2301 */ | |
2302 int dw_window_show(HWND handle) | |
2303 { | |
2304 int rc = ShowWindow(handle, TRUE); | |
2305 SetFocus(handle); | |
2306 _initial_focus(handle); | |
2307 return rc; | |
2308 } | |
2309 | |
2310 /* | |
2311 * Makes the window invisible. | |
2312 * Parameters: | |
2313 * handle: The window handle to make visible. | |
2314 */ | |
2315 int dw_window_hide(HWND handle) | |
2316 { | |
2317 return ShowWindow(handle, FALSE); | |
2318 } | |
2319 | |
2320 /* | |
2321 * Destroys a window and all of it's children. | |
2322 * Parameters: | |
2323 * handle: The window handle to destroy. | |
2324 */ | |
2325 int dw_window_destroy(HWND handle) | |
2326 { | |
2327 return DestroyWindow(handle); | |
2328 } | |
2329 | |
2330 /* | |
2331 * Changes a window's parent to newparent. | |
2332 * Parameters: | |
2333 * handle: The window handle to destroy. | |
2334 * newparent: The window's new parent window. | |
2335 */ | |
2336 void dw_window_reparent(HWND handle, HWND newparent) | |
2337 { | |
2338 SetParent(handle, newparent); | |
2339 } | |
2340 | |
2341 HFONT _aquire_font(char *fontname) | |
2342 { | |
2343 HFONT hfont; | |
2344 int z, size = 9; | |
2345 LOGFONT lf; | |
2346 | |
2347 if(fontname == DefaultFont) | |
2348 hfont = GetStockObject(DEFAULT_GUI_FONT); | |
2349 else | |
2350 { | |
2351 for(z=0;z<strlen(fontname);z++) | |
2352 { | |
2353 if(fontname[z]=='.') | |
2354 break; | |
2355 } | |
2356 size = atoi(fontname) + 5; | |
2357 | |
2358 lf.lfHeight = size; | |
2359 lf.lfWidth = 0; | |
2360 lf.lfEscapement = 0; | |
2361 lf.lfOrientation = 0; | |
2362 lf.lfItalic = 0; | |
2363 lf.lfUnderline = 0; | |
2364 lf.lfStrikeOut = 0; | |
2365 lf.lfWeight = FW_NORMAL; | |
2366 lf.lfCharSet = DEFAULT_CHARSET; | |
2367 lf.lfOutPrecision = 0; | |
2368 lf.lfClipPrecision = 0; | |
2369 lf.lfQuality = DEFAULT_QUALITY; | |
2370 lf.lfPitchAndFamily = DEFAULT_PITCH | FW_DONTCARE; | |
2371 strcpy(lf.lfFaceName, &fontname[z+1]); | |
2372 | |
2373 hfont = CreateFontIndirect(&lf); | |
2374 } | |
2375 return hfont; | |
2376 } | |
2377 | |
2378 /* | |
2379 * Sets the font used by a specified window (widget) handle. | |
2380 * Parameters: | |
2381 * handle: The window (widget) handle. | |
2382 * fontname: Name and size of the font in the form "size.fontname" | |
2383 */ | |
2384 int dw_window_set_font(HWND handle, char *fontname) | |
2385 { | |
2386 HFONT hfont = _aquire_font(fontname); | |
2387 ColorInfo *cinfo; | |
2388 | |
2389 cinfo = (ColorInfo *)GetWindowLong(handle, GWL_USERDATA); | |
2390 | |
2391 if(fontname) | |
2392 { | |
2393 if(cinfo) | |
2394 { | |
2395 strcpy(cinfo->fontname, fontname); | |
2396 } | |
2397 else | |
2398 { | |
2399 cinfo = calloc(1, sizeof(ColorInfo)); | |
2400 cinfo->fore = cinfo->back = -1; | |
2401 cinfo->buddy = 0; | |
2402 | |
2403 strcpy(cinfo->fontname, fontname); | |
2404 | |
2405 cinfo->pOldProc = SubclassWindow(handle, _colorwndproc); | |
2406 SetWindowLong(handle, GWL_USERDATA, (ULONG)cinfo); | |
2407 } | |
2408 } | |
2409 SendMessage(handle, WM_SETFONT, (WPARAM)hfont, FALSE); | |
2410 return 0; | |
2411 } | |
2412 | |
2413 /* | |
2414 * Sets the colors used by a specified window (widget) handle. | |
2415 * Parameters: | |
2416 * handle: The window (widget) handle. | |
2417 * fore: Foreground color in RGB format. | |
2418 * back: Background color in RGB format. | |
2419 */ | |
2420 int dw_window_set_color(HWND handle, ULONG fore, ULONG back) | |
2421 { | |
2422 ColorInfo *cinfo; | |
2423 char tmpbuf[100]; | |
2424 | |
2425 cinfo = (ColorInfo *)GetWindowLong(handle, GWL_USERDATA); | |
2426 | |
2427 GetClassName(handle, tmpbuf, 99); | |
2428 | |
2429 if(strnicmp(tmpbuf, FRAMECLASSNAME, strlen(FRAMECLASSNAME))==0) | |
2430 return FALSE; | |
2431 | |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2432 if(strnicmp(tmpbuf, WC_LISTVIEW, strlen(WC_LISTVIEW))==0) |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2433 { |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2434 ListView_SetTextColor(handle, RGB(DW_RED_VALUE(fore), |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2435 DW_GREEN_VALUE(fore), |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2436 DW_BLUE_VALUE(fore))); |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2437 ListView_SetTextBkColor(handle, RGB(DW_RED_VALUE(back), |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2438 DW_GREEN_VALUE(back), |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2439 DW_BLUE_VALUE(back))); |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2440 ListView_SetBkColor(handle, RGB(DW_RED_VALUE(back), |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2441 DW_GREEN_VALUE(back), |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2442 DW_BLUE_VALUE(back))); |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2443 InvalidateRgn(handle, NULL, TRUE); |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2444 return TRUE; |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2445 } |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2446 |
3 | 2447 if(cinfo) |
2448 { | |
2449 cinfo->fore = fore; | |
2450 cinfo->back = back; | |
2451 } | |
2452 else | |
2453 { | |
2454 cinfo = calloc(1, sizeof(ColorInfo)); | |
2455 | |
2456 cinfo->fore = fore; | |
2457 cinfo->back = back; | |
2458 cinfo->buddy = 0; | |
2459 | |
2460 cinfo->pOldProc = SubclassWindow(handle, _colorwndproc); | |
2461 SetWindowLong(handle, GWL_USERDATA, (ULONG)cinfo); | |
2462 } | |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2463 InvalidateRgn(handle, NULL, TRUE); |
3 | 2464 return TRUE; |
2465 } | |
2466 | |
2467 /* | |
2468 * Sets the font used by a specified window (widget) handle. | |
2469 * Parameters: | |
2470 * handle: The window (widget) handle. | |
2471 * border: Size of the window border in pixels. | |
2472 */ | |
2473 int dw_window_set_border(HWND handle, int border) | |
2474 { | |
2475 return 0; | |
2476 } | |
2477 | |
2478 /* | |
2479 * Captures the mouse input to this window. | |
2480 * Parameters: | |
2481 * handle: Handle to receive mouse input. | |
2482 */ | |
2483 void dw_window_capture(HWND handle) | |
2484 { | |
2485 SetCapture(handle); | |
2486 } | |
2487 | |
2488 /* | |
2489 * Releases previous mouse capture. | |
2490 */ | |
2491 void dw_window_release(void) | |
2492 { | |
2493 ReleaseCapture(); | |
2494 } | |
2495 | |
2496 /* | |
2497 * Create a new Window Frame. | |
2498 * Parameters: | |
2499 * owner: The Owner's window handle or HWND_DESKTOP. | |
2500 * title: The Window title. | |
2501 * flStyle: Style flags, see the DW reference. | |
2502 */ | |
2503 HWND dw_window_new(HWND hwndOwner, char *title, ULONG flStyle) | |
2504 { | |
2505 HWND hwndframe; | |
2506 Box *newbox = malloc(sizeof(Box)); | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2507 ULONG flStyleEx = 0; |
3 | 2508 |
2509 newbox->pad = 0; | |
2510 newbox->type = BOXVERT; | |
2511 newbox->count = 0; | |
2512 | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2513 if(hwndOwner) |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2514 flStyleEx |= WS_EX_MDICHILD; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2515 |
3 | 2516 if(!(flStyle & WS_CAPTION)) |
2517 flStyle |= WS_POPUPWINDOW; | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2518 |
3 | 2519 if(flStyle & DW_FCF_TASKLIST) |
2520 { | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2521 ULONG newflags = (flStyle | WS_CLIPCHILDREN) & ~DW_FCF_TASKLIST; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2522 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2523 hwndframe = CreateWindowEx(flStyleEx, ClassName, title, newflags, CW_USEDEFAULT, CW_USEDEFAULT, |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2524 CW_USEDEFAULT, CW_USEDEFAULT, hwndOwner, NULL, NULL, NULL); |
3 | 2525 } |
2526 else | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2527 { |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2528 flStyleEx |= WS_EX_TOOLWINDOW; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2529 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2530 hwndframe = CreateWindowEx(flStyleEx, ClassName, title, flStyle | WS_CLIPCHILDREN, CW_USEDEFAULT, CW_USEDEFAULT, |
3 | 2531 CW_USEDEFAULT, CW_USEDEFAULT, hwndOwner, NULL, NULL, NULL); |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2532 } |
3 | 2533 SetWindowLong(hwndframe, GWL_USERDATA, (ULONG)newbox); |
2534 | |
14
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2535 #if 0 |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2536 if(hwndOwner) |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2537 SetParent(hwndframe, hwndOwner); |
14
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2538 #endif |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2539 |
3 | 2540 return hwndframe; |
2541 } | |
2542 | |
2543 /* | |
2544 * Create a new Box to be packed. | |
2545 * Parameters: | |
2546 * type: Either BOXVERT (vertical) or BOXHORZ (horizontal). | |
2547 * pad: Number of pixels to pad around the box. | |
2548 */ | |
2549 HWND dw_box_new(int type, int pad) | |
2550 { | |
14
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2551 Box *newbox = malloc(sizeof(Box)); |
3 | 2552 HWND hwndframe; |
2553 | |
2554 newbox->pad = pad; | |
2555 newbox->type = type; | |
2556 newbox->count = 0; | |
2557 newbox->grouphwnd = (HWND)NULL; | |
2558 | |
2559 hwndframe = CreateWindow(FRAMECLASSNAME, | |
2560 "", | |
2561 WS_CHILD | WS_CLIPCHILDREN, | |
2562 0,0,2000,1000, | |
2563 DW_HWND_OBJECT, | |
2564 NULL, | |
2565 NULL, | |
2566 NULL); | |
2567 | |
2568 newbox->cinfo.pOldProc = SubclassWindow(hwndframe, _colorwndproc); | |
2569 newbox->cinfo.fore = newbox->cinfo.back = -1; | |
2570 | |
2571 SetWindowLong(hwndframe, GWL_USERDATA, (ULONG)newbox); | |
2572 return hwndframe; | |
2573 } | |
2574 | |
2575 /* | |
2576 * Create a new Group Box to be packed. | |
2577 * Parameters: | |
2578 * type: Either BOXVERT (vertical) or BOXHORZ (horizontal). | |
2579 * pad: Number of pixels to pad around the box. | |
2580 * title: Text to be displayined in the group outline. | |
2581 */ | |
2582 HWND dw_groupbox_new(int type, int pad, char *title) | |
2583 { | |
2584 Box *newbox = malloc(sizeof(Box)); | |
2585 HWND hwndframe; | |
2586 | |
2587 newbox->pad = pad; | |
2588 newbox->type = type; | |
2589 newbox->count = 0; | |
2590 | |
2591 hwndframe = CreateWindow(FRAMECLASSNAME, | |
2592 "", | |
2593 WS_CHILD, | |
2594 0,0,2000,1000, | |
2595 DW_HWND_OBJECT, | |
2596 NULL, | |
2597 NULL, | |
2598 NULL); | |
2599 | |
2600 newbox->grouphwnd = CreateWindow(BUTTONCLASSNAME, | |
2601 title, | |
2602 WS_CHILD | BS_GROUPBOX | | |
2603 WS_VISIBLE | WS_CLIPCHILDREN, | |
2604 0,0,2000,1000, | |
2605 hwndframe, | |
2606 NULL, | |
2607 NULL, | |
2608 NULL); | |
2609 | |
2610 SetWindowLong(hwndframe, GWL_USERDATA, (ULONG)newbox); | |
2611 dw_window_set_font(newbox->grouphwnd, DefaultFont); | |
2612 return hwndframe; | |
2613 } | |
2614 | |
2615 /* | |
14
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2616 * Create a new MDI Frame to be packed. |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2617 * Parameters: |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2618 * id: An ID to be used with dw_window_from_id or 0L. |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2619 */ |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2620 HWND dw_mdi_new(unsigned long id) |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2621 { |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2622 CLIENTCREATESTRUCT ccs; |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2623 HWND hwndframe; |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2624 |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2625 ccs.hWindowMenu = NULL; |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2626 ccs.idFirstChild = 0; |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2627 |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2628 hwndframe = CreateWindow("MDICLIENT", |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2629 "", |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2630 WS_CHILD | WS_CLIPSIBLINGS, |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2631 0,0,2000,1000, |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2632 DW_HWND_OBJECT, |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2633 NULL, |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2634 DWInstance, |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2635 &ccs); |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2636 return hwndframe; |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2637 } |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2638 |
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2639 /* |
3 | 2640 * Create a bitmap object to be packed. |
2641 * Parameters: | |
14
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
2642 * id: An ID to be used with dw_window_from_id or 0L. |
3 | 2643 */ |
2644 HWND dw_bitmap_new(ULONG id) | |
2645 { | |
2646 return CreateWindow(STATICCLASSNAME, | |
2647 "", | |
2648 SS_BITMAP | WS_CHILD | WS_CLIPCHILDREN, | |
2649 0,0,2000,1000, | |
2650 DW_HWND_OBJECT, | |
2651 NULL, | |
2652 NULL, | |
2653 NULL); | |
2654 } | |
2655 | |
2656 /* | |
2657 * Create a notebook object to be packed. | |
2658 * Parameters: | |
2659 * id: An ID to be used for getting the resource from the | |
2660 * resource file. | |
2661 */ | |
2662 HWND dw_notebook_new(ULONG id, int top) | |
2663 { | |
2664 ULONG flags = 0; | |
2665 HWND tmp; | |
2666 NotebookPage **array = calloc(256, sizeof(NotebookPage *)); | |
2667 | |
2668 if(!top) | |
2669 flags = TCS_BOTTOM; | |
2670 | |
2671 tmp = CreateWindow(WC_TABCONTROL, | |
2672 "", | |
2673 WS_CHILD | WS_CLIPCHILDREN, | |
2674 0,0,2000,1000, | |
2675 DW_HWND_OBJECT, | |
2676 NULL, | |
2677 NULL, | |
2678 NULL); | |
2679 SetWindowLong(tmp, GWL_USERDATA, (ULONG)array); | |
2680 dw_window_set_font(tmp, DefaultFont); | |
2681 return tmp; | |
2682 } | |
2683 | |
2684 /* | |
2685 * Create a menu object to be popped up. | |
2686 * Parameters: | |
2687 * id: An ID to be used for getting the resource from the | |
2688 * resource file. | |
2689 */ | |
2690 HMENUI dw_menu_new(ULONG id) | |
2691 { | |
2692 HMENUI tmp = malloc(sizeof(struct _hmenui)); | |
2693 | |
2694 if(!tmp) | |
2695 return NULL; | |
2696 | |
2697 tmp->menu = CreatePopupMenu(); | |
2698 tmp->hwnd = NULL; | |
2699 return tmp; | |
2700 } | |
2701 | |
2702 /* | |
2703 * Create a menubar on a window. | |
2704 * Parameters: | |
2705 * location: Handle of a window frame to be attached to. | |
2706 */ | |
2707 HMENUI dw_menubar_new(HWND location) | |
2708 { | |
2709 HMENUI tmp = malloc(sizeof(struct _hmenui)); | |
2710 | |
2711 if(!tmp) | |
2712 return NULL; | |
2713 | |
2714 tmp->menu = CreateMenu(); | |
2715 tmp->hwnd = location; | |
2716 | |
2717 SetMenu(location, tmp->menu); | |
2718 return tmp; | |
2719 } | |
2720 | |
2721 /* | |
2722 * Destroys a menu created with dw_menubar_new or dw_menu_new. | |
2723 * Parameters: | |
2724 * menu: Handle of a menu. | |
2725 */ | |
2726 void dw_menu_destroy(HMENUI *menu) | |
2727 { | |
2728 if(menu && *menu) | |
2729 { | |
2730 DestroyMenu((*menu)->menu); | |
2731 free(*menu); | |
2732 *menu = NULL; | |
2733 } | |
2734 } | |
2735 | |
2736 /* | |
2737 * Adds a menuitem or submenu to an existing menu. | |
2738 * Parameters: | |
2739 * menu: The handle the the existing menu. | |
2740 * title: The title text on the menu item to be added. | |
2741 * id: An ID to be used for message passing. | |
2742 * end: If TRUE memu is positioned at the end of the menu. | |
2743 * check: If TRUE menu is "check"able. | |
2744 * flags: Extended attributes to set on the menu. | |
2745 * submenu: Handle to an existing menu to be a submenu or NULL. | |
2746 */ | |
2747 HWND dw_menu_append_item(HMENUI menux, char *title, ULONG id, ULONG flags, int end, int check, HMENUI submenu) | |
2748 { | |
2749 MENUITEMINFO mii; | |
2750 HMENU menu; | |
2751 | |
2752 if(!menux) | |
2753 return NULL; | |
2754 | |
2755 menu = menux->menu; | |
2756 | |
2757 mii.cbSize = sizeof(MENUITEMINFO); | |
2758 mii.fMask = MIIM_ID | MIIM_SUBMENU | MIIM_TYPE; | |
2759 | |
2760 /* Convert from OS/2 style accellerators to Win32 style */ | |
2761 if(title) | |
2762 { | |
2763 char *tmp = title; | |
2764 | |
2765 while(*tmp) | |
2766 { | |
2767 if(*tmp == '~') | |
2768 *tmp = '&'; | |
2769 tmp++; | |
2770 } | |
2771 } | |
2772 | |
2773 if(title && *title) | |
2774 mii.fType = MFT_STRING; | |
2775 else | |
2776 mii.fType = MFT_SEPARATOR; | |
2777 | |
2778 mii.wID = id; | |
2779 mii.hSubMenu = submenu ? submenu->menu : 0; | |
2780 mii.dwTypeData = title; | |
2781 mii.cch = strlen(title); | |
2782 | |
2783 InsertMenuItem(menu, 65535, TRUE, &mii); | |
2784 if(menux->hwnd) | |
2785 DrawMenuBar(menux->hwnd); | |
2786 return (HWND)id; | |
2787 } | |
2788 | |
2789 /* | |
2790 * Sets the state of a menu item check. | |
2791 * Parameters: | |
2792 * menu: The handle the the existing menu. | |
2793 * id: Menuitem id. | |
2794 * check: TRUE for checked FALSE for not checked. | |
2795 */ | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
2796 void dw_menu_item_set_check(HMENUI menux, unsigned long id, int check) |
3 | 2797 { |
2798 MENUITEMINFO mii; | |
2799 HMENU menu; | |
2800 | |
2801 if(!menux) | |
2802 return; | |
2803 | |
2804 menu = menux->menu; | |
2805 | |
2806 mii.cbSize = sizeof(MENUITEMINFO); | |
2807 mii.fMask = MIIM_STATE; | |
2808 if(check) | |
2809 mii.fState = MFS_CHECKED; | |
2810 else | |
2811 mii.fState = MFS_UNCHECKED; | |
2812 SetMenuItemInfo(menu, id, FALSE, &mii); | |
2813 } | |
2814 | |
2815 /* | |
2816 * Pops up a context menu at given x and y coordinates. | |
2817 * Parameters: | |
2818 * menu: The handle the the existing menu. | |
2819 * parent: Handle to the window initiating the popup. | |
2820 * x: X coordinate. | |
2821 * y: Y coordinate. | |
2822 */ | |
2823 void dw_menu_popup(HMENUI *menu, HWND parent, int x, int y) | |
2824 { | |
2825 if(menu && *menu) | |
2826 { | |
2827 TrackPopupMenu((*menu)->menu, 0, x, y, 0, parent, NULL); | |
2828 free(*menu); | |
2829 *menu = NULL; | |
2830 } | |
2831 } | |
2832 | |
2833 | |
2834 /* | |
2835 * Create a container object to be packed. | |
2836 * Parameters: | |
2837 * id: An ID to be used for getting the resource from the | |
2838 * resource file. | |
2839 */ | |
2840 HWND dw_container_new(ULONG id) | |
2841 { | |
2842 HWND tmp = CreateWindow(WC_LISTVIEW, | |
2843 "", | |
2844 WS_CHILD | LVS_REPORT | | |
2845 LVS_SHAREIMAGELISTS | WS_BORDER | | |
2846 WS_CLIPCHILDREN, | |
2847 0,0,2000,1000, | |
2848 DW_HWND_OBJECT, | |
2849 (HMENU)id, | |
2850 NULL, | |
2851 NULL); | |
2852 ContainerInfo *cinfo = (ContainerInfo *)calloc(1, sizeof(ContainerInfo)); | |
2853 | |
2854 if(!cinfo) | |
2855 { | |
2856 DestroyWindow(tmp); | |
2857 return NULL; | |
2858 } | |
2859 | |
2860 cinfo->pOldProc = (WNDPROC)SubclassWindow(tmp, _containerwndproc); | |
2861 | |
2862 SetWindowLong(tmp, GWL_USERDATA, (ULONG)cinfo); | |
2863 dw_window_set_font(tmp, DefaultFont); | |
2864 return tmp; | |
2865 } | |
2866 | |
2867 /* | |
2868 * Returns the current X and Y coordinates of the mouse pointer. | |
2869 * Parameters: | |
2870 * x: Pointer to variable to store X coordinate. | |
2871 * y: Pointer to variable to store Y coordinate. | |
2872 */ | |
2873 void dw_pointer_query_pos(long *x, long *y) | |
2874 { | |
2875 POINT ptl; | |
2876 | |
2877 GetCursorPos(&ptl); | |
2878 if(x && y) | |
2879 { | |
2880 *x = ptl.x; | |
2881 *y = ptl.y; | |
2882 } | |
2883 } | |
2884 | |
2885 /* | |
2886 * Sets the X and Y coordinates of the mouse pointer. | |
2887 * Parameters: | |
2888 * x: X coordinate. | |
2889 * y: Y coordinate. | |
2890 */ | |
2891 void dw_pointer_set_pos(long x, long y) | |
2892 { | |
2893 SetCursorPos(x, y); | |
2894 } | |
2895 | |
2896 /* | |
2897 * Create a new static text window (widget) to be packed. | |
2898 * Parameters: | |
2899 * text: The text to be display by the static text widget. | |
2900 * id: An ID to be used with WinWindowFromID() or 0L. | |
2901 */ | |
2902 HWND dw_text_new(char *text, ULONG id) | |
2903 { | |
2904 HWND tmp = CreateWindow(STATICCLASSNAME, | |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2905 text, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2906 BS_TEXT | WS_CHILD | WS_CLIPCHILDREN, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2907 0,0,2000,1000, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2908 DW_HWND_OBJECT, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2909 (HMENU)id, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2910 NULL, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2911 NULL); |
3 | 2912 dw_window_set_font(tmp, DefaultFont); |
2913 return tmp; | |
2914 } | |
2915 | |
2916 /* | |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2917 * Create a new status text window (widget) to be packed. |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2918 * Parameters: |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2919 * text: The text to be display by the static text widget. |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2920 * id: An ID to be used with WinWindowFromID() or 0L. |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2921 */ |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2922 HWND dw_status_text_new(char *text, ULONG id) |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2923 { |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2924 HWND tmp = CreateWindow(STATICCLASSNAME, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2925 text, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2926 BS_TEXT | WS_CHILD | WS_CLIPCHILDREN, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2927 0,0,2000,1000, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2928 DW_HWND_OBJECT, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2929 (HMENU)id, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2930 NULL, |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2931 NULL); |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2932 dw_window_set_font(tmp, DefaultFont); |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2933 SubclassWindow(tmp, _statuswndproc); |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2934 return tmp; |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2935 } |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2936 |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
2937 /* |
3 | 2938 * Create a new Multiline Editbox window (widget) to be packed. |
2939 * Parameters: | |
2940 * id: An ID to be used with WinWindowFromID() or 0L. | |
2941 */ | |
2942 HWND dw_mle_new(ULONG id) | |
2943 { | |
2944 | |
2945 HWND tmp = CreateWindow(EDITCLASSNAME, | |
2946 "", | |
2947 WS_BORDER | ES_AUTOHSCROLL | | |
2948 WS_VSCROLL | ES_MULTILINE | | |
2949 ES_WANTRETURN | WS_CHILD | | |
2950 WS_CLIPCHILDREN, | |
2951 0,0,2000,1000, | |
2952 DW_HWND_OBJECT, | |
2953 (HMENU)id, | |
2954 NULL, | |
2955 NULL); | |
2956 dw_window_set_font(tmp, DefaultFont); | |
2957 return tmp; | |
2958 } | |
2959 | |
2960 /* | |
2961 * Create a new Entryfield window (widget) to be packed. | |
2962 * Parameters: | |
2963 * text: The default text to be in the entryfield widget. | |
2964 * id: An ID to be used with WinWindowFromID() or 0L. | |
2965 */ | |
2966 HWND dw_entryfield_new(char *text, ULONG id) | |
2967 { | |
2968 HWND tmp = CreateWindow(EDITCLASSNAME, | |
2969 text, | |
2970 ES_WANTRETURN | WS_CHILD | | |
2971 WS_BORDER | ES_AUTOHSCROLL | | |
2972 WS_CLIPCHILDREN, | |
2973 0,0,2000,1000, | |
2974 DW_HWND_OBJECT, | |
2975 (HMENU)id, | |
2976 NULL, | |
2977 NULL); | |
2978 ColorInfo *cinfo = calloc(1, sizeof(ColorInfo)); | |
2979 | |
2980 cinfo->back = cinfo->fore = -1; | |
2981 cinfo->buddy = 0; | |
2982 | |
2983 cinfo->pOldProc = SubclassWindow(tmp, _colorwndproc); | |
2984 SetWindowLong(tmp, GWL_USERDATA, (ULONG)cinfo); | |
2985 dw_window_set_font(tmp, DefaultFont); | |
2986 return tmp; | |
2987 } | |
2988 | |
2989 /* | |
2990 * Create a new Entryfield passwird window (widget) to be packed. | |
2991 * Parameters: | |
2992 * text: The default text to be in the entryfield widget. | |
2993 * id: An ID to be used with WinWindowFromID() or 0L. | |
2994 */ | |
2995 HWND dw_entryfield_password_new(char *text, ULONG id) | |
2996 { | |
2997 HWND tmp = CreateWindow(EDITCLASSNAME, | |
2998 text, | |
2999 ES_WANTRETURN | WS_CHILD | | |
3000 ES_PASSWORD | WS_BORDER | | |
3001 ES_AUTOHSCROLL | WS_CLIPCHILDREN, | |
3002 0,0,2000,1000, | |
3003 DW_HWND_OBJECT, | |
3004 (HMENU)id, | |
3005 NULL, | |
3006 NULL); | |
3007 ColorInfo *cinfo = calloc(1, sizeof(ColorInfo)); | |
3008 | |
3009 cinfo->back = cinfo->fore = -1; | |
3010 cinfo->buddy = 0; | |
3011 | |
3012 cinfo->pOldProc = SubclassWindow(tmp, _colorwndproc); | |
3013 SetWindowLong(tmp, GWL_USERDATA, (ULONG)cinfo); | |
3014 dw_window_set_font(tmp, DefaultFont); | |
3015 return tmp; | |
3016 } | |
3017 | |
3018 /* | |
3019 * Create a new Combobox window (widget) to be packed. | |
3020 * Parameters: | |
3021 * text: The default text to be in the combpbox widget. | |
3022 * id: An ID to be used with WinWindowFromID() or 0L. | |
3023 */ | |
3024 HWND dw_combobox_new(char *text, ULONG id) | |
3025 { | |
3026 HWND tmp = CreateWindow(COMBOBOXCLASSNAME, | |
3027 "", | |
3028 WS_CHILD | CBS_DROPDOWN | WS_CLIPCHILDREN, | |
3029 0,0,2000,1000, | |
3030 DW_HWND_OBJECT, | |
3031 (HMENU)id, | |
3032 NULL, | |
3033 NULL); | |
3034 ContainerInfo *cinfo = (ContainerInfo *)calloc(1, sizeof(ContainerInfo)); | |
3035 | |
3036 if(!cinfo) | |
3037 { | |
3038 DestroyWindow(tmp); | |
3039 return NULL; | |
3040 } | |
3041 | |
3042 cinfo->cinfo.fore = -1; | |
3043 cinfo->cinfo.back = -1; | |
3044 cinfo->pOldProc = (WNDPROC)SubclassWindow(tmp, _containerwndproc); | |
3045 | |
3046 SetWindowLong(tmp, GWL_USERDATA, (ULONG)cinfo); | |
3047 dw_window_set_font(tmp, DefaultFont); | |
3048 return tmp; | |
3049 } | |
3050 | |
3051 /* | |
3052 * Create a new button window (widget) to be packed. | |
3053 * Parameters: | |
3054 * text: The text to be display by the static text widget. | |
3055 * id: An ID to be used with WinWindowFromID() or 0L. | |
3056 */ | |
3057 HWND dw_button_new(char *text, ULONG id) | |
3058 { | |
3059 BubbleButton *bubble = malloc(sizeof(BubbleButton)); | |
3060 | |
3061 HWND tmp = CreateWindow(BUTTONCLASSNAME, | |
3062 text, | |
3063 WS_CHILD | BS_PUSHBUTTON | WS_CLIPCHILDREN, | |
3064 0,0,2000,1000, | |
3065 DW_HWND_OBJECT, | |
3066 (HMENU)id, | |
3067 NULL, | |
3068 NULL); | |
3069 | |
3070 bubble->id = id; | |
3071 bubble->bubbletext[0] = '\0'; | |
3072 bubble->pOldProc = (WNDPROC)SubclassWindow(tmp, _BtProc); | |
3073 | |
3074 SetWindowLong(tmp, GWL_USERDATA, (ULONG)bubble); | |
3075 dw_window_set_font(tmp, DefaultFont); | |
3076 return tmp; | |
3077 } | |
3078 | |
3079 /* | |
3080 * Create a new bitmap button window (widget) to be packed. | |
3081 * Parameters: | |
3082 * text: Bubble help text to be displayed. | |
3083 * id: An ID of a bitmap in the resource file. | |
3084 */ | |
3085 HWND dw_bitmapbutton_new(char *text, ULONG id) | |
3086 { | |
3087 HWND tmp; | |
3088 BubbleButton *bubble = malloc(sizeof(BubbleButton)); | |
3089 HBITMAP hbitmap = LoadBitmap(DWInstance, MAKEINTRESOURCE(id)); | |
3090 | |
3091 tmp = CreateWindow(BUTTONCLASSNAME, | |
3092 "", | |
3093 WS_CHILD | BS_PUSHBUTTON | | |
3094 BS_BITMAP | WS_CLIPCHILDREN, | |
3095 0,0,2000,1000, | |
3096 DW_HWND_OBJECT, | |
3097 (HMENU)id, | |
3098 NULL, | |
3099 NULL); | |
3100 | |
3101 bubble->id = id; | |
3102 strncpy(bubble->bubbletext, text, BUBBLE_HELP_MAX - 1); | |
3103 bubble->bubbletext[BUBBLE_HELP_MAX - 1] = '\0'; | |
3104 bubble->pOldProc = (WNDPROC)SubclassWindow(tmp, _BtProc); | |
3105 | |
3106 SetWindowLong(tmp, GWL_USERDATA, (ULONG)bubble); | |
3107 | |
3108 SendMessage(tmp, BM_SETIMAGE, | |
3109 (WPARAM) IMAGE_BITMAP, | |
3110 (LPARAM) hbitmap); | |
3111 return tmp; | |
3112 } | |
3113 | |
3114 /* | |
3115 * Create a new spinbutton window (widget) to be packed. | |
3116 * Parameters: | |
3117 * text: The text to be display by the static text widget. | |
3118 * id: An ID to be used with WinWindowFromID() or 0L. | |
3119 */ | |
3120 HWND dw_spinbutton_new(char *text, ULONG id) | |
3121 { | |
3122 ULONG *data = malloc(sizeof(ULONG)); | |
3123 HWND buddy = CreateWindow(EDITCLASSNAME, | |
3124 text, | |
3125 WS_CHILD | WS_BORDER | | |
3126 ES_NUMBER | WS_CLIPCHILDREN, | |
3127 0,0,2000,1000, | |
3128 DW_HWND_OBJECT, | |
3129 NULL, | |
3130 NULL, | |
3131 NULL); | |
3132 HWND tmp = CreateUpDownControl( | |
3133 WS_CHILD | UDS_ALIGNRIGHT | | |
3134 UDS_ARROWKEYS | UDS_SETBUDDYINT | | |
3135 UDS_WRAP | UDS_NOTHOUSANDS, | |
3136 0, | |
3137 0, | |
3138 2000, | |
3139 1000, | |
3140 DW_HWND_OBJECT, | |
3141 id, | |
3142 DWInstance, | |
3143 buddy, | |
3144 0, | |
3145 100, | |
3146 0); | |
3147 ColorInfo *cinfo = calloc(1, sizeof(ColorInfo)); | |
3148 | |
3149 cinfo->back = cinfo->fore = -1; | |
3150 cinfo->buddy = tmp; | |
3151 | |
3152 cinfo->pOldProc = SubclassWindow(buddy, _colorwndproc); | |
3153 SetWindowLong(buddy, GWL_USERDATA, (ULONG)cinfo); | |
3154 | |
3155 cinfo = calloc(1, sizeof(ColorInfo)); | |
3156 cinfo->buddy = buddy; | |
3157 cinfo->pOldProc = SubclassWindow(tmp, _spinnerwndproc); | |
3158 | |
3159 SetWindowLong(tmp, GWL_USERDATA, (ULONG)cinfo); | |
3160 dw_window_set_font(buddy, DefaultFont); | |
3161 return tmp; | |
3162 } | |
3163 | |
3164 /* | |
3165 * Create a new radiobutton window (widget) to be packed. | |
3166 * Parameters: | |
3167 * text: The text to be display by the static text widget. | |
3168 * id: An ID to be used with WinWindowFromID() or 0L. | |
3169 */ | |
3170 HWND dw_radiobutton_new(char *text, ULONG id) | |
3171 { | |
3172 HWND tmp = CreateWindow(BUTTONCLASSNAME, | |
3173 text, | |
3174 WS_CHILD | BS_AUTORADIOBUTTON | | |
3175 WS_CLIPCHILDREN, | |
3176 0,0,2000,1000, | |
3177 DW_HWND_OBJECT, | |
3178 (HMENU)id, | |
3179 NULL, | |
3180 NULL); | |
3181 | |
3182 ColorInfo *cinfo = calloc(1, sizeof(ColorInfo)); | |
3183 | |
3184 cinfo->back = cinfo->fore = -1; | |
3185 cinfo->buddy = 0; | |
3186 cinfo->user = 0; | |
3187 | |
3188 cinfo->pOldProc = SubclassWindow(tmp, _colorwndproc); | |
3189 SetWindowLong(tmp, GWL_USERDATA, (ULONG)cinfo); | |
3190 dw_window_set_font(tmp, DefaultFont); | |
3191 return tmp; | |
3192 } | |
3193 | |
3194 | |
3195 /* | |
3196 * Create a new slider window (widget) to be packed. | |
3197 * Parameters: | |
3198 * id: An ID to be used with WinWindowFromID() or 0L. | |
3199 */ | |
3200 HWND dw_slider_new(ULONG id) | |
3201 { | |
3202 return CreateWindow(PROGRESS_CLASS, | |
3203 "", | |
3204 WS_CHILD | WS_CLIPCHILDREN, | |
3205 0,0,2000,1000, | |
3206 DW_HWND_OBJECT, | |
3207 NULL, | |
3208 NULL, | |
3209 NULL); | |
3210 } | |
3211 | |
3212 /* | |
3213 * Create a new checkbox window (widget) to be packed. | |
3214 * Parameters: | |
3215 * text: The text to be display by the static text widget. | |
3216 * id: An ID to be used with WinWindowFromID() or 0L. | |
3217 */ | |
3218 HWND dw_checkbox_new(char *text, ULONG id) | |
3219 { | |
3220 HWND tmp = CreateWindow(BUTTONCLASSNAME, | |
3221 text, | |
3222 WS_CHILD | BS_AUTOCHECKBOX | | |
3223 BS_TEXT | WS_CLIPCHILDREN, | |
3224 0,0,2000,1000, | |
3225 DW_HWND_OBJECT, | |
3226 NULL, | |
3227 NULL, | |
3228 NULL); | |
3229 ColorInfo *cinfo = calloc(1, sizeof(ColorInfo)); | |
3230 | |
3231 cinfo->back = cinfo->fore = -1; | |
3232 cinfo->buddy = 0; | |
3233 cinfo->user = 1; | |
3234 | |
3235 cinfo->pOldProc = SubclassWindow(tmp, _colorwndproc); | |
3236 SetWindowLong(tmp, GWL_USERDATA, (ULONG)cinfo); | |
3237 dw_window_set_font(tmp, DefaultFont); | |
3238 return tmp; | |
3239 } | |
3240 | |
3241 /* | |
3242 * Create a new listbox window (widget) to be packed. | |
3243 * Parameters: | |
3244 * id: An ID to be used with WinWindowFromID() or 0L. | |
3245 * multi: Multiple select TRUE or FALSE. | |
3246 */ | |
3247 HWND dw_listbox_new(ULONG id, int multi) | |
3248 { | |
3249 HWND tmp = CreateWindow(LISTBOXCLASSNAME, | |
3250 "", | |
3251 LBS_NOINTEGRALHEIGHT | WS_CHILD | LBS_HASSTRINGS | | |
3252 LBS_NOTIFY | WS_BORDER | WS_CLIPCHILDREN | | |
3253 WS_VSCROLL | (multi ? LBS_EXTENDEDSEL : 0) , | |
3254 0,0,2000,1000, | |
3255 DW_HWND_OBJECT, | |
3256 NULL, | |
3257 NULL, | |
3258 NULL); | |
3259 ContainerInfo *cinfo = (ContainerInfo *)calloc(1, sizeof(ContainerInfo)); | |
3260 | |
3261 if(!cinfo) | |
3262 { | |
3263 DestroyWindow(tmp); | |
3264 return NULL; | |
3265 } | |
3266 | |
3267 cinfo->cinfo.fore = -1; | |
3268 cinfo->cinfo.back = -1; | |
3269 cinfo->pOldProc = (WNDPROC)SubclassWindow(tmp, _containerwndproc); | |
3270 | |
3271 SetWindowLong(tmp, GWL_USERDATA, (ULONG)cinfo); | |
3272 dw_window_set_font(tmp, DefaultFont); | |
3273 return tmp; | |
3274 } | |
3275 | |
3276 /* | |
3277 * Sets the icon used for a given window. | |
3278 * Parameters: | |
3279 * handle: Handle to the window. | |
3280 * id: An ID to be used to specify the icon. | |
3281 */ | |
3282 void dw_window_set_icon(HWND handle, ULONG id) | |
3283 { | |
3284 HICON hicon = LoadIcon(DWInstance, MAKEINTRESOURCE(id)); | |
3285 | |
3286 SendMessage(handle, WM_SETICON, | |
3287 (WPARAM) IMAGE_ICON, | |
3288 (LPARAM) hicon); | |
3289 } | |
3290 | |
3291 /* | |
3292 * Sets the bitmap used for a given static window. | |
3293 * Parameters: | |
3294 * handle: Handle to the window. | |
3295 * id: An ID to be used to specify the icon. | |
3296 */ | |
3297 void dw_window_set_bitmap(HWND handle, ULONG id) | |
3298 { | |
3299 HBITMAP hbitmap = LoadBitmap(DWInstance, MAKEINTRESOURCE(id)); | |
3300 | |
3301 SendMessage(handle, STM_SETIMAGE, | |
3302 (WPARAM) IMAGE_BITMAP, | |
3303 (LPARAM) hbitmap); | |
3304 } | |
3305 | |
3306 /* | |
3307 * Sets the text used for a given window. | |
3308 * Parameters: | |
3309 * handle: Handle to the window. | |
3310 * text: The text associsated with a given window. | |
3311 */ | |
3312 void dw_window_set_text(HWND handle, char *text) | |
3313 { | |
3314 SetWindowText(handle, text); | |
3315 } | |
3316 | |
3317 /* | |
3318 * Gets the text used for a given window. | |
3319 * Parameters: | |
3320 * handle: Handle to the window. | |
3321 * Returns: | |
3322 * text: The text associsated with a given window. | |
3323 */ | |
3324 char *dw_window_get_text(HWND handle) | |
3325 { | |
3326 char tempbuf[4096] = ""; | |
3327 | |
3328 GetWindowText(handle, tempbuf, 4095); | |
3329 tempbuf[4095] = 0; | |
3330 | |
3331 return strdup(tempbuf); | |
3332 } | |
3333 | |
3334 /* | |
3335 * Disables given window (widget). | |
3336 * Parameters: | |
3337 * handle: Handle to the window. | |
3338 */ | |
3339 void dw_window_disable(HWND handle) | |
3340 { | |
3341 EnableWindow(handle, FALSE); | |
3342 } | |
3343 | |
3344 /* | |
3345 * Enables given window (widget). | |
3346 * Parameters: | |
3347 * handle: Handle to the window. | |
3348 */ | |
3349 void dw_window_enable(HWND handle) | |
3350 { | |
3351 EnableWindow(handle, TRUE); | |
3352 } | |
3353 | |
3354 /* | |
3355 * Gets the child window handle with specified ID. | |
3356 * Parameters: | |
3357 * handle: Handle to the parent window. | |
3358 * id: Integer ID of the child. | |
3359 */ | |
3360 HWND dw_window_from_id(HWND handle, int id) | |
3361 { | |
3362 return 0L; | |
3363 } | |
3364 /* | |
3365 * Pack windows (widgets) into a box from the start (or top). | |
3366 * Parameters: | |
3367 * box: Window handle of the box to be packed into. | |
3368 * item: Window handle of the item to be back. | |
3369 * width: Width in pixels of the item or -1 to be self determined. | |
3370 * height: Height in pixels of the item or -1 to be self determined. | |
3371 * hsize: TRUE if the window (widget) should expand horizontally to fill space given. | |
3372 * vsize: TRUE if the window (widget) should expand vertically to fill space given. | |
3373 * pad: Number of pixels of padding around the item. | |
3374 */ | |
3375 void dw_box_pack_start(HWND box, HWND item, int width, int height, int hsize, int vsize, int pad) | |
3376 { | |
3377 Box *thisbox; | |
3378 | |
3379 thisbox = (Box *)GetWindowLong(box, GWL_USERDATA); | |
3380 if(thisbox) | |
3381 { | |
3382 int z; | |
3383 Item *tmpitem, *thisitem = thisbox->items; | |
3384 char tmpbuf[100]; | |
3385 | |
14
176cee043f1b
Lots of Windows and Unix bug fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
12
diff
changeset
|
3386 tmpitem = malloc(sizeof(Item)*(thisbox->count+1)); |
3 | 3387 |
3388 for(z=0;z<thisbox->count;z++) | |
3389 { | |
3390 tmpitem[z] = thisitem[z]; | |
3391 } | |
3392 | |
3393 GetClassName(item, tmpbuf, 99); | |
3394 | |
3395 if(strnicmp(tmpbuf, FRAMECLASSNAME, 2)==0) | |
3396 tmpitem[thisbox->count].type = TYPEBOX; | |
3397 else | |
3398 tmpitem[thisbox->count].type = TYPEITEM; | |
3399 | |
3400 tmpitem[thisbox->count].hwnd = item; | |
3401 tmpitem[thisbox->count].origwidth = tmpitem[thisbox->count].width = width; | |
3402 tmpitem[thisbox->count].origheight = tmpitem[thisbox->count].height = height; | |
3403 tmpitem[thisbox->count].pad = pad; | |
3404 if(hsize) | |
3405 tmpitem[thisbox->count].hsize = SIZEEXPAND; | |
3406 else | |
3407 tmpitem[thisbox->count].hsize = SIZESTATIC; | |
3408 | |
3409 if(vsize) | |
3410 tmpitem[thisbox->count].vsize = SIZEEXPAND; | |
3411 else | |
3412 tmpitem[thisbox->count].vsize = SIZESTATIC; | |
3413 | |
3414 thisbox->items = tmpitem; | |
3415 | |
3416 if(thisbox->count) | |
3417 free(thisitem); | |
3418 | |
3419 thisbox->count++; | |
3420 | |
3421 SetParent(item, box); | |
3422 ShowWindow(item, SW_SHOW); | |
3423 if(strncmp(tmpbuf, UPDOWN_CLASS, strlen(UPDOWN_CLASS))==0) | |
3424 { | |
3425 ColorInfo *cinfo = (ColorInfo *)GetWindowLong(item, GWL_USERDATA); | |
3426 | |
3427 if(cinfo) | |
3428 { | |
3429 SetParent(cinfo->buddy, box); | |
3430 ShowWindow(cinfo->buddy, SW_SHOW); | |
3431 SendMessage(item, UDM_SETBUDDY, (WPARAM)cinfo->buddy, 0); | |
3432 } | |
3433 } | |
3434 } | |
3435 } | |
3436 | |
3437 /* | |
3438 * Sets the size of a given window (widget). | |
3439 * Parameters: | |
3440 * handle: Window (widget) handle. | |
3441 * width: New width in pixels. | |
3442 * height: New height in pixels. | |
3443 */ | |
3444 void dw_window_set_usize(HWND handle, ULONG width, ULONG height) | |
3445 { | |
3446 SetWindowPos(handle, (HWND)NULL, 0, 0, width, height, SWP_SHOWWINDOW | SWP_NOZORDER | SWP_NOMOVE); | |
3447 } | |
3448 | |
3449 /* | |
3450 * Returns the width of the screen. | |
3451 */ | |
3452 int dw_screen_width(void) | |
3453 { | |
3454 return GetSystemMetrics(SM_CXSCREEN); | |
3455 } | |
3456 | |
3457 /* | |
3458 * Returns the height of the screen. | |
3459 */ | |
3460 int dw_screen_height(void) | |
3461 { | |
3462 return GetSystemMetrics(SM_CYSCREEN); | |
3463 } | |
3464 | |
3465 /* This should return the current color depth */ | |
3466 unsigned long dw_color_depth(void) | |
3467 { | |
3468 int bpp; | |
3469 HDC hdc = GetDC(HWND_DESKTOP); | |
3470 | |
3471 bpp = GetDeviceCaps(hdc, BITSPIXEL); | |
3472 | |
3473 ReleaseDC(HWND_DESKTOP, hdc); | |
3474 | |
3475 return bpp; | |
3476 } | |
3477 | |
3478 | |
3479 /* | |
3480 * Sets the position of a given window (widget). | |
3481 * Parameters: | |
3482 * handle: Window (widget) handle. | |
3483 * x: X location from the bottom left. | |
3484 * y: Y location from the bottom left. | |
3485 */ | |
3486 void dw_window_set_pos(HWND handle, ULONG x, ULONG y) | |
3487 { | |
3488 SetWindowPos(handle, (HWND)NULL, x, y, 0, 0, SWP_NOSIZE | SWP_NOZORDER); | |
3489 } | |
3490 | |
3491 /* | |
3492 * Sets the position and size of a given window (widget). | |
3493 * Parameters: | |
3494 * handle: Window (widget) handle. | |
3495 * x: X location from the bottom left. | |
3496 * y: Y location from the bottom left. | |
3497 * width: Width of the widget. | |
3498 * height: Height of the widget. | |
3499 */ | |
3500 void dw_window_set_pos_size(HWND handle, ULONG x, ULONG y, ULONG width, ULONG height) | |
3501 { | |
3502 SetWindowPos(handle, (HWND)NULL, x, y, width, height, SWP_NOZORDER | SWP_SHOWWINDOW); | |
3503 } | |
3504 | |
3505 /* | |
3506 * Gets the position and size of a given window (widget). | |
3507 * Parameters: | |
3508 * handle: Window (widget) handle. | |
3509 * x: X location from the bottom left. | |
3510 * y: Y location from the bottom left. | |
3511 * width: Width of the widget. | |
3512 * height: Height of the widget. | |
3513 */ | |
3514 void dw_window_get_pos_size(HWND handle, ULONG *x, ULONG *y, ULONG *width, ULONG *height) | |
3515 { | |
3516 WINDOWPLACEMENT wp; | |
3517 | |
3518 wp.length = sizeof(WINDOWPLACEMENT); | |
3519 | |
3520 GetWindowPlacement(handle, &wp); | |
3521 if(x) | |
3522 *x = wp.rcNormalPosition.left; | |
3523 if(y) | |
3524 *y = wp.rcNormalPosition.top; | |
3525 if(width) | |
3526 *width = wp.rcNormalPosition.right - wp.rcNormalPosition.left; | |
3527 if(height) | |
3528 *height = wp.rcNormalPosition.bottom - wp.rcNormalPosition.top; | |
3529 | |
3530 } | |
3531 | |
3532 /* | |
3533 * Sets the style of a given window (widget). | |
3534 * Parameters: | |
3535 * handle: Window (widget) handle. | |
3536 * width: New width in pixels. | |
3537 * height: New height in pixels. | |
3538 */ | |
3539 void dw_window_set_style(HWND handle, ULONG style, ULONG mask) | |
3540 { | |
3541 ULONG tmp, currentstyle = GetWindowLong(handle, GWL_STYLE); | |
3542 | |
3543 tmp = currentstyle | mask; | |
3544 tmp ^= mask; | |
3545 tmp |= style; | |
3546 | |
3547 SetWindowLong(handle, GWL_STYLE, tmp); | |
3548 } | |
3549 | |
3550 /* Finds the physical ID from the reference ID */ | |
3551 int _findnotebookid(NotebookPage **array, int pageid) | |
3552 { | |
3553 int z; | |
3554 | |
3555 for(z=0;z<256;z++) | |
3556 { | |
3557 if(array[z] && array[z]->realid == pageid) | |
3558 return z; | |
3559 } | |
3560 return -1; | |
3561 } | |
3562 | |
3563 /* | |
3564 * Adds a new page to specified notebook. | |
3565 * Parameters: | |
3566 * handle: Window (widget) handle. | |
3567 * flags: Any additional page creation flags. | |
3568 * front: If TRUE page is added at the beginning. | |
3569 */ | |
3570 ULONG dw_notebook_page_new(HWND handle, ULONG flags, int front) | |
3571 { | |
3572 NotebookPage **array = (NotebookPage **)GetWindowLong(handle, GWL_USERDATA); | |
3573 | |
3574 if(array) | |
3575 { | |
3576 int z, refid = -1; | |
3577 | |
3578 for(z=0;z<256;z++) | |
3579 { | |
3580 if(_findnotebookid(array, z) == -1) | |
3581 { | |
3582 refid = z; | |
3583 break; | |
3584 } | |
3585 } | |
3586 | |
3587 if(refid == -1) | |
3588 return -1; | |
3589 | |
3590 for(z=0;z<256;z++) | |
3591 { | |
3592 if(!array[z]) | |
3593 { | |
3594 int oldpage = TabCtrl_GetCurSel(handle); | |
3595 | |
3596 array[z] = calloc(1, sizeof(NotebookPage)); | |
3597 array[z]->realid = refid; | |
3598 array[z]->item.mask = TCIF_TEXT; | |
3599 array[z]->item.iImage = -1; | |
3600 array[z]->item.pszText = ""; | |
3601 TabCtrl_InsertItem(handle, z, &(array[z]->item)); | |
3602 | |
3603 if(oldpage > -1 && array[oldpage]) | |
3604 SetParent(array[oldpage]->hwnd, DW_HWND_OBJECT); | |
3605 | |
3606 TabCtrl_SetCurSel(handle, z); | |
3607 return refid; | |
3608 } | |
3609 } | |
3610 } | |
3611 return -1; | |
3612 } | |
3613 | |
3614 /* | |
3615 * Sets the text on the specified notebook tab. | |
3616 * Parameters: | |
3617 * handle: Notebook handle. | |
3618 * pageid: Page ID of the tab to set. | |
3619 * text: Pointer to the text to set. | |
3620 */ | |
3621 void dw_notebook_page_set_text(HWND handle, ULONG pageidx, char *text) | |
3622 { | |
3623 | |
3624 NotebookPage **array = (NotebookPage **)GetWindowLong(handle, GWL_USERDATA); | |
3625 int pageid; | |
3626 | |
3627 if(!array) | |
3628 return; | |
3629 | |
3630 pageid = _findnotebookid(array, pageidx); | |
3631 | |
3632 if(pageid > -1 && array[pageid]) | |
3633 { | |
3634 array[pageid]->item.mask = TCIF_TEXT; | |
3635 array[pageid]->item.pszText = text; | |
3636 TabCtrl_SetItem(handle, pageid, &(array[pageid]->item)); | |
3637 _resize_notebook_page(handle, pageid); | |
3638 } | |
3639 } | |
3640 | |
3641 /* | |
3642 * Sets the text on the specified notebook tab status area. | |
3643 * Parameters: | |
3644 * handle: Notebook handle. | |
3645 * pageid: Page ID of the tab to set. | |
3646 * text: Pointer to the text to set. | |
3647 */ | |
3648 void dw_notebook_page_set_status_text(HWND handle, ULONG pageid, char *text) | |
3649 { | |
3650 } | |
3651 | |
3652 /* | |
3653 * Packs the specified box into the notebook page. | |
3654 * Parameters: | |
3655 * handle: Handle to the notebook to be packed. | |
3656 * pageid: Page ID in the notebook which is being packed. | |
3657 * page: Box handle to be packed. | |
3658 */ | |
3659 void dw_notebook_pack(HWND handle, ULONG pageidx, HWND page) | |
3660 { | |
3661 NotebookPage **array = (NotebookPage **)GetWindowLong(handle, GWL_USERDATA); | |
3662 int pageid; | |
3663 | |
3664 if(!array) | |
3665 return; | |
3666 | |
3667 pageid = _findnotebookid(array, pageidx); | |
3668 | |
3669 if(pageid > -1 && array[pageid]) | |
3670 { | |
3671 HWND tmpbox = dw_box_new(BOXVERT, 0); | |
3672 | |
3673 dw_box_pack_start(tmpbox, page, 0, 0, TRUE, TRUE, 0); | |
3674 SubclassWindow(tmpbox, _wndproc); | |
3675 if(array[pageid]->hwnd) | |
3676 dw_window_destroy(array[pageid]->hwnd); | |
3677 array[pageid]->hwnd = tmpbox; | |
3678 if(pageidx == dw_notebook_page_query(handle)) | |
3679 { | |
3680 SetParent(tmpbox, handle); | |
3681 _resize_notebook_page(handle, pageid); | |
3682 } | |
3683 } | |
3684 } | |
3685 | |
3686 /* | |
3687 * Remove a page from a notebook. | |
3688 * Parameters: | |
3689 * handle: Handle to the notebook widget. | |
3690 * pageid: ID of the page to be destroyed. | |
3691 */ | |
3692 void dw_notebook_page_destroy(HWND handle, unsigned int pageidx) | |
3693 { | |
3694 NotebookPage **array = (NotebookPage **)GetWindowLong(handle, GWL_USERDATA); | |
3695 int newid = -1, z, pageid; | |
3696 | |
3697 if(!array) | |
3698 return; | |
3699 | |
3700 pageid = _findnotebookid(array, pageidx); | |
3701 | |
3702 if(pageid < 0) | |
3703 return; | |
3704 | |
3705 if(array[pageid]) | |
3706 { | |
3707 SetParent(array[pageid]->hwnd, DW_HWND_OBJECT); | |
3708 free(array[pageid]); | |
3709 array[pageid] = NULL; | |
3710 } | |
3711 | |
3712 TabCtrl_DeleteItem(handle, pageid); | |
3713 | |
3714 /* Shift the pages over 1 */ | |
3715 for(z=pageid;z<255;z++) | |
3716 array[z] = array[z+1]; | |
3717 array[255] = NULL; | |
3718 | |
3719 for(z=0;z<256;z++) | |
3720 { | |
3721 if(array[z]) | |
3722 { | |
3723 newid = z; | |
3724 break; | |
3725 } | |
3726 } | |
3727 if(newid > -1) | |
3728 { | |
3729 SetParent(array[newid]->hwnd, handle); | |
3730 _resize_notebook_page(handle, newid); | |
3731 dw_notebook_page_set(handle, array[newid]->realid); | |
3732 } | |
3733 } | |
3734 | |
3735 /* | |
3736 * Queries the currently visible page ID. | |
3737 * Parameters: | |
3738 * handle: Handle to the notebook widget. | |
3739 */ | |
3740 unsigned int dw_notebook_page_query(HWND handle) | |
3741 { | |
3742 NotebookPage **array = (NotebookPage **)GetWindowLong(handle, GWL_USERDATA); | |
3743 int physid = TabCtrl_GetCurSel(handle); | |
3744 | |
3745 if(physid > -1 && physid < 256 && array && array[physid]) | |
3746 return array[physid]->realid; | |
3747 return -1; | |
3748 } | |
3749 | |
3750 /* | |
3751 * Sets the currently visible page ID. | |
3752 * Parameters: | |
3753 * handle: Handle to the notebook widget. | |
3754 * pageid: ID of the page to be made visible. | |
3755 */ | |
3756 void dw_notebook_page_set(HWND handle, unsigned int pageidx) | |
3757 { | |
3758 NotebookPage **array = (NotebookPage **)GetWindowLong(handle, GWL_USERDATA); | |
3759 int pageid; | |
3760 | |
3761 if(!array) | |
3762 return; | |
3763 | |
3764 pageid= _findnotebookid(array, pageidx); | |
3765 | |
3766 if(pageid > -1 && pageid < 256) | |
3767 TabCtrl_SetCurSel(handle, pageid); | |
3768 } | |
3769 | |
3770 /* | |
3771 * Appends the specified text to the listbox's (or combobox) entry list. | |
3772 * Parameters: | |
3773 * handle: Handle to the listbox to be appended to. | |
3774 * text: Text to append into listbox. | |
3775 */ | |
3776 void dw_listbox_append(HWND handle, char *text) | |
3777 { | |
3778 char tmpbuf[100]; | |
3779 | |
3780 GetClassName(handle, tmpbuf, 99); | |
3781 | |
3782 if(strnicmp(tmpbuf, COMBOBOXCLASSNAME, strlen(COMBOBOXCLASSNAME))==0) | |
3783 SendMessage(handle, | |
3784 CB_ADDSTRING, | |
3785 0, (LPARAM)text); | |
3786 else | |
3787 SendMessage(handle, | |
3788 LB_ADDSTRING, | |
3789 0, (LPARAM)text); | |
3790 } | |
3791 | |
3792 /* | |
3793 * Clears the listbox's (or combobox) list of all entries. | |
3794 * Parameters: | |
3795 * handle: Handle to the listbox to be cleared. | |
3796 */ | |
3797 void dw_listbox_clear(HWND handle) | |
3798 { | |
3799 char tmpbuf[100]; | |
3800 | |
3801 GetClassName(handle, tmpbuf, 99); | |
3802 | |
3803 if(strnicmp(tmpbuf, COMBOBOXCLASSNAME, strlen(COMBOBOXCLASSNAME))==0) | |
3804 { | |
3805 char *buf = dw_window_get_text(handle); | |
3806 | |
3807 SendMessage(handle, | |
3808 CB_RESETCONTENT, 0L, 0L); | |
3809 | |
3810 if(buf) | |
3811 { | |
3812 dw_window_set_text(handle, buf); | |
3813 free(buf); | |
3814 } | |
3815 } | |
3816 else | |
3817 SendMessage(handle, | |
3818 LB_RESETCONTENT, 0L, 0L); | |
3819 } | |
3820 | |
3821 /* | |
3822 * Sets the text of a given listbox entry. | |
3823 * Parameters: | |
3824 * handle: Handle to the listbox to be queried. | |
3825 * index: Index into the list to be queried. | |
3826 * buffer: Buffer where text will be copied. | |
3827 */ | |
3828 void dw_listbox_set_text(HWND handle, unsigned int index, char *buffer) | |
3829 { | |
3830 unsigned int sel = (unsigned int)SendMessage(handle, LB_GETCURSEL, 0, 0); | |
3831 SendMessage(handle, LB_DELETESTRING, (WPARAM)index, 0); | |
3832 SendMessage(handle, LB_INSERTSTRING, (WPARAM)index, (LPARAM)buffer); | |
3833 SendMessage(handle, LB_SETCURSEL, (WPARAM)sel, 0); | |
3834 SendMessage(handle, LB_SETSEL, (WPARAM)TRUE, (LPARAM)sel); | |
3835 } | |
3836 | |
3837 /* | |
3838 * Copies the given index item's text into buffer. | |
3839 * Parameters: | |
3840 * handle: Handle to the listbox to be queried. | |
3841 * index: Index into the list to be queried. | |
3842 * buffer: Buffer where text will be copied. | |
3843 * length: Length of the buffer (including NULL). | |
3844 */ | |
3845 void dw_listbox_query_text(HWND handle, unsigned int index, char *buffer, unsigned int length) | |
3846 { | |
3847 SendMessage(handle, | |
3848 LB_GETTEXT, (WPARAM)index, (LPARAM)buffer); | |
3849 } | |
3850 | |
3851 /* | |
3852 * Returns the index to the item in the list currently selected. | |
3853 * Parameters: | |
3854 * handle: Handle to the listbox to be queried. | |
3855 */ | |
3856 unsigned int dw_listbox_selected(HWND handle) | |
3857 { | |
3858 char tmpbuf[100]; | |
3859 | |
3860 GetClassName(handle, tmpbuf, 99); | |
3861 | |
3862 if(strnicmp(tmpbuf, COMBOBOXCLASSNAME, strlen(COMBOBOXCLASSNAME))==0) | |
3863 return (unsigned int)SendMessage(handle, | |
3864 CB_GETCURSEL, | |
3865 0, 0); | |
3866 | |
3867 return (unsigned int)SendMessage(handle, | |
3868 LB_GETCURSEL, | |
3869 0, 0); | |
3870 } | |
3871 | |
3872 /* | |
3873 * Returns the index to the current selected item or -1 when done. | |
3874 * Parameters: | |
3875 * handle: Handle to the listbox to be queried. | |
3876 * where: Either the previous return or -1 to restart. | |
3877 */ | |
3878 int dw_listbox_selected_multi(HWND handle, int where) | |
3879 { | |
3880 int *array, count, z; | |
3881 | |
3882 count = (int)SendMessage(handle, LB_GETSELCOUNT, 0, 0); | |
3883 if(count > 0) | |
3884 { | |
3885 array = malloc(sizeof(int)*count); | |
3886 SendMessage(handle, LB_GETSELITEMS, (WPARAM)count, (LPARAM)array); | |
3887 | |
3888 if(where == -1) | |
3889 { | |
3890 int ret = array[0]; | |
3891 free(array); | |
3892 return ret; | |
3893 } | |
3894 for(z=0;z<count;z++) | |
3895 { | |
3896 if(array[z] == where && (z+1) < count) | |
3897 { | |
3898 int ret = array[z+1]; | |
3899 free(array); | |
3900 return ret; | |
3901 } | |
3902 } | |
3903 free(array); | |
3904 } | |
3905 return -1; | |
3906 } | |
3907 | |
3908 /* | |
3909 * Sets the selection state of a given index. | |
3910 * Parameters: | |
3911 * handle: Handle to the listbox to be set. | |
3912 * index: Item index. | |
3913 * state: TRUE if selected FALSE if unselected. | |
3914 */ | |
3915 void dw_listbox_select(HWND handle, int index, int state) | |
3916 { | |
3917 char tmpbuf[100]; | |
3918 | |
3919 GetClassName(handle, tmpbuf, 99); | |
3920 | |
3921 if(strnicmp(tmpbuf, COMBOBOXCLASSNAME, strlen(COMBOBOXCLASSNAME))==0) | |
3922 SendMessage(handle, CB_SETCURSEL, (WPARAM)index, 0); | |
3923 else | |
3924 { | |
3925 SendMessage(handle, LB_SETCURSEL, (WPARAM)index, 0); | |
3926 SendMessage(handle, LB_SETSEL, (WPARAM)state, (LPARAM)index); | |
3927 } | |
3928 _wndproc(handle, WM_COMMAND, (WPARAM)(LBN_SELCHANGE << 16), (LPARAM)handle); | |
3929 } | |
3930 | |
3931 /* | |
3932 * Deletes the item with given index from the list. | |
3933 * Parameters: | |
3934 * handle: Handle to the listbox to be set. | |
3935 * index: Item index. | |
3936 */ | |
3937 void dw_listbox_delete(HWND handle, int index) | |
3938 { | |
3939 SendMessage(handle, LB_DELETESTRING, (WPARAM)index, 0); | |
3940 } | |
3941 | |
3942 /* | |
3943 * Returns the listbox's item count. | |
3944 * Parameters: | |
3945 * handle: Handle to the listbox to be cleared. | |
3946 */ | |
3947 int dw_listbox_count(HWND handle) | |
3948 { | |
3949 char tmpbuf[100]; | |
3950 | |
3951 GetClassName(handle, tmpbuf, 99); | |
3952 | |
3953 if(strnicmp(tmpbuf, COMBOBOXCLASSNAME, strlen(COMBOBOXCLASSNAME))==0) | |
3954 return (int)SendMessage(handle, | |
3955 CB_GETCOUNT,0L, 0L); | |
3956 | |
3957 return (int)SendMessage(handle, | |
3958 LB_GETCOUNT,0L, 0L); | |
3959 } | |
3960 | |
3961 /* | |
3962 * Sets the topmost item in the viewport. | |
3963 * Parameters: | |
3964 * handle: Handle to the listbox to be cleared. | |
3965 * top: Index to the top item. | |
3966 */ | |
3967 void dw_listbox_set_top(HWND handle, int top) | |
3968 { | |
3969 SendMessage(handle, LB_SETTOPINDEX, (WPARAM)top, 0); | |
3970 } | |
3971 | |
3972 #define MLE_MAX 200000 | |
3973 /* | |
3974 * Adds text to an MLE box and returns the current point. | |
3975 * Parameters: | |
3976 * handle: Handle to the MLE to be queried. | |
3977 * buffer: Text buffer to be imported. | |
3978 * startpoint: Point to start entering text. | |
3979 */ | |
3980 unsigned int dw_mle_import(HWND handle, char *buffer, int startpoint) | |
3981 { | |
3982 char *tmpbuf = malloc(MLE_MAX+1); | |
3983 int len; | |
3984 | |
3985 if(startpoint < 0) | |
3986 startpoint = 0; | |
3987 | |
3988 GetWindowText(handle, tmpbuf, MLE_MAX); | |
3989 tmpbuf[MLE_MAX] = 0; | |
3990 | |
3991 len = strlen(tmpbuf); | |
3992 if(len) | |
3993 memcpy(&tmpbuf[startpoint+strlen(buffer)], &tmpbuf[startpoint], (len-startpoint)); | |
3994 memcpy(&tmpbuf[startpoint], buffer, strlen(buffer)); | |
3995 | |
3996 tmpbuf[len+strlen(buffer)] = 0; | |
3997 | |
3998 SetWindowText(handle, tmpbuf); | |
3999 | |
4000 free(tmpbuf); | |
4001 return startpoint+strlen(buffer); | |
4002 } | |
4003 | |
4004 /* | |
4005 * Grabs text from an MLE box. | |
4006 * Parameters: | |
4007 * handle: Handle to the MLE to be queried. | |
4008 * buffer: Text buffer to be exported. | |
4009 * startpoint: Point to start grabbing text. | |
4010 * length: Amount of text to be grabbed. | |
4011 */ | |
4012 void dw_mle_export(HWND handle, char *buffer, int startpoint, int length) | |
4013 { | |
4014 char *tmpbuf = malloc(MLE_MAX+1); | |
4015 | |
4016 GetWindowText(handle, tmpbuf, MLE_MAX); | |
4017 tmpbuf[MLE_MAX] = 0; | |
4018 | |
4019 memcpy(buffer, &tmpbuf[startpoint], length); | |
4020 | |
4021 free(tmpbuf); | |
4022 } | |
4023 | |
4024 /* | |
4025 * Obtains information about an MLE box. | |
4026 * Parameters: | |
4027 * handle: Handle to the MLE to be queried. | |
4028 * bytes: A pointer to a variable to return the total bytes. | |
4029 * lines: A pointer to a variable to return the number of lines. | |
4030 */ | |
4031 void dw_mle_query(HWND handle, unsigned long *bytes, unsigned long *lines) | |
4032 { | |
4033 char *tmpbuf = malloc(MLE_MAX+1); | |
4034 | |
4035 GetWindowText(handle, tmpbuf, MLE_MAX); | |
4036 tmpbuf[MLE_MAX] = 0; | |
4037 | |
4038 if(bytes) | |
4039 *bytes = strlen(tmpbuf); | |
4040 if(lines) | |
4041 *lines = (unsigned long)SendMessage(handle, EM_GETLINECOUNT, 0, 0); | |
4042 | |
4043 free(tmpbuf); | |
4044 } | |
4045 | |
4046 /* | |
4047 * Deletes text from an MLE box. | |
4048 * Parameters: | |
4049 * handle: Handle to the MLE to be deleted from. | |
4050 * startpoint: Point to start deleting text. | |
4051 * length: Amount of text to be deleted. | |
4052 */ | |
4053 void dw_mle_delete(HWND handle, int startpoint, int length) | |
4054 { | |
4055 char *tmpbuf = malloc(MLE_MAX+1); | |
4056 int len; | |
4057 | |
4058 GetWindowText(handle, tmpbuf, MLE_MAX); | |
4059 tmpbuf[MLE_MAX] = 0; | |
4060 | |
4061 len = strlen(tmpbuf); | |
4062 | |
4063 strcpy(&tmpbuf[startpoint], &tmpbuf[startpoint+length]); | |
4064 | |
4065 SetWindowText(handle, tmpbuf); | |
4066 | |
4067 free(tmpbuf); | |
4068 } | |
4069 | |
4070 /* | |
4071 * Clears all text from an MLE box. | |
4072 * Parameters: | |
4073 * handle: Handle to the MLE to be cleared. | |
4074 */ | |
4075 void dw_mle_clear(HWND handle) | |
4076 { | |
4077 SetWindowText(handle, ""); | |
4078 } | |
4079 | |
4080 /* | |
4081 * Sets the visible line of an MLE box. | |
4082 * Parameters: | |
4083 * handle: Handle to the MLE. | |
4084 * line: Line to be visible. | |
4085 */ | |
4086 void dw_mle_set_visible(HWND handle, int line) | |
4087 { | |
4088 int point = (int)SendMessage(handle, EM_LINEINDEX, (WPARAM)line, 0); | |
4089 dw_mle_set(handle, point); | |
4090 } | |
4091 | |
4092 /* | |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4093 * Sets the editablity of an MLE box. |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4094 * Parameters: |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4095 * handle: Handle to the MLE. |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4096 * state: TRUE if it can be edited, FALSE for readonly. |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4097 */ |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4098 void dw_mle_set_editable(HWND handle, int state) |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4099 { |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4100 SendMessage(handle, EM_SETREADONLY, (WPARAM)(state ? FALSE : TRUE), 0); |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4101 } |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4102 |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4103 /* |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4104 * Sets the word wrap state of an MLE box. |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4105 * Parameters: |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4106 * handle: Handle to the MLE. |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4107 * state: TRUE if it wraps, FALSE if it doesn't. |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4108 */ |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4109 void dw_mle_set_word_wrap(HWND handle, int state) |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4110 { |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4111 } |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4112 |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4113 /* |
3 | 4114 * Sets the current cursor position of an MLE box. |
4115 * Parameters: | |
4116 * handle: Handle to the MLE to be positioned. | |
4117 * point: Point to position cursor. | |
4118 */ | |
4119 void dw_mle_set(HWND handle, int point) | |
4120 { | |
4121 SendMessage(handle, EM_SETSEL, (WPARAM)point, (LPARAM)point); | |
4122 SendMessage(handle, EM_SCROLLCARET, 0, 0); | |
4123 } | |
4124 | |
4125 /* | |
4126 * Finds text in an MLE box. | |
4127 * Parameters: | |
4128 * handle: Handle to the MLE to be cleared. | |
4129 * text: Text to search for. | |
4130 * point: Start point of search. | |
4131 * flags: Search specific flags. | |
4132 */ | |
4133 int dw_mle_search(HWND handle, char *text, int point, unsigned long flags) | |
4134 { | |
4135 char *tmpbuf = malloc(MLE_MAX+1); | |
4136 int z, len, textlen, retval = 0; | |
4137 | |
4138 GetWindowText(handle, tmpbuf, MLE_MAX); | |
4139 tmpbuf[MLE_MAX] = 0; | |
4140 | |
4141 len = strlen(tmpbuf); | |
4142 textlen = strlen(text); | |
4143 | |
4144 if(flags & DW_MLE_CASESENSITIVE) | |
4145 { | |
4146 for(z=point;z<(len-textlen) && !retval;z++) | |
4147 { | |
4148 if(strncmp(&tmpbuf[z], text, textlen) == 0) | |
4149 retval = z + textlen; | |
4150 } | |
4151 } | |
4152 else | |
4153 { | |
4154 for(z=point;z<(len-textlen) && !retval;z++) | |
4155 { | |
4156 if(strnicmp(&tmpbuf[z], text, textlen) == 0) | |
4157 retval = z + textlen; | |
4158 } | |
4159 } | |
4160 | |
4161 if(retval) | |
4162 { | |
4163 SendMessage(handle, EM_SETSEL, (WPARAM)retval - textlen, (LPARAM)retval); | |
4164 SendMessage(handle, EM_SCROLLCARET, 0, 0); | |
4165 } | |
4166 | |
4167 free(tmpbuf); | |
4168 | |
4169 return retval; | |
4170 } | |
4171 | |
4172 /* | |
4173 * Stops redrawing of an MLE box. | |
4174 * Parameters: | |
4175 * handle: Handle to the MLE to freeze. | |
4176 */ | |
4177 void dw_mle_freeze(HWND handle) | |
4178 { | |
4179 } | |
4180 | |
4181 /* | |
4182 * Resumes redrawing of an MLE box. | |
4183 * Parameters: | |
4184 * handle: Handle to the MLE to thaw. | |
4185 */ | |
4186 void dw_mle_thaw(HWND handle) | |
4187 { | |
4188 } | |
4189 | |
4190 /* | |
4191 * Returns the range of the slider. | |
4192 * Parameters: | |
4193 * handle: Handle to the slider to be queried. | |
4194 */ | |
4195 unsigned int dw_slider_query_range(HWND handle) | |
4196 { | |
4197 return (unsigned int)SendMessage(handle, PBM_GETRANGE, (WPARAM)FALSE, 0); | |
4198 } | |
4199 | |
4200 /* | |
4201 * Sets the slider position. | |
4202 * Parameters: | |
4203 * handle: Handle to the slider to be set. | |
4204 * position: Position of the slider withing the range. | |
4205 */ | |
4206 void dw_slider_set_pos(HWND handle, unsigned int position) | |
4207 { | |
4208 SendMessage(handle, PBM_SETPOS, (WPARAM)position, 0); | |
4209 } | |
4210 | |
4211 /* | |
4212 * Sets the spinbutton value. | |
4213 * Parameters: | |
4214 * handle: Handle to the spinbutton to be set. | |
4215 * position: Current value of the spinbutton. | |
4216 */ | |
4217 void dw_spinbutton_set_pos(HWND handle, long position) | |
4218 { | |
4219 char tmpbuf[100]; | |
4220 ColorInfo *cinfo = (ColorInfo *)GetWindowLong(handle, GWL_USERDATA); | |
4221 | |
4222 sprintf(tmpbuf, "%d", position); | |
4223 | |
4224 if(cinfo && cinfo->buddy) | |
4225 SetWindowText(cinfo->buddy, tmpbuf); | |
4226 | |
4227 if(IS_WIN98PLUS) | |
4228 SendMessage(handle, UDM_SETPOS32, 0, (LPARAM)position); | |
4229 else | |
4230 SendMessage(handle, UDM_SETPOS, 0, (LPARAM)MAKELONG((short)position, 0)); | |
4231 } | |
4232 | |
4233 /* | |
4234 * Sets the spinbutton limits. | |
4235 * Parameters: | |
4236 * handle: Handle to the spinbutton to be set. | |
4237 * position: Current value of the spinbutton. | |
4238 * position: Current value of the spinbutton. | |
4239 */ | |
4240 void dw_spinbutton_set_limits(HWND handle, long upper, long lower) | |
4241 { | |
4242 if(IS_WIN98PLUS) | |
4243 SendMessage(handle, UDM_SETRANGE32, (WPARAM)lower,(LPARAM)upper); | |
4244 else | |
4245 SendMessage(handle, UDM_SETRANGE32, (WPARAM)((short)lower), | |
4246 (LPARAM)((short)upper)); | |
4247 } | |
4248 | |
4249 /* | |
4250 * Sets the entryfield character limit. | |
4251 * Parameters: | |
4252 * handle: Handle to the spinbutton to be set. | |
4253 * limit: Number of characters the entryfield will take. | |
4254 */ | |
4255 void dw_entryfield_set_limit(HWND handle, ULONG limit) | |
4256 { | |
4257 SendMessage(handle, EM_SETLIMITTEXT, (WPARAM)limit, 0); | |
4258 } | |
4259 | |
4260 /* | |
4261 * Returns the current value of the spinbutton. | |
4262 * Parameters: | |
4263 * handle: Handle to the spinbutton to be queried. | |
4264 */ | |
4265 long dw_spinbutton_query(HWND handle) | |
4266 { | |
4267 if(IS_WIN98PLUS) | |
4268 return (long)SendMessage(handle, UDM_GETPOS32, 0, 0); | |
4269 else | |
4270 return (long)SendMessage(handle, UDM_GETPOS, 0, 0); | |
4271 } | |
4272 | |
4273 /* | |
4274 * Returns the state of the checkbox. | |
4275 * Parameters: | |
4276 * handle: Handle to the checkbox to be queried. | |
4277 */ | |
4278 int dw_checkbox_query(HWND handle) | |
4279 { | |
4280 if(SendMessage(handle, BM_GETCHECK, 0, 0) == BST_CHECKED) | |
4281 return TRUE; | |
4282 return FALSE; | |
4283 } | |
4284 | |
4285 /* | |
4286 * Sets the state of the checkbox. | |
4287 * Parameters: | |
4288 * handle: Handle to the checkbox to be queried. | |
4289 * value: TRUE for checked, FALSE for unchecked. | |
4290 */ | |
4291 void dw_checkbox_set(HWND handle, int value) | |
4292 { | |
4293 ColorInfo *cinfo = (ColorInfo *)GetWindowLong(handle, GWL_USERDATA); | |
4294 | |
4295 if(cinfo && !cinfo->user) | |
4296 SendMessage(handle, BM_CLICK, 0, 0); | |
4297 SendMessage(handle, BM_SETCHECK, (WPARAM)value, 0); | |
4298 } | |
4299 | |
4300 /* | |
4301 * Sets up the container columns. | |
4302 * Parameters: | |
4303 * handle: Handle to the container to be configured. | |
4304 * flags: An array of unsigned longs with column flags. | |
4305 * titles: An array of strings with column text titles. | |
4306 * count: The number of columns (this should match the arrays). | |
4307 * separator: The column number that contains the main separator. | |
4308 * (only used on OS/2 but must be >= 0 on all) | |
4309 */ | |
4310 int dw_container_setup(HWND handle, unsigned long *flags, char **titles, int count, int separator) | |
4311 { | |
4312 ContainerInfo *cinfo = (ContainerInfo *)GetWindowLong(handle, GWL_USERDATA); | |
4313 int z, l = 0; | |
4314 unsigned long *tempflags = malloc(sizeof(unsigned long) * (count + 2)); | |
4315 LV_COLUMN lvc; | |
4316 | |
4317 if(separator == -1) | |
4318 l = 1; | |
4319 | |
4320 memcpy(&tempflags[l], flags, sizeof(unsigned long) * count); | |
4321 tempflags[count + l] = 0; | |
4322 cinfo->flags = tempflags; | |
4323 | |
4324 | |
4325 for(z=0;z<count;z++) | |
4326 { | |
4327 lvc.mask = LVCF_TEXT | LVCF_WIDTH | LVCF_SUBITEM /*| LVCF_FORMAT*/; | |
4328 lvc.pszText = titles[z]; | |
4329 lvc.cchTextMax = strlen(titles[z]); | |
4330 lvc.fmt = flags[z]; | |
4331 lvc.cx = 75; | |
4332 lvc.iSubItem = count; | |
4333 SendMessage(handle, LVM_INSERTCOLUMN, (WPARAM)z + l, (LPARAM)&lvc); | |
4334 } | |
4335 ListView_SetExtendedListViewStyle(handle, LVS_EX_FULLROWSELECT | LVS_EX_GRIDLINES); | |
4336 return TRUE; | |
4337 } | |
4338 | |
4339 /* | |
4340 * Sets up the filesystem columns, note: filesystem always has an icon/filename field. | |
4341 * Parameters: | |
4342 * handle: Handle to the container to be configured. | |
4343 * flags: An array of unsigned longs with column flags. | |
4344 * titles: An array of strings with column text titles. | |
4345 * count: The number of columns (this should match the arrays). | |
4346 */ | |
4347 int dw_filesystem_setup(HWND handle, unsigned long *flags, char **titles, int count) | |
4348 { | |
4349 LV_COLUMN lvc; | |
4350 | |
4351 lvc.mask = LVCF_TEXT | LVCF_WIDTH | LVCF_SUBITEM; | |
4352 lvc.pszText = "Filename"; | |
4353 lvc.cchTextMax = 8; | |
4354 lvc.fmt = 0; | |
4355 if(!count) | |
4356 lvc.cx = 300; | |
4357 else | |
4358 lvc.cx = 150; | |
4359 lvc.iSubItem = count; | |
4360 SendMessage(handle, LVM_INSERTCOLUMN, (WPARAM)0, (LPARAM)&lvc); | |
4361 dw_container_setup(handle, flags, titles, count, -1); | |
4362 return TRUE; | |
4363 } | |
4364 | |
4365 /* | |
4366 * Obtains an icon from a module (or header in GTK). | |
4367 * Parameters: | |
4368 * module: Handle to module (DLL) in OS/2 and Windows. | |
4369 * id: A unsigned long id int the resources on OS/2 and | |
4370 * Windows, on GTK this is converted to a pointer | |
4371 * to an embedded XPM. | |
4372 */ | |
4373 unsigned long dw_icon_load(unsigned long module, unsigned long id) | |
4374 { | |
4375 return (unsigned long)LoadIcon(DWInstance, MAKEINTRESOURCE(id)); | |
4376 } | |
4377 | |
4378 /* | |
4379 * Frees a loaded resource in OS/2 and Windows. | |
4380 * Parameters: | |
4381 * handle: Handle to icon returned by dw_icon_load(). | |
4382 */ | |
4383 void dw_icon_free(unsigned long handle) | |
4384 { | |
4385 DestroyIcon((HICON)handle); | |
4386 } | |
4387 | |
4388 /* | |
4389 * Allocates memory used to populate a container. | |
4390 * Parameters: | |
4391 * handle: Handle to the container window (widget). | |
4392 * rowcount: The number of items to be populated. | |
4393 */ | |
4394 void *dw_container_alloc(HWND handle, int rowcount) | |
4395 { | |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4396 LV_ITEM lvi; |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4397 int z; |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4398 |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4399 lvi.mask = LVIF_DI_SETITEM | LVIF_TEXT; |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4400 lvi.iSubItem = 0; |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4401 lvi.pszText = ""; |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4402 lvi.cchTextMax = 1; |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4403 |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4404 for(z=0;z<rowcount;z++) |
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4405 ListView_InsertItem(handle, &lvi); |
3 | 4406 return (void *)handle; |
4407 } | |
4408 | |
4409 /* Finds a icon in the table, otherwise it adds it to the table | |
4410 * and returns the index in the table. | |
4411 */ | |
4412 int _lookup_icon(HWND handle, HICON hicon) | |
4413 { | |
4414 int z; | |
4415 static HWND lasthwnd = NULL; | |
4416 | |
4417 if(!lookup[0]) | |
4418 { | |
4419 hSmall = ImageList_Create(16, 16, FALSE, ICON_INDEX_LIMIT, 0); | |
4420 hLarge = ImageList_Create(32, 32, FALSE, ICON_INDEX_LIMIT, 0); | |
4421 } | |
4422 for(z=0;z<ICON_INDEX_LIMIT;z++) | |
4423 { | |
4424 if(!lookup[z]) | |
4425 { | |
4426 lookup[z] = hicon; | |
4427 ImageList_AddIcon(hSmall, hicon); | |
4428 ImageList_AddIcon(hLarge, hicon); | |
4429 ListView_SetImageList(handle, hSmall, LVSIL_SMALL); | |
4430 ListView_SetImageList(handle, hLarge, LVSIL_NORMAL); | |
4431 lasthwnd = handle; | |
4432 return z; | |
4433 } | |
4434 | |
4435 if(hicon == lookup[z]) | |
4436 { | |
4437 if(lasthwnd != handle) | |
4438 { | |
4439 ListView_SetImageList(handle, hSmall, LVSIL_SMALL); | |
4440 ListView_SetImageList(handle, hLarge, LVSIL_NORMAL); | |
4441 lasthwnd = handle; | |
4442 } | |
4443 return z; | |
4444 } | |
4445 } | |
4446 return -1; | |
4447 } | |
4448 | |
4449 /* | |
4450 * Sets an item in specified row and column to the given data. | |
4451 * Parameters: | |
4452 * handle: Handle to the container window (widget). | |
4453 * pointer: Pointer to the allocated memory in dw_container_alloc(). | |
4454 * column: Zero based column of data being set. | |
4455 * row: Zero based row of data being set. | |
4456 * data: Pointer to the data to be added. | |
4457 */ | |
4458 void dw_filesystem_set_file(HWND handle, void *pointer, int row, char *filename, unsigned long icon) | |
4459 { | |
4460 LV_ITEM lvi; | |
4461 | |
4462 lvi.iItem = row; | |
4463 lvi.iSubItem = 0; | |
4464 lvi.mask = LVIF_DI_SETITEM | LVIF_IMAGE | LVIF_TEXT; | |
4465 lvi.pszText = filename; | |
4466 lvi.cchTextMax = strlen(filename); | |
4467 lvi.iImage = _lookup_icon(handle, (HICON)icon); | |
4468 | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4469 ListView_SetItem(handle, &lvi); |
3 | 4470 } |
4471 | |
4472 /* | |
4473 * Sets an item in specified row and column to the given data. | |
4474 * Parameters: | |
4475 * handle: Handle to the container window (widget). | |
4476 * pointer: Pointer to the allocated memory in dw_container_alloc(). | |
4477 * column: Zero based column of data being set. | |
4478 * row: Zero based row of data being set. | |
4479 * data: Pointer to the data to be added. | |
4480 */ | |
4481 void dw_filesystem_set_item(HWND handle, void *pointer, int column, int row, void *data) | |
4482 { | |
4483 dw_container_set_item(handle, pointer, column + 1, row, data); | |
4484 } | |
4485 | |
4486 /* | |
4487 * Sets an item in specified row and column to the given data. | |
4488 * Parameters: | |
4489 * handle: Handle to the container window (widget). | |
4490 * pointer: Pointer to the allocated memory in dw_container_alloc(). | |
4491 * column: Zero based column of data being set. | |
4492 * row: Zero based row of data being set. | |
4493 * data: Pointer to the data to be added. | |
4494 */ | |
4495 void dw_container_set_item(HWND handle, void *pointer, int column, int row, void *data) | |
4496 { | |
4497 ContainerInfo *cinfo = (ContainerInfo *)GetWindowLong(handle, GWL_USERDATA); | |
4498 ULONG *flags; | |
4499 LV_ITEM lvi; | |
4500 char textbuffer[100], *destptr = textbuffer; | |
4501 | |
4502 if(!cinfo || !cinfo->flags || !data) | |
4503 return; | |
4504 | |
4505 flags = cinfo->flags; | |
4506 | |
4507 lvi.mask = LVIF_DI_SETITEM | LVIF_TEXT; | |
4508 lvi.iItem = row; | |
4509 lvi.iSubItem = column; | |
4510 | |
4511 if(flags[column] & DW_CFA_BITMAPORICON) | |
4512 { | |
4513 HICON hicon = *((HICON *)data); | |
4514 | |
4515 lvi.mask = LVIF_DI_SETITEM | LVIF_IMAGE; | |
4516 lvi.pszText = NULL; | |
4517 lvi.cchTextMax = 0; | |
4518 lvi.iImage = _lookup_icon(handle, hicon); | |
4519 } | |
4520 else if(flags[column] & DW_CFA_STRING) | |
4521 { | |
4522 char *tmp = *((char **)data); | |
4523 | |
4524 lvi.pszText = tmp; | |
4525 lvi.cchTextMax = strlen(tmp); | |
4526 destptr = tmp; | |
4527 } | |
4528 else if(flags[column] & DW_CFA_ULONG) | |
4529 { | |
4530 ULONG tmp = *((ULONG *)data); | |
4531 | |
4532 sprintf(textbuffer, "%lu", tmp); | |
4533 | |
4534 lvi.pszText = textbuffer; | |
4535 lvi.cchTextMax = strlen(textbuffer); | |
4536 } | |
4537 else if(flags[column] & DW_CFA_DATE) | |
4538 { | |
4539 CDATE fdate = *((CDATE *)data); | |
4540 | |
4541 sprintf(textbuffer, "%s %d, %d", monthlist[fdate.month], fdate.day, fdate.year); | |
4542 lvi.pszText = textbuffer; | |
4543 lvi.cchTextMax = strlen(textbuffer); | |
4544 } | |
4545 else if(flags[column] & DW_CFA_TIME) | |
4546 { | |
4547 CTIME ftime = *((CTIME *)data); | |
4548 | |
4549 if(ftime.hours > 12) | |
4550 sprintf(textbuffer, "%d:%s%dpm", ftime.hours - 12, (ftime.minutes < 10) ? "0" : "", ftime.minutes); | |
4551 else | |
4552 sprintf(textbuffer, "%d:%s%dam", ftime.hours ? ftime.hours : 12, (ftime.minutes < 10) ? "0" : "", ftime.minutes); | |
4553 lvi.pszText = textbuffer; | |
4554 lvi.cchTextMax = strlen(textbuffer); | |
4555 } | |
4556 | |
7
005fa766e8c2
Updates to latest build.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
3
diff
changeset
|
4557 ListView_SetItemText(handle, row, column, destptr); |
3 | 4558 } |
4559 | |
4560 /* | |
4561 * Sets the title of a row in the container. | |
4562 * Parameters: | |
4563 * pointer: Pointer to the allocated memory in dw_container_alloc(). | |
4564 * row: Zero based row of data being set. | |
4565 * title: String title of the item. | |
4566 */ | |
4567 void dw_container_set_row_title(void *pointer, int row, char *title) | |
4568 { | |
4569 LV_ITEM lvi; | |
4570 HWND container = (HWND)pointer; | |
4571 | |
4572 lvi.iItem = row; | |
4573 lvi.iSubItem = 0; | |
4574 lvi.mask = LVIF_PARAM; | |
4575 lvi.lParam = (LPARAM)title; | |
4576 | |
4577 if(!ListView_SetItem(container, &lvi) && lvi.lParam) | |
4578 lvi.lParam = 0; | |
4579 | |
4580 } | |
4581 | |
4582 /* | |
4583 * Sets the title of a row in the container. | |
4584 * Parameters: | |
4585 * handle: Handle to the container window (widget). | |
4586 * pointer: Pointer to the allocated memory in dw_container_alloc(). | |
4587 * rowcount: The number of rows to be inserted. | |
4588 */ | |
4589 void dw_container_insert(HWND handle, void *pointer, int rowcount) | |
4590 { | |
4591 /* This isn't a separate step in windows. */ | |
4592 } | |
4593 | |
4594 /* | |
4595 * Removes all rows from a container. | |
4596 * Parameters: | |
4597 * handle: Handle to the window (widget) to be cleared. | |
4598 */ | |
4599 void dw_container_clear(HWND handle) | |
4600 { | |
4601 /* May need to delete manually so I can | |
4602 * remove the memory allocated for the | |
4603 * lParam field. | |
4604 */ | |
4605 ListView_DeleteAllItems(handle); | |
4606 } | |
4607 | |
4608 /* | |
4609 * Removes all rows from a container. | |
4610 * Parameters: | |
4611 * handle: Handle to the window (widget) to be cleared. | |
4612 */ | |
4613 void dw_container_set_view(HWND handle, unsigned long flags, int iconwidth, int iconheight) | |
4614 { | |
4615 } | |
4616 | |
4617 /* | |
4618 * Starts a new query of a container. | |
4619 * Parameters: | |
4620 * handle: Handle to the window (widget) to be queried. | |
4621 * flags: If this parameter is DW_CRA_SELECTED it will only | |
4622 * return items that are currently selected. Otherwise | |
4623 * it will return all records in the container. | |
4624 */ | |
4625 char *dw_container_query_start(HWND handle, unsigned long flags) | |
4626 { | |
4627 LV_ITEM lvi; | |
4628 | |
4629 if(flags) | |
4630 _index = ListView_GetNextItem(handle, -1, LVNI_SELECTED); | |
4631 else | |
4632 _index = ListView_GetNextItem(handle, -1, LVNI_ALL); | |
4633 | |
4634 | |
4635 lvi.iItem = _index; | |
4636 lvi.mask = LVIF_PARAM; | |
4637 | |
4638 ListView_GetItem(handle, &lvi); | |
4639 | |
4640 return (char *)lvi.lParam; | |
4641 } | |
4642 | |
4643 /* | |
4644 * Continues an existing query of a container. | |
4645 * Parameters: | |
4646 * handle: Handle to the window (widget) to be queried. | |
4647 * flags: If this parameter is DW_CRA_SELECTED it will only | |
4648 * return items that are currently selected. Otherwise | |
4649 * it will return all records in the container. | |
4650 */ | |
4651 char *dw_container_query_next(HWND handle, unsigned long flags) | |
4652 { | |
4653 LV_ITEM lvi; | |
4654 | |
4655 if(flags) | |
4656 _index = ListView_GetNextItem(handle, _index, LVNI_SELECTED); | |
4657 else | |
4658 _index = ListView_GetNextItem(handle, _index, LVNI_ALL); | |
4659 | |
4660 if(_index == -1) | |
4661 return NULL; | |
4662 | |
4663 lvi.iItem = _index; | |
4664 lvi.mask = LVIF_PARAM; | |
4665 | |
4666 ListView_GetItem(handle, &lvi); | |
4667 | |
4668 return (char *)lvi.lParam; | |
4669 } | |
4670 | |
4671 /* | |
4672 * Creates a rendering context widget (window) to be packed. | |
4673 * Parameters: | |
4674 * id: An id to be used with dw_window_from_id. | |
4675 * Returns: | |
4676 * A handle to the widget or NULL on failure. | |
4677 */ | |
4678 HWND dw_render_new(unsigned long id) | |
4679 { | |
4680 HWND tmp = CreateWindow(ObjectClassName, | |
4681 "", | |
4682 WS_CHILD | WS_CLIPCHILDREN, | |
4683 0,0,2000,1000, | |
4684 DW_HWND_OBJECT, | |
4685 NULL, | |
4686 NULL, | |
4687 NULL); | |
4688 SubclassWindow(tmp, _rendwndproc); | |
4689 return tmp; | |
4690 } | |
4691 | |
4692 /* Sets the current foreground drawing color. | |
4693 * Parameters: | |
4694 * red: red value. | |
4695 * green: green value. | |
4696 * blue: blue value. | |
4697 */ | |
4698 void dw_color_foreground_set(unsigned long value) | |
4699 { | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4700 int threadid = dw_thread_id(); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4701 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4702 if(threadid < 0 || threadid >= THREAD_LIMIT) |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4703 threadid = 0; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4704 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4705 DeleteObject(_hPen[threadid]); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4706 DeleteObject(_hBrush[threadid]); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4707 _foreground[threadid] = RGB(DW_RED_VALUE(value), DW_GREEN_VALUE(value), DW_BLUE_VALUE(value)); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4708 _hPen[threadid] = CreatePen(PS_SOLID, 1, _foreground[threadid]); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4709 _hBrush[threadid] = CreateSolidBrush(_foreground[threadid]); |
3 | 4710 } |
4711 | |
4712 /* Sets the current background drawing color. | |
4713 * Parameters: | |
4714 * red: red value. | |
4715 * green: green value. | |
4716 * blue: blue value. | |
4717 */ | |
4718 void dw_color_background_set(unsigned long value) | |
4719 { | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4720 int threadid = dw_thread_id(); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4721 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4722 if(threadid < 0 || threadid >= THREAD_LIMIT) |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4723 threadid = 0; |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4724 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4725 _background[threadid] = RGB(DW_RED_VALUE(value), DW_GREEN_VALUE(value), DW_BLUE_VALUE(value)); |
3 | 4726 } |
4727 | |
4728 /* Draw a point on a window (preferably a render window). | |
4729 * Parameters: | |
4730 * handle: Handle to the window. | |
4731 * pixmap: Handle to the pixmap. (choose only one of these) | |
4732 * x: X coordinate. | |
4733 * y: Y coordinate. | |
4734 */ | |
4735 void dw_draw_point(HWND handle, HPIXMAP pixmap, int x, int y) | |
4736 { | |
4737 HDC hdcPaint; | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4738 int threadid = dw_thread_id(); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4739 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4740 if(threadid < 0 || threadid >= THREAD_LIMIT) |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4741 threadid = 0; |
3 | 4742 |
4743 if(handle) | |
4744 hdcPaint = GetDC(handle); | |
4745 else if(pixmap) | |
4746 hdcPaint = pixmap->hdc; | |
4747 else | |
4748 return; | |
4749 | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4750 SetPixel(hdcPaint, x, y, _foreground[threadid]); |
3 | 4751 if(!pixmap) |
4752 ReleaseDC(handle, hdcPaint); | |
4753 } | |
4754 | |
4755 /* Draw a line on a window (preferably a render window). | |
4756 * Parameters: | |
4757 * handle: Handle to the window. | |
4758 * pixmap: Handle to the pixmap. (choose only one of these) | |
4759 * x1: First X coordinate. | |
4760 * y1: First Y coordinate. | |
4761 * x2: Second X coordinate. | |
4762 * y2: Second Y coordinate. | |
4763 */ | |
4764 void dw_draw_line(HWND handle, HPIXMAP pixmap, int x1, int y1, int x2, int y2) | |
4765 { | |
4766 HDC hdcPaint; | |
4767 HPEN oldPen; | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4768 int threadid = dw_thread_id(); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4769 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4770 if(threadid < 0 || threadid >= THREAD_LIMIT) |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4771 threadid = 0; |
3 | 4772 |
4773 if(handle) | |
4774 hdcPaint = GetDC(handle); | |
4775 else if(pixmap) | |
4776 hdcPaint = pixmap->hdc; | |
4777 else | |
4778 return; | |
4779 | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4780 oldPen = SelectObject(hdcPaint, _hPen[threadid]); |
3 | 4781 MoveToEx(hdcPaint, x1, y1, NULL); |
4782 LineTo(hdcPaint, x2, y2); | |
4783 SelectObject(hdcPaint, oldPen); | |
4784 /* For some reason Win98 (at least) fails | |
4785 * to draw the last pixel. So I do it myself. | |
4786 */ | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4787 SetPixel(hdcPaint, x2, y2, _foreground[threadid]); |
3 | 4788 if(!pixmap) |
4789 ReleaseDC(handle, hdcPaint); | |
4790 } | |
4791 | |
4792 /* Draw a rectangle on a window (preferably a render window). | |
4793 * Parameters: | |
4794 * handle: Handle to the window. | |
4795 * pixmap: Handle to the pixmap. (choose only one of these) | |
4796 * x: X coordinate. | |
4797 * y: Y coordinate. | |
4798 * width: Width of rectangle. | |
4799 * height: Height of rectangle. | |
4800 */ | |
4801 void dw_draw_rect(HWND handle, HPIXMAP pixmap, int fill, int x, int y, int width, int height) | |
4802 { | |
4803 HDC hdcPaint; | |
4804 HPEN oldPen; | |
4805 HBRUSH oldBrush; | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4806 int threadid = dw_thread_id(); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4807 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4808 if(threadid < 0 || threadid >= THREAD_LIMIT) |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4809 threadid = 0; |
3 | 4810 |
4811 if(handle) | |
4812 hdcPaint = GetDC(handle); | |
4813 else if(pixmap) | |
4814 hdcPaint = pixmap->hdc; | |
4815 else | |
4816 return; | |
4817 | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4818 oldPen = SelectObject(hdcPaint, _hPen[threadid]); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4819 oldBrush = SelectObject(hdcPaint, _hBrush[threadid]); |
3 | 4820 Rectangle(hdcPaint, x, y, x + width, y + height); |
4821 SelectObject(hdcPaint, oldPen); | |
4822 SelectObject(hdcPaint, oldBrush); | |
4823 if(!pixmap) | |
4824 ReleaseDC(handle, hdcPaint); | |
4825 } | |
4826 | |
4827 /* Draw text on a window (preferably a render window). | |
4828 * Parameters: | |
4829 * handle: Handle to the window. | |
4830 * pixmap: Handle to the pixmap. (choose only one of these) | |
4831 * x: X coordinate. | |
4832 * y: Y coordinate. | |
4833 * text: Text to be displayed. | |
4834 */ | |
4835 void dw_draw_text(HWND handle, HPIXMAP pixmap, int x, int y, char *text) | |
4836 { | |
4837 HDC hdc; | |
4838 int size = 9, z, mustdelete = 0; | |
4839 HFONT hFont, oldFont; | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4840 int threadid = dw_thread_id(); |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4841 |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4842 if(threadid < 0 || threadid >= THREAD_LIMIT) |
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4843 threadid = 0; |
3 | 4844 |
4845 if(handle) | |
4846 { | |
4847 hdc = GetDC(handle); | |
4848 hFont = (HFONT)SendMessage(handle, WM_GETFONT, 0, 0); | |
4849 } | |
4850 else if(pixmap) | |
4851 { | |
4852 hdc = pixmap->hdc; | |
4853 hFont = (HFONT)SendMessage(pixmap->handle, WM_GETFONT, 0, 0); | |
4854 } | |
4855 else | |
4856 return; | |
4857 | |
4858 if(!hFont) | |
4859 { | |
4860 ColorInfo *cinfo; | |
4861 | |
4862 if(handle) | |
4863 cinfo = (ColorInfo *)GetWindowLong(handle, GWL_USERDATA); | |
4864 else | |
4865 cinfo = (ColorInfo *)GetWindowLong(pixmap->handle, GWL_USERDATA); | |
4866 | |
4867 if(cinfo) | |
4868 { | |
4869 hFont = _aquire_font(cinfo->fontname); | |
4870 mustdelete = 1; | |
4871 } | |
4872 } | |
4873 oldFont = SelectObject(hdc, hFont); | |
12
26e2130135b9
Many Win32 and GTK fixes.
bsmith@81767d24-ef19-dc11-ae90-00e081727c95
parents:
7
diff
changeset
|
4874 SetTextColor(hdc, _foreground[threadid]); |
3 | 4875 SetBkMode(hdc, TRANSPARENT); |
4876 TextOut(hdc, x, y, text, strlen(text)); | |
4877 SelectObject(hdc, oldFont); | |
4878 if(mustdelete) | |
4879 DeleteObject(hFont); | |
4880 if(!pixmap) | |
4881 ReleaseDC(handle, hdc); | |
4882 } | |
4883 | |
4884 /* Call this after drawing to the screen to make sure | |
4885 * anything you have drawn is visible. | |
4886 */ | |
4887 void dw_flush(void) | |
4888 { | |
4889 } | |
4890 | |
4891 /* | |
4892 * Creates a pixmap with given parameters. | |
4893 * Parameters: | |
4894 * handle: Window handle the pixmap is associated with. | |
4895 * width: Width of the pixmap in pixels. | |
4896 * height: Height of the pixmap in pixels. | |
4897 * depth: Color depth of the pixmap. | |
4898 * Returns: | |
4899 * A handle to a pixmap or NULL on failure. | |
4900 */ | |
4901 HPIXMAP dw_pixmap_new(HWND handle, unsigned long width, unsigned long height, int depth) | |
4902 { | |
4903 HPIXMAP pixmap; | |
4904 BITMAP bm; | |
4905 HDC hdc; | |
4906 | |
4907 if (!(pixmap = calloc(1,sizeof(struct _hpixmap)))) | |
4908 return NULL; | |
4909 | |
4910 hdc = GetDC(handle); | |
4911 | |
4912 pixmap->width = width; pixmap->height = height; | |
4913 | |
4914 pixmap->handle = handle; | |
4915 pixmap->hbm = CreateCompatibleBitmap(hdc, width, height); | |
4916 pixmap->hdc = CreateCompatibleDC(hdc); | |
4917 | |
4918 SelectObject(pixmap->hdc, pixmap->hbm); | |
4919 | |
4920 ReleaseDC(handle, hdc); | |
4921 | |
4922 return pixmap; | |
4923 } | |
4924 | |
4925 /* | |
4926 * Creates a pixmap from internal resource graphic specified by id. | |
4927 * Parameters: | |
4928 * handle: Window handle the pixmap is associated with. | |
4929 * id: Resource ID associated with requested pixmap. | |
4930 * Returns: | |
4931 * A handle to a pixmap or NULL on failure. | |
4932 */ | |
4933 HPIXMAP dw_pixmap_grab(HWND handle, ULONG id) | |
4934 { | |
4935 HPIXMAP pixmap; | |
4936 BITMAP bm; | |
4937 HDC hdc; | |
4938 | |
4939 if (!(pixmap = calloc(1,sizeof(struct _hpixmap)))) | |
4940 return NULL; | |
4941 | |
4942 hdc = GetDC(handle); | |
4943 | |
4944 | |
4945 pixmap->hbm = LoadBitmap(DWInstance, MAKEINTRESOURCE(id)); | |
4946 pixmap->hdc = CreateCompatibleDC(hdc); | |
4947 | |
4948 GetObject(pixmap->hbm, sizeof(BITMAP), (void *)&bm); | |
4949 | |
4950 pixmap->width = bm.bmWidth; pixmap->height = bm.bmHeight; | |
4951 | |
4952 SelectObject(pixmap->hdc, pixmap->hbm); | |
4953 | |
4954 ReleaseDC(handle, hdc); | |
4955 | |
4956 return pixmap; | |
4957 } | |
4958 | |
4959 /* | |
4960 * Destroys an allocated pixmap. | |
4961 * Parameters: | |
4962 * pixmap: Handle to a pixmap returned by | |
4963 * dw_pixmap_new.. | |
4964 */ | |
4965 void dw_pixmap_destroy(HPIXMAP pixmap) | |
4966 { | |
4967 if(pixmap) | |
4968 { | |
4969 DeleteDC(pixmap->hdc); | |
4970 DeleteObject(pixmap->hbm); | |
4971 free(pixmap); | |
4972 } | |
4973 } | |
4974 | |
4975 /* | |
4976 * Copies from one item to another. | |
4977 * Parameters: | |
4978 * dest: Destination window handle. | |
4979 * destp: Destination pixmap. (choose only one). | |
4980 * xdest: X coordinate of destination. | |
4981 * ydest: Y coordinate of destination. | |
4982 * width: Width of area to copy. | |
4983 * height: Height of area to copy. | |
4984 * src: Source window handle. | |
4985 * srcp: Source pixmap. (choose only one). | |
4986 * xsrc: X coordinate of source. | |
4987 * ysrc: Y coordinate of source. | |
4988 */ | |
4989 void dw_pixmap_bitblt(HWND dest, HPIXMAP destp, int xdest, int ydest, int width, int height, HWND src, HPIXMAP srcp, int xsrc, int ysrc) | |
4990 { | |
4991 HDC hdcdest; | |
4992 HDC hdcsrc; | |
4993 | |
4994 if(dest) | |
4995 hdcdest = GetDC(dest); | |
4996 else if(destp) | |
4997 hdcdest = destp->hdc; | |
4998 else | |
4999 return; | |
5000 | |
5001 if(src) | |
5002 hdcsrc = GetDC(src); | |
5003 else if(srcp) | |
5004 hdcsrc = srcp->hdc; | |
5005 else | |
5006 return; | |
5007 | |
5008 BitBlt(hdcdest, xdest, ydest, width, height, hdcsrc, xsrc, ysrc, SRCCOPY); | |
5009 | |
5010 if(!destp) | |
5011 ReleaseDC(dest, hdcdest); | |
5012 if(!srcp) | |
5013 ReleaseDC(src, hdcsrc); | |
5014 } | |
5015 | |
5016 /* | |
5017 * Emits a beep. | |
5018 * Parameters: | |
5019 * freq: Frequency. | |
5020 * dur: Duration. | |
5021 */ | |
5022 void dw_beep(int freq, int dur) | |
5023 { | |
5024 Beep(freq, dur); | |
5025 } | |
5026 | |
5027 /* | |
5028 * Returns the handle to an unnamed mutex semaphore. | |
5029 */ | |
5030 HMTX dw_mutex_new(void) | |
5031 { | |
5032 return (HMTX)CreateMutex(NULL, FALSE, NULL); | |
5033 } | |
5034 | |
5035 /* | |
5036 * Closes a semaphore created by dw_mutex_new(). | |
5037 * Parameters: | |
5038 * mutex: The handle to the mutex returned by dw_mutex_new(). | |
5039 */ | |
5040 void dw_mutex_close(HMTX mutex) | |
5041 { | |
5042 CloseHandle((HANDLE)mutex); | |
5043 } | |
5044 | |
5045 /* | |
5046 * Tries to gain access to the semaphore, if it can't it blocks. | |
5047 * Parameters: | |
5048 * mutex: The handle to the mutex returned by dw_mutex_new(). | |
5049 */ | |
5050 void dw_mutex_lock(HMTX mutex) | |
5051 { | |
5052 WaitForSingleObject((HANDLE)mutex, INFINITE); | |
5053 } | |
5054 | |
5055 /* | |
5056 * Reliquishes the access to the semaphore. | |
5057 * Parameters: | |
5058 * mutex: The handle to the mutex returned by dw_mutex_new(). | |
5059 */ | |
5060 void dw_mutex_unlock(HMTX mutex) | |
5061 { | |
5062 ReleaseMutex((HANDLE)mutex); | |
5063 } | |
5064 | |
5065 /* | |
5066 * Returns the handle to an unnamed event semaphore. | |
5067 */ | |
5068 HEV dw_event_new(void) | |
5069 { | |
5070 return CreateEvent(NULL, TRUE, FALSE, NULL); | |
5071 } | |
5072 | |
5073 /* | |
5074 * Resets a semaphore created by dw_event_new(). | |
5075 * Parameters: | |
5076 * eve: The handle to the event returned by dw_event_new(). | |
5077 */ | |
5078 int dw_event_reset(HEV eve) | |
5079 { | |
5080 return ResetEvent(eve); | |
5081 } | |
5082 | |
5083 /* | |
5084 * Posts a semaphore created by dw_event_new(). Causing all threads | |
5085 * waiting on this event in dw_event_wait to continue. | |
5086 * Parameters: | |
5087 * eve: The handle to the event returned by dw_event_new(). | |
5088 */ | |
5089 int dw_event_post(HEV eve) | |
5090 { | |
5091 return SetEvent(eve); | |
5092 } | |
5093 | |
5094 /* | |
5095 * Waits on a semaphore created by dw_event_new(), until the | |
5096 * event gets posted or until the timeout expires. | |
5097 * Parameters: | |
5098 * eve: The handle to the event returned by dw_event_new(). | |
5099 */ | |
5100 int dw_event_wait(HEV eve, unsigned long timeout) | |
5101 { | |
5102 int rc; | |
5103 | |
5104 rc = WaitForSingleObject(eve, timeout); | |
5105 if(rc == WAIT_OBJECT_0) | |
5106 return 1; | |
5107 if(rc == WAIT_ABANDONED) | |
5108 return -1; | |
5109 return 0; | |
5110 } | |
5111 | |
5112 /* | |
5113 * Closes a semaphore created by dw_event_new(). | |
5114 * Parameters: | |
5115 * eve: The handle to the event returned by dw_event_new(). | |
5116 */ | |
5117 int dw_event_close(HEV *eve) | |
5118 { | |
5119 if(eve) | |
5120 return CloseHandle(*eve); | |
5121 return FALSE; | |
5122 } | |
5123 | |
5124 /* | |
5125 * Creates a new thread with a starting point of func. | |
5126 * Parameters: | |
5127 * func: Function which will be run in the new thread. | |
5128 * data: Parameter(s) passed to the function. | |
5129 * stack: Stack size of new thread (OS/2 and Windows only). | |
5130 */ | |
5131 DWTID dw_thread_new(void *func, void *data, int stack) | |
5132 { | |
5133 #if defined(__CYGWIN__) | |
5134 return 0; | |
5135 #else | |
5136 return (DWTID)_beginthread((void(*)(void *))func, stack, data); | |
5137 #endif | |
5138 } | |
5139 | |
5140 /* | |
5141 * Ends execution of current thread immediately. | |
5142 */ | |
5143 void dw_thread_end(void) | |
5144 { | |
5145 #if !defined(__CYGWIN__) | |
5146 _endthread(); | |
5147 #endif | |
5148 } | |
5149 | |
5150 /* | |
5151 * Returns the current thread's ID. | |
5152 */ | |
5153 DWTID dw_thread_id(void) | |
5154 { | |
5155 #if defined(__CYGWIN__) | |
5156 return 0; | |
5157 #else | |
5158 return (DWTID)GetCurrentThreadId(); | |
5159 #endif | |
5160 } | |
5161 | |
5162 /* | |
5163 * Cleanly terminates a DW session, should be signal handler safe. | |
5164 * Parameters: | |
5165 * exitcode: Exit code reported to the operating system. | |
5166 */ | |
5167 void dw_exit(int exitcode) | |
5168 { | |
5169 exit(exitcode); | |
5170 } | |
5171 | |
5172 /* | |
5173 * Pack a splitbar (sizer) into the specified box from the start. | |
5174 * Parameters: | |
5175 * box: Window handle of the box to be packed into. | |
5176 */ | |
5177 void dw_box_pack_splitbar_start(HWND box) | |
5178 { | |
5179 Box *thisbox = (Box *)GetWindowLong(box, GWL_USERDATA); | |
5180 | |
5181 if(thisbox) | |
5182 { | |
5183 HWND tmp = CreateWindow(SplitbarClassName, | |
5184 "", | |
5185 WS_CHILD | WS_CLIPCHILDREN, | |
5186 0,0,2000,1000, | |
5187 DW_HWND_OBJECT, | |
5188 NULL, | |
5189 NULL, | |
5190 NULL); | |
5191 if(thisbox->type == BOXVERT) | |
5192 dw_box_pack_start(box, tmp, 1, SPLITBAR_WIDTH, TRUE, FALSE, 0); | |
5193 else | |
5194 dw_box_pack_start(box, tmp, SPLITBAR_WIDTH, 1, FALSE, TRUE, 0); | |
5195 | |
5196 } | |
5197 } | |
5198 | |
5199 /* | |
5200 * Pack a splitbar (sizer) into the specified box from the end. | |
5201 * Parameters: | |
5202 * box: Window handle of the box to be packed into. | |
5203 */ | |
5204 void dw_box_pack_splitbar_end(HWND box) | |
5205 { | |
5206 Box *thisbox = (Box *)GetWindowLong(box, GWL_USERDATA); | |
5207 | |
5208 if(thisbox) | |
5209 { | |
5210 HWND tmp = CreateWindow(SplitbarClassName, | |
5211 "", | |
5212 WS_CHILD | WS_CLIPCHILDREN, | |
5213 0,0,2000,1000, | |
5214 DW_HWND_OBJECT, | |
5215 NULL, | |
5216 NULL, | |
5217 NULL); | |
5218 if(thisbox->type == BOXVERT) | |
5219 dw_box_pack_end(box, tmp, 1, SPLITBAR_WIDTH, TRUE, FALSE, 0); | |
5220 else | |
5221 dw_box_pack_end(box, tmp, SPLITBAR_WIDTH, 1, FALSE, TRUE, 0); | |
5222 | |
5223 } | |
5224 } | |
5225 | |
5226 /* | |
5227 * Pack windows (widgets) into a box from the end (or bottom). | |
5228 * Parameters: | |
5229 * box: Window handle of the box to be packed into. | |
5230 * item: Window handle of the item to be back. | |
5231 * width: Width in pixels of the item or -1 to be self determined. | |
5232 * height: Height in pixels of the item or -1 to be self determined. | |
5233 * hsize: TRUE if the window (widget) should expand horizontally to fill space given. | |
5234 * vsize: TRUE if the window (widget) should expand vertically to fill space given. | |
5235 * pad: Number of pixels of padding around the item. | |
5236 */ | |
5237 void dw_box_pack_end(HWND box, HWND item, int width, int height, int hsize, int vsize, int pad) | |
5238 { | |
5239 Box *thisbox; | |
5240 | |
5241 thisbox = (Box *)GetWindowLong(box, GWL_USERDATA); | |
5242 if(thisbox) | |
5243 { | |
5244 int z; | |
5245 Item *tmpitem, *thisitem = thisbox->items; | |
5246 char tmpbuf[100]; | |
5247 | |
5248 tmpitem = malloc(sizeof(Item)*(thisbox->count+1)); | |
5249 | |
5250 for(z=0;z<thisbox->count;z++) | |
5251 { | |
5252 tmpitem[z+1] = thisitem[z]; | |
5253 } | |
5254 | |
5255 GetClassName(item, tmpbuf, 99); | |
5256 | |
5257 if(strnicmp(tmpbuf, FRAMECLASSNAME, 2)==0) | |
5258 tmpitem[0].type = TYPEBOX; | |
5259 else | |
5260 tmpitem[0].type = TYPEITEM; | |
5261 | |
5262 tmpitem[0].hwnd = item; | |
5263 tmpitem[0].origwidth = tmpitem[0].width = width; | |
5264 tmpitem[0].origheight = tmpitem[0].height = height; | |
5265 tmpitem[0].pad = pad; | |
5266 if(hsize) | |
5267 tmpitem[0].hsize = SIZEEXPAND; | |
5268 else | |
5269 tmpitem[0].hsize = SIZESTATIC; | |
5270 | |
5271 if(vsize) | |
5272 tmpitem[0].vsize = SIZEEXPAND; | |
5273 else | |
5274 tmpitem[0].vsize = SIZESTATIC; | |
5275 | |
5276 thisbox->items = tmpitem; | |
5277 | |
5278 if(thisbox->count) | |
5279 free(thisitem); | |
5280 | |
5281 thisbox->count++; | |
5282 | |
5283 SetParent(item, box); | |
5284 ShowWindow(item, SW_SHOW); | |
5285 if(strncmp(tmpbuf, UPDOWN_CLASS, strlen(UPDOWN_CLASS))==0) | |
5286 { | |
5287 ColorInfo *cinfo = (ColorInfo *)GetWindowLong(item, GWL_USERDATA); | |
5288 | |
5289 if(cinfo) | |
5290 { | |
5291 SetParent(cinfo->buddy, box); | |
5292 ShowWindow(cinfo->buddy, SW_SHOW); | |
5293 SendMessage(item, UDM_SETBUDDY, (WPARAM)cinfo->buddy, 0); | |
5294 } | |
5295 } | |
5296 } | |
5297 } | |
5298 | |
5299 /* | |
5300 * Returns some information about the current operating environment. | |
5301 * Parameters: | |
5302 * env: Pointer to a DWEnv struct. | |
5303 */ | |
5304 void dw_environment_query(DWEnv *env) | |
5305 { | |
5306 if(!env) | |
5307 return; | |
5308 | |
5309 /* Get the Windows version. */ | |
5310 | |
5311 env->MajorVersion = (DWORD)(LOBYTE(LOWORD(dwVersion))); | |
5312 env->MinorVersion = (DWORD)(HIBYTE(LOWORD(dwVersion))); | |
5313 | |
5314 /* Get the build number for Windows NT/Windows 2000. */ | |
5315 | |
5316 env->MinorBuild = 0; | |
5317 | |
5318 if (dwVersion < 0x80000000) | |
5319 { | |
5320 if(env->MajorVersion == 5) | |
5321 strcpy(env->osName, "Windows 2000"); | |
5322 else | |
5323 strcpy(env->osName, "Windows NT"); | |
5324 | |
5325 env->MajorBuild = (DWORD)(HIWORD(dwVersion)); | |
5326 } | |
5327 else | |
5328 { | |
5329 strcpy(env->osName, "Windows 95/98/ME"); | |
5330 env->MajorBuild = 0; | |
5331 } | |
5332 } | |
5333 | |
5334 /* | |
5335 * Opens a file dialog and queries user selection. | |
5336 * Parameters: | |
5337 * title: Title bar text for dialog. | |
5338 * defpath: The default path of the open dialog. | |
5339 * ext: Default file extention. | |
5340 * flags: DW_FILE_OPEN or DW_FILE_SAVE. | |
5341 * Returns: | |
5342 * NULL on error. A malloced buffer containing | |
5343 * the file path on success. | |
5344 * | |
5345 */ | |
5346 char *dw_file_browse(char *title, char *defpath, char *ext, int flags) | |
5347 { | |
5348 OPENFILENAME of; | |
5349 char filenamebuf[1001] = ""; | |
5350 int rc; | |
5351 | |
5352 if(ext) | |
5353 { | |
5354 strcpy(filenamebuf, "*."); | |
5355 strcat(filenamebuf, ext); | |
5356 } | |
5357 | |
5358 memset(&of, 0, sizeof(OPENFILENAME)); | |
5359 | |
5360 of.lStructSize = sizeof(OPENFILENAME); | |
5361 of.hwndOwner = HWND_DESKTOP; | |
5362 of.hInstance = DWInstance; | |
5363 of.lpstrInitialDir = defpath; | |
5364 of.lpstrTitle = title; | |
5365 of.lpstrFile = filenamebuf; | |
5366 of.nMaxFile = 1000; | |
5367 of.lpstrDefExt = ext; | |
5368 of.Flags = 0; | |
5369 | |
5370 if(flags & DW_FILE_SAVE) | |
5371 rc = GetSaveFileName(&of); | |
5372 else | |
5373 rc = GetOpenFileName(&of); | |
5374 | |
5375 if(rc) | |
5376 return strdup(of.lpstrFile); | |
5377 | |
5378 return NULL; | |
5379 } | |
5380 | |
5381 /* | |
5382 * Execute and external program in a seperate session. | |
5383 * Parameters: | |
5384 * program: Program name with optional path. | |
5385 * type: Either DW_EXEC_CON or DW_EXEC_GUI. | |
5386 * params: An array of pointers to string arguements. | |
5387 * Returns: | |
5388 * -1 on error. | |
5389 */ | |
5390 int dw_exec(char *program, int type, char **params) | |
5391 { | |
5392 char **newparams; | |
5393 int retcode, count = 0, z; | |
5394 | |
5395 while(params[count]) | |
5396 { | |
5397 count++; | |
5398 } | |
5399 | |
5400 newparams = (char **)malloc(sizeof(char *) * (count+1)); | |
5401 | |
5402 for(z=0;z<count;z++) | |
5403 { | |
5404 newparams[z] = malloc(strlen(params[z])+3); | |
5405 strcpy(newparams[z], "\""); | |
5406 strcat(newparams[z], params[z]); | |
5407 strcat(newparams[z], "\""); | |
5408 } | |
5409 newparams[count] = NULL; | |
5410 | |
5411 retcode = spawnvp(P_NOWAIT, program, newparams); | |
5412 | |
5413 for(z=0;z<count;z++) | |
5414 { | |
5415 free(newparams[z]); | |
5416 } | |
5417 free(newparams); | |
5418 | |
5419 return retcode; | |
5420 } | |
5421 | |
5422 /* | |
5423 * Loads a web browser pointed at the given URL. | |
5424 * Parameters: | |
5425 * url: Uniform resource locator. | |
5426 */ | |
5427 int dw_browse(char *url) | |
5428 { | |
5429 char *browseurl = url; | |
5430 int retcode; | |
5431 | |
5432 if(strlen(url) > 7 && strncmp(url, "file://", 7) == 0) | |
5433 { | |
5434 int len, z; | |
5435 | |
5436 browseurl = &url[7]; | |
5437 len = strlen(browseurl); | |
5438 | |
5439 for(z=0;z<len;z++) | |
5440 { | |
5441 if(browseurl[z] == '|') | |
5442 browseurl[z] = ':'; | |
5443 if(browseurl[z] == '/') | |
5444 browseurl[z] = '\\'; | |
5445 } | |
5446 } | |
5447 | |
5448 retcode = (int)ShellExecute(NULL, "open", browseurl, NULL, NULL, SW_SHOWNORMAL); | |
5449 if(retcode<33 && retcode != 2) | |
5450 return -1; | |
5451 return 1; | |
5452 } | |
5453 | |
5454 /* | |
5455 * Returns a pointer to a static buffer which containes the | |
5456 * current user directory. Or the root directory (C:\ on | |
5457 * OS/2 and Windows). | |
5458 */ | |
5459 char *dw_user_dir(void) | |
5460 { | |
5461 static char _user_dir[1024] = ""; | |
5462 | |
5463 if(!_user_dir[0]) | |
5464 { | |
5465 /* Figure out how to do this the "Windows way" */ | |
5466 char *home = getenv("HOME"); | |
5467 | |
5468 if(home) | |
5469 strcpy(_user_dir, home); | |
5470 else | |
5471 strcpy(_user_dir, "C:\\"); | |
5472 } | |
5473 return _user_dir; | |
5474 } | |
5475 | |
5476 /* | |
5477 * Call a function from the window (widget)'s context. | |
5478 * Parameters: | |
5479 * handle: Window handle of the widget. | |
5480 * function: Function pointer to be called. | |
5481 * data: Pointer to the data to be passed to the function. | |
5482 */ | |
5483 void dw_window_function(HWND handle, void *function, void *data) | |
5484 { | |
5485 SendMessage(handle, WM_USER, (WPARAM)function, (LPARAM)data); | |
5486 } | |
5487 | |
5488 #ifndef NO_SIGNALS | |
5489 /* | |
5490 * Add a callback to a window event. | |
5491 * Parameters: | |
5492 * window: Window handle of signal to be called back. | |
5493 * signame: A string pointer identifying which signal to be hooked. | |
5494 * sigfunc: The pointer to the function to be used as the callback. | |
5495 * data: User data to be passed to the handler function. | |
5496 */ | |
5497 void dw_signal_connect(HWND window, char *signame, void *sigfunc, void *data) | |
5498 { | |
5499 ULONG message = 0L; | |
5500 | |
5501 if(window && signame && sigfunc) | |
5502 { | |
5503 if((message = _findsigmessage(signame)) != 0) | |
5504 _new_signal(message, window, sigfunc, data); | |
5505 } | |
5506 } | |
5507 | |
5508 /* | |
5509 * Removes callbacks for a given window with given name. | |
5510 * Parameters: | |
5511 * window: Window handle of callback to be removed. | |
5512 */ | |
5513 void dw_signal_disconnect_by_name(HWND window, char *signame) | |
5514 { | |
5515 SignalHandler *prev = NULL, *tmp = Root; | |
5516 ULONG message; | |
5517 | |
5518 if(!window || !signame || (message = _findsigmessage(signame)) == 0) | |
5519 return; | |
5520 | |
5521 while(tmp) | |
5522 { | |
5523 if(tmp->window == window && tmp->message == message) | |
5524 { | |
5525 if(prev) | |
5526 { | |
5527 prev->next = tmp->next; | |
5528 free(tmp); | |
5529 tmp = prev->next; | |
5530 } | |
5531 else | |
5532 { | |
5533 Root = tmp->next; | |
5534 free(tmp); | |
5535 tmp = Root; | |
5536 } | |
5537 } | |
5538 else | |
5539 { | |
5540 prev = tmp; | |
5541 tmp = tmp->next; | |
5542 } | |
5543 } | |
5544 } | |
5545 | |
5546 /* | |
5547 * Removes all callbacks for a given window. | |
5548 * Parameters: | |
5549 * window: Window handle of callback to be removed. | |
5550 */ | |
5551 void dw_signal_disconnect_by_window(HWND window) | |
5552 { | |
5553 SignalHandler *prev = NULL, *tmp = Root; | |
5554 | |
5555 while(tmp) | |
5556 { | |
5557 if(tmp->window == window) | |
5558 { | |
5559 if(prev) | |
5560 { | |
5561 prev->next = tmp->next; | |
5562 free(tmp); | |
5563 tmp = prev->next; | |
5564 } | |
5565 else | |
5566 { | |
5567 Root = tmp->next; | |
5568 free(tmp); | |
5569 tmp = Root; | |
5570 } | |
5571 } | |
5572 else | |
5573 { | |
5574 prev = tmp; | |
5575 tmp = tmp->next; | |
5576 } | |
5577 } | |
5578 } | |
5579 | |
5580 /* | |
5581 * Removes all callbacks for a given window with specified data. | |
5582 * Parameters: | |
5583 * window: Window handle of callback to be removed. | |
5584 * data: Pointer to the data to be compared against. | |
5585 */ | |
5586 void dw_signal_disconnect_by_data(HWND window, void *data) | |
5587 { | |
5588 SignalHandler *prev = NULL, *tmp = Root; | |
5589 | |
5590 while(tmp) | |
5591 { | |
5592 if(tmp->window == window && tmp->data == data) | |
5593 { | |
5594 if(prev) | |
5595 { | |
5596 prev->next = tmp->next; | |
5597 free(tmp); | |
5598 tmp = prev->next; | |
5599 } | |
5600 else | |
5601 { | |
5602 Root = tmp->next; | |
5603 free(tmp); | |
5604 tmp = Root; | |
5605 } | |
5606 } | |
5607 else | |
5608 { | |
5609 prev = tmp; | |
5610 tmp = tmp->next; | |
5611 } | |
5612 } | |
5613 } | |
5614 #endif | |
5615 | |
5616 #ifdef TEST | |
5617 HWND mainwindow, | |
5618 listbox, | |
5619 okbutton, | |
5620 cancelbutton, | |
5621 lbbox, | |
5622 stext, | |
5623 buttonbox, | |
5624 testwindow, | |
5625 testbox, | |
5626 testok, | |
5627 testcancel, | |
5628 testbox2, | |
5629 testok2, | |
5630 testcancel2, | |
5631 notebook; | |
5632 int count = 2; | |
5633 | |
5634 #ifdef USE_FILTER | |
5635 /* Do any handling you need in the filter function */ | |
5636 LONG testfilter(HWND hwnd, ULONG msg, MPARAM mp1, MPARAM mp2) | |
5637 { | |
5638 switch(msg) | |
5639 { | |
5640 case WM_COMMAND: | |
5641 switch (COMMANDMSG(&msg)->cmd) | |
5642 { | |
5643 case 1001L: | |
5644 case 1002L: | |
5645 dw_window_destroy(mainwindow);; | |
5646 count--; | |
5647 break; | |
5648 case 1003L: | |
5649 case 1004L: | |
5650 dw_window_destroy(testwindow);; | |
5651 count--; | |
5652 break; | |
5653 } | |
5654 if(!count) | |
5655 exit(0); | |
5656 break; | |
5657 } | |
5658 /* Return -1 to allow the default handlers to return. */ | |
5659 return TRUE; | |
5660 } | |
5661 #else | |
5662 int test_callback(HWND window, void *data) | |
5663 { | |
5664 dw_window_destroy((HWND)data); | |
5665 /* Return -1 to allow the default handlers to return. */ | |
5666 count--; | |
5667 if(!count) | |
5668 exit(0); | |
5669 return -1; | |
5670 } | |
5671 #endif | |
5672 | |
5673 /* | |
5674 * Let's demonstrate the functionality of this library. :) | |
5675 */ | |
5676 int WINAPI WinMain( | |
5677 HINSTANCE hInstance, | |
5678 HINSTANCE hPrevInstance, | |
5679 LPSTR lpCmdLine, | |
5680 int nCmdShow | |
5681 ) | |
5682 { | |
5683 ULONG flStyle = DW_FCF_SYSMENU | DW_FCF_TITLEBAR | | |
5684 DW_FCF_SHELLPOSITION | DW_FCF_TASKLIST | DW_FCF_DLGBORDER; | |
5685 int pageid; | |
5686 | |
5687 dw_init(TRUE); | |
5688 | |
5689 /* Try a little server dialog. :) */ | |
5690 mainwindow = dw_window_new(HWND_DESKTOP, "Server", flStyle | DW_FCF_SIZEBORDER | DW_FCF_MINMAX); | |
5691 | |
5692 lbbox = dw_box_new(BOXVERT, 10); | |
5693 | |
5694 dw_box_pack_start(mainwindow, lbbox, 0, 0, TRUE, TRUE, 0); | |
5695 | |
5696 stext = dw_text_new("Choose a server:", 0); | |
5697 | |
5698 dw_window_set_style(stext, DW_DT_VCENTER, DW_DT_VCENTER); | |
5699 | |
5700 dw_box_pack_start(lbbox, stext, 130, 15, FALSE, FALSE, 10); | |
5701 | |
5702 listbox = dw_listbox_new(100L, FALSE); | |
5703 | |
5704 dw_box_pack_start(lbbox, listbox, 130, 200, TRUE, TRUE, 10); | |
5705 | |
5706 buttonbox = dw_box_new(BOXHORZ, 0); | |
5707 | |
5708 dw_box_pack_start(lbbox, buttonbox, 0, 0, TRUE, TRUE, 0); | |
5709 | |
5710 okbutton = dw_button_new("Ok", 1001L); | |
5711 | |
5712 dw_box_pack_start(buttonbox, okbutton, 50, 30, TRUE, TRUE, 5); | |
5713 | |
5714 cancelbutton = dw_button_new("Cancel", 1002L); | |
5715 | |
5716 dw_box_pack_start(buttonbox, cancelbutton, 50, 30, TRUE, TRUE, 5); | |
5717 | |
5718 /* Set some nice fonts and colors */ | |
5719 dw_window_set_color(lbbox, DW_CLR_PALEGRAY, DW_CLR_PALEGRAY); | |
5720 dw_window_set_color(buttonbox, DW_CLR_PALEGRAY, DW_CLR_PALEGRAY); | |
5721 dw_window_set_font(stext, "9.WarpSans"); | |
5722 dw_window_set_color(stext, DW_CLR_BLACK, DW_CLR_PALEGRAY); | |
5723 dw_window_set_font(listbox, "9.WarpSans"); | |
5724 dw_window_set_font(okbutton, "9.WarpSans"); | |
5725 dw_window_set_font(cancelbutton, "9.WarpSans"); | |
5726 | |
5727 dw_window_show(mainwindow); | |
5728 | |
5729 dw_window_set_usize(mainwindow, 170, 340); | |
5730 | |
5731 /* Another small example */ | |
5732 flStyle |= DW_FCF_MINMAX | DW_FCF_SIZEBORDER; | |
5733 | |
5734 testwindow = dw_window_new(HWND_DESKTOP, "Wow a test dialog! :) yay!", flStyle); | |
5735 | |
5736 testbox = dw_box_new(BOXVERT, 0); | |
5737 | |
5738 dw_box_pack_start(testwindow, testbox, 0, 0, TRUE, TRUE, 0); | |
5739 | |
5740 notebook = dw_notebook_new(1010L, TRUE); | |
5741 | |
5742 dw_box_pack_start(testbox, notebook, 100, 100, TRUE, TRUE, 0); | |
5743 | |
5744 testbox = dw_box_new(BOXVERT, 10); | |
5745 | |
5746 pageid = dw_notebook_page_new(notebook, 0L, FALSE); | |
5747 | |
5748 dw_notebook_page_set_text(notebook, pageid, "Test page"); | |
5749 dw_notebook_page_set_status_text(notebook, pageid, "Test page"); | |
5750 | |
5751 dw_notebook_pack(notebook, pageid, testbox); | |
5752 | |
5753 testok = dw_button_new("Ok", 1003L); | |
5754 | |
5755 dw_box_pack_start(testbox, testok, 60, 40, TRUE, TRUE, 10); | |
5756 | |
5757 testcancel = dw_button_new("Cancel", 1004L); | |
5758 | |
5759 dw_box_pack_start(testbox, testcancel, 60, 40, TRUE, TRUE, 10); | |
5760 | |
5761 testbox2 = dw_box_new(BOXHORZ, 0); | |
5762 | |
5763 dw_box_pack_start(testbox, testbox2, 0, 0, TRUE, TRUE, 0); | |
5764 | |
5765 testok2 = dw_button_new("Ok", 1003L); | |
5766 | |
5767 dw_box_pack_start(testbox2, testok2, 60, 40, TRUE, TRUE, 10); | |
5768 | |
5769 dw_box_pack_splitbar_start(testbox2); | |
5770 | |
5771 testcancel2 = dw_button_new("Cancel", 1004L); | |
5772 | |
5773 dw_box_pack_start(testbox2, testcancel2, 60, 40, TRUE, TRUE, 10); | |
5774 | |
5775 /* Set some nice fonts and colors */ | |
5776 dw_window_set_color(testbox, DW_CLR_PALEGRAY, DW_CLR_PALEGRAY); | |
5777 dw_window_set_color(testbox2, DW_CLR_PALEGRAY, DW_CLR_PALEGRAY); | |
5778 dw_window_set_font(testok, "9.WarpSans"); | |
5779 dw_window_set_font(testcancel, "9.WarpSans"); | |
5780 dw_window_set_font(testok2, "9.WarpSans"); | |
5781 dw_window_set_font(testcancel2, "9.WarpSans"); | |
5782 | |
5783 dw_window_show(testwindow); | |
5784 | |
5785 #ifdef USE_FILTER | |
5786 | |
5787 dw_main(0L, (void *)testfilter); | |
5788 #else | |
5789 /* Setup the function callbacks */ | |
5790 dw_signal_connect(okbutton, "clicked", DW_SIGNAL_FUNC(test_callback), (void *)mainwindow); | |
5791 dw_signal_connect(cancelbutton, "clicked", DW_SIGNAL_FUNC(test_callback), (void *)mainwindow); | |
5792 dw_signal_connect(testok, "clicked", DW_SIGNAL_FUNC(test_callback), (void *)testwindow); | |
5793 dw_signal_connect(testcancel, "clicked", DW_SIGNAL_FUNC(test_callback), (void *)testwindow); | |
5794 dw_signal_connect(testok2, "clicked", DW_SIGNAL_FUNC(test_callback), (void *)testwindow); | |
5795 dw_signal_connect(testcancel2, "clicked", DW_SIGNAL_FUNC(test_callback), (void *)testwindow); | |
5796 dw_signal_connect(mainwindow, "delete_event", DW_SIGNAL_FUNC(test_callback), (void *)mainwindow); | |
5797 dw_signal_connect(testwindow, "delete_event", DW_SIGNAL_FUNC(test_callback), (void *)testwindow); | |
5798 | |
5799 dw_main(0L, NULL); | |
5800 #endif | |
5801 | |
5802 return 0; | |
5803 } | |
5804 #endif |