Release 0.4.3
Tue Sep 28 19:59:21 1993 David Metcalfe
* [windows/win.c]
Implemented support for windows with no borders. Added
GetParent(), GetDlgCtrlID(), GetWindowText() and
GetWindowTextLength() functions.
* [misc/xt.c]
Added processing of WM_GETTEXT and WM_GETTEXTLENGTH messages
to DefWindowProc and Implemented MessageBeep().
* [windows/syscolor.c]
Added preliminary system color support.
* [controls/button1.c]
Mods to new button control and integration with Wine.
Tue Sep 28 19:59:21 1993 Johannes Ruscheinski
* [controls/button1.c]
New button control using GDI functions.
Tue Sep 28 19:59:21 1993 Eric Youngdale
* [debugger/*]
Added debugging capabilities to Wine
Sat Sep 25 13:22:50 1993 Alexandre Julliard (julliard@di.epfl.ch)
* [objects/region.c]
Bug fix
Fri Sep 24 07:35:11 1993 Bob Amstadt (bob at pooh)
* [tools/build.c]
Changed the entry point code to reduce the standard entry
point size from 22 bytes to 10 bytes. This leaves about
4000 free entry points instead of the 800 in version 0.4.2.
* [loader/resource.c]
Rewrote functions to allow loading of resources from any
DLL.
* [loader/wine.c] [include/wine.h]
Added functions GetFilenameFromInstance() and GetFileInfo()
to search for a loaded file based on its instance handle.
Added a field in struct w_files to make searching by an instance
handle faster.
Tue Sep 21 09:57:01 1993 miguel@roxanne.nuclecu.unam.mx (Miguel de Icaza)
* [misc/profile.c]
Implementation of .INI file handling
Mon Sep 20 10:54:32 1993 David Metcalfe
* [misc/profile.c.old]
Implementation of .INI file handling
Mon Sep 20 10:54:32 1993 John Brezak
* [controls/WinButton.c]
Bug fix with call to XtVaSetValues.
Mon Sep 20 10:54:32 1993 Alexandre Julliard
* [windows/win.c]
Quick patch to get colormaps to work with button widget.
Mon Sep 20 02:42:54 1993 (yngvi@hafro.is)
* misc/keyboard.c:
Ifdefed out some bogus Ansi<->Oem conversion functions
* misc/lstr.c:
New file with string functions like lstr* IsChar* *Ansi*
Wed Sep 15 20:35:10 1993 John Brezak
* [loader/signal.c]
Additional changes to support NetBSD.
Wed Sep 15 22:19:22 1993 Martin Ayotte
* [windows/graphics.c]
Added FrameRect function
Tue Sep 14 13:54:45 1993 Alexandre Julliard
* [objects/color.c] [objects/palette.c]
Preliminary support for private color map.
* [windows/class.c]
Implemented CS_CLASSDC style.
* [windows/dce.c]
Moved DCEs to USER heap.
Implemented class and window DCs.
* [windows/event.c]
Implemented CS_DBLCLKS style.
* [windows/graphics.c]
Bug fix in SetPixel().
* [windows/win.c]
Implemented CS_OWNDC style.
Implemented Get/SetWindowLong().
* [controls/menu.c] [windows/class.c] [windows/clipping.c]
[windows/dce.c] [windows/message.c] [windows/win.c]
Moved windows from global heap to USER heap.
diff --git a/controls/button.c b/controls/button.c
index 3a65bc0..f843beb 100644
--- a/controls/button.c
+++ b/controls/button.c
@@ -1,86 +1,351 @@
-/*
- * Interface code to button widgets
+/* File: button.c -- MS-Windows(tm) compatible "Button" replacement widget
*
- * Copyright David W. Metcalfe, 1993
+ * programmed by Johannes Ruscheinski for the Linux WABI
+ * project.
+ * (C) 1993 by Johannes Ruscheinski
*
+ * Modifications by David Metcalfe
*/
-static char Copyright[] = "Copyright David W. Metcalfe, 1993";
-
-#include <X11/Intrinsic.h>
-#include <X11/StringDefs.h>
-#include "WinButton.h"
-#include "windows.h"
-#include "heap.h"
+#include <windows.h>
#include "win.h"
-static void BUTTON_WinButtonCallback(Widget w, XtPointer client_data,
- XtPointer call_data);
+LONG ButtonWndProc(HWND hWnd, WORD uMsg, WORD wParam, LONG lParam);
-void BUTTON_CreateButton(LPSTR className, LPSTR buttonLabel, HWND hwnd)
+static COLORREF color_windowframe, color_btnface, color_btnshadow,
+ color_btntext, color_btnhighlight;
+
+static BOOL pressed;
+
+#define NOTIFY_PARENT(hWndCntrl, wNotifyCode) \
+ SendMessage(GetParent(hWndCntrl), WM_COMMAND, \
+ GetDlgCtrlID(hWndCntrl), MAKELPARAM(hWndCntrl, wNotifyCode));
+#define DIM(array) ((sizeof array)/(sizeof array[0]))
+
+static LONG PB_Paint(HWND hWnd);
+static LONG PB_LButtonDown(HWND hWnd, WORD wParam, LONG lParam);
+static LONG PB_LButtonUp(HWND hWnd, WORD wParam, LONG lParam);
+static LONG PB_LButtonDblClk(HWND hWnd, WORD wParam, LONG lParam);
+static void DrawRaisedPushButton(HDC hDC, HWND hButton, RECT rc);
+static void DrawPressedPushButton(HDC hDC, HWND hButton, RECT rc);
+
+typedef struct
{
- WND *wndPtr = WIN_FindWndPtr(hwnd);
- WND *parentPtr = WIN_FindWndPtr(wndPtr->hwndParent);
- DWORD style;
- char widgetName[15];
+ LONG (*paintfn)();
+ LONG (*lButtonDownfn)();
+ LONG (*lButtonUpfn)();
+ LONG (*lButtonDblClkfn)();
+} BTNFN;
-#ifdef DEBUG_BUTTON
- printf("button: label = %s, x = %d, y = %d\n", buttonLabel,
- wndPtr->rectClient.left, wndPtr->rectClient.top);
- printf(" width = %d, height = %d\n",
- wndPtr->rectClient.right - wndPtr->rectClient.left,
- wndPtr->rectClient.bottom - wndPtr->rectClient.top);
+#define MAX_BTN_TYPE 2
+
+static BTNFN btnfn[MAX_BTN_TYPE] =
+{
+ {
+ (LONG(*)())PB_Paint, /* BS_PUSHBUTTON */
+ (LONG(*)())PB_LButtonDown,
+ (LONG(*)())PB_LButtonUp,
+ (LONG(*)())PB_LButtonDblClk
+ },
+ {
+ (LONG(*)())PB_Paint, /* BS_DEFPUSHBUTTON */
+ (LONG(*)())PB_LButtonDown,
+ (LONG(*)())PB_LButtonUp,
+ (LONG(*)())PB_LButtonDblClk
+ }
+};
+
+
+LONG ButtonWndProc(HWND hWnd, WORD uMsg, WORD wParam, LONG lParam)
+{
+ LONG lResult = 0;
+ HDC hDC;
+ RECT rc;
+
+ WND *wndPtr = WIN_FindWndPtr(hWnd);
+ LONG style = wndPtr->dwStyle & 0x0000000F;
+
+ switch (uMsg) {
+/* case WM_GETDLGCODE:
+ lResult = DLGC_BUTTON;
+ break;
+*/
+ case WM_ENABLE:
+ InvalidateRect(hWnd, NULL, FALSE);
+ break;
+
+ case WM_CREATE:
+ if (style < 0L || style >= (LONG)DIM(btnfn))
+ lResult = -1L;
+ else
+ {
+ /* initialise colours used for button rendering: */
+ color_windowframe = GetSysColor(COLOR_WINDOWFRAME);
+ color_btnface = GetSysColor(COLOR_BTNFACE);
+ color_btnshadow = GetSysColor(COLOR_BTNSHADOW);
+ color_btntext = GetSysColor(COLOR_BTNTEXT);
+ color_btnhighlight = GetSysColor(COLOR_BTNHIGHLIGHT);
+
+ pressed = FALSE;
+ lResult = 0L;
+ }
+ break;
+
+ case WM_PAINT:
+ (btnfn[style].paintfn)(hWnd);
+ break;
+
+ case WM_LBUTTONDOWN:
+ (btnfn[style].lButtonDownfn)(hWnd, wParam, lParam);
+ break;
+
+ case WM_LBUTTONUP:
+ (btnfn[style].lButtonUpfn)(hWnd, wParam, lParam);
+ break;
+
+ case WM_LBUTTONDBLCLK:
+ (btnfn[style].lButtonDblClkfn)(hWnd, wParam, lParam);
+ break;
+
+ case WM_SETFOCUS:
+ break;
+
+ case WM_KILLFOCUS:
+ InvalidateRect(hWnd, NULL, FALSE);
+ UpdateWindow(hWnd);
+ break;
+
+ case WM_SYSCOLORCHANGE:
+ color_windowframe = GetSysColor(COLOR_WINDOWFRAME);
+ color_btnface = GetSysColor(COLOR_BTNFACE);
+ color_btnshadow = GetSysColor(COLOR_BTNSHADOW);
+ color_btntext = GetSysColor(COLOR_BTNTEXT);
+ color_btnhighlight = GetSysColor(COLOR_BTNHIGHLIGHT);
+ InvalidateRect(hWnd, NULL, TRUE);
+ break;
+
+ default:
+ lResult = DefWindowProc(hWnd, uMsg, wParam, lParam);
+ break;
+ }
+
+ GlobalUnlock(hWnd);
+ return lResult;
+}
+
+
+/**********************************************************************
+ * Push Button Functions
+ */
+
+static LONG PB_Paint(HWND hWnd)
+{
+ PAINTSTRUCT ps;
+ RECT rc;
+ HDC hDC;
+
+ hDC = BeginPaint(hWnd, &ps);
+ GetClientRect(hWnd, &rc);
+ if (pressed)
+ DrawPressedPushButton(hDC, hWnd, rc);
+ else
+ DrawRaisedPushButton(hDC, hWnd, rc);
+ EndPaint(hWnd, &ps);
+}
+
+static LONG PB_LButtonDown(HWND hWnd, WORD wParam, LONG lParam)
+{
+/* SetFocus(hWnd); */
+ SetCapture(hWnd);
+ pressed = TRUE;
+ InvalidateRect(hWnd, NULL, FALSE);
+ UpdateWindow(hWnd);
+}
+
+static LONG PB_LButtonUp(HWND hWnd, WORD wParam, LONG lParam)
+{
+ RECT rc;
+
+ pressed = FALSE;
+ ReleaseCapture();
+ GetClientRect(hWnd, &rc);
+ if (PtInRect(&rc, MAKEPOINT(lParam)))
+ NOTIFY_PARENT(hWnd, BN_CLICKED);
+ InvalidateRect(hWnd, NULL, FALSE);
+ UpdateWindow(hWnd);
+}
+
+static LONG PB_LButtonDblClk(HWND hWnd, WORD wParam, LONG lParam)
+{
+ RECT rc;
+
+ GetClientRect(hWnd, &rc);
+ if (PtInRect(&rc, MAKEPOINT(lParam)))
+ NOTIFY_PARENT(hWnd, BN_DOUBLECLICKED);
+}
+
+static void DrawRaisedPushButton(HDC hDC, HWND hButton, RECT rc)
+{
+ HPEN hOldPen, hFramePen;
+ HBRUSH hOldBrush, hShadowBrush, hHighlightBrush, hBackgrndBrush;
+ HRGN rgn1, rgn2, rgn;
+ int len;
+ static char text[50+1];
+ POINT points[6];
+ DWORD dwTextSize;
+ int delta;
+ TEXTMETRIC tm;
+ int i;
+
+ hFramePen = CreatePen(PS_SOLID, 1, color_windowframe);
+ hBackgrndBrush = CreateSolidBrush(color_btnface);
+
+ hOldPen = (HPEN)SelectObject(hDC, (HANDLE)hFramePen);
+ hOldBrush = (HBRUSH)SelectObject(hDC, (HANDLE)hBackgrndBrush);
+ SetBkMode(hDC, TRANSPARENT);
+
+ rgn = CreateRectRgn(0, 0, 0, 0);
+ rgn1 = CreateRectRgn(rc.left, rc.top, rc.right, rc.bottom);
+
+ SendMessage(GetParent(hButton), WM_CTLCOLOR, (WORD)hDC,
+ MAKELPARAM(hButton, CTLCOLOR_BTN));
+ Rectangle(hDC, rc.left, rc.top, rc.right, rc.bottom);
+
+ /* draw button label, if any: */
+ len = GetWindowText(hButton, text, sizeof text);
+ if (len >= 1) {
+ rc.left--; rc.bottom--;
+ DrawText(hDC, text, len, &rc,
+ DT_SINGLELINE | DT_CENTER| DT_VCENTER);
+ }
+
+ /* draw button highlight */
+ points[0].x = rc.left+2;
+ points[0].y = rc.bottom;
+ points[1].x = rc.left+4;
+ points[1].y = rc.bottom-2;
+ points[2].x = rc.left+4;
+ points[2].y = rc.top+3;
+ points[3].x = rc.right-3;
+ points[3].y = rc.top+3;
+ points[4].x = rc.right-1;
+ points[4].y = rc.top+1;
+ points[5].x = rc.left+2;
+ points[5].y = rc.top+1;
+ hHighlightBrush = CreateSolidBrush(color_btnhighlight);
+ rgn2 = CreatePolygonRgn(points, DIM(points), ALTERNATE);
+ CombineRgn(rgn, rgn1, rgn2, RGN_AND);
+ FillRgn(hDC, rgn2, hHighlightBrush);
+
+ /* draw button shadow: */
+ points[0].x = rc.left+2;
+ points[0].y = rc.bottom;
+ points[1].x = rc.left+4;
+ points[1].y = rc.bottom-2;
+ points[2].x = rc.right-3;
+ points[2].y = rc.bottom-2;
+ points[3].x = rc.right-3;
+ points[3].y = rc.top+3;
+ points[4].x = rc.right-1;
+ points[4].y = rc.top;
+ points[5].x = rc.right-1;
+ points[5].y = rc.bottom;
+ hShadowBrush = CreateSolidBrush(color_btnshadow);
+ rgn2 = CreatePolygonRgn(points, DIM(points), ALTERNATE);
+ CombineRgn(rgn, rgn1, rgn2, RGN_AND);
+ FillRgn(hDC, rgn2, hShadowBrush);
+
+#if 0
+ /* do we have the focus? */
+ if (len >= 1 && GetFocus() == hButton) {
+ dwTextSize = GetTextExtent(hDC, text, len);
+ delta = ((rc.right - rc.left) - LOWORD(dwTextSize) + 1) >> 1;
+ rc.left += delta; rc.right -= delta;
+ GetTextMetrics(hDC, &tm);
+ delta = ((rc.bottom - rc.top) -
+ tm.tmHeight + tm.tmInternalLeading) >> 1;
+ rc.top += delta; rc.bottom -= delta;
+ DrawFocusRect(hDC, &rc);
+ }
#endif
- if (!wndPtr)
- return;
-
- style = wndPtr->dwStyle & 0x0000000F;
-
- switch (style)
- {
- case BS_PUSHBUTTON:
- case BS_DEFPUSHBUTTON:
- sprintf(widgetName, "%s%d", className, wndPtr->wIDmenu);
- wndPtr->winWidget = XtVaCreateManagedWidget(widgetName,
- winButtonWidgetClass,
- parentPtr->winWidget,
- XtNlabel, buttonLabel,
- XtNx, wndPtr->rectClient.left,
- XtNy, wndPtr->rectClient.top,
- XtNwidth, wndPtr->rectClient.right -
- wndPtr->rectClient.left,
- XtNheight, wndPtr->rectClient.bottom -
- wndPtr->rectClient.top,
- XtVaTypedArg, XtNbackground, XtRString,
- "grey70", strlen("grey75")+1,
- NULL);
-
- XtAddCallback(wndPtr->winWidget, XtNcallback,
- BUTTON_WinButtonCallback, (XtPointer) hwnd);
- break;
-
- default:
- printf("CreateButton: Unsupported button style %lX\n",
- wndPtr->dwStyle);
- }
-
- GlobalUnlock(hwnd);
- GlobalUnlock(wndPtr->hwndParent);
+ SelectObject(hDC, (HANDLE)hOldPen);
+ SelectObject(hDC, (HANDLE)hOldBrush);
+ DeleteObject((HANDLE)hFramePen);
+ DeleteObject((HANDLE)hShadowBrush);
+ DeleteObject((HANDLE)hBackgrndBrush);
+ DeleteObject((HANDLE)rgn1);
+#if 0
+ DeleteObject((HANDLE)rgn2);
+ DeleteObject((HANDLE)rgn);
+#endif
}
-static void BUTTON_WinButtonCallback(Widget w, XtPointer client_data,
- XtPointer call_data)
+
+static void DrawPressedPushButton(HDC hDC, HWND hButton, RECT rc)
{
- HWND hwnd = (HWND) client_data;
- WND *wndPtr;
- wndPtr = WIN_FindWndPtr(hwnd);
+ HPEN hOldPen, hShadowPen, hFramePen;
+ HBRUSH hOldBrush, hBackgrndBrush;
+ HRGN rgn1, rgn2, rgn;
+ int len;
+ static char text[50+1];
+ DWORD dwTextSize;
+ int delta;
+ TEXTMETRIC tm;
- CallWindowProc(wndPtr->lpfnWndProc, wndPtr->hwndParent, WM_COMMAND,
- wndPtr->wIDmenu, MAKELPARAM(hwnd, BN_CLICKED));
+ hFramePen = CreatePen(PS_SOLID, 1, color_windowframe);
+ hBackgrndBrush = CreateSolidBrush(color_btnface);
- GlobalUnlock(hwnd);
+ hOldBrush = (HBRUSH)SelectObject(hDC, (HANDLE)hBackgrndBrush);
+ hOldPen = (HPEN)SelectObject(hDC, (HANDLE)hFramePen);
+ SetBkMode(hDC, TRANSPARENT);
+
+ /* give parent a chance to alter parameters: */
+ SendMessage(GetParent(hButton), WM_CTLCOLOR, (WORD)hDC,
+ MAKELPARAM(hButton, CTLCOLOR_BTN));
+ Rectangle(hDC, rc.left, rc.top, rc.right, rc.bottom);
+
+ /* draw button shadow: */
+ hShadowPen = CreatePen(PS_SOLID, 1, color_btnshadow);
+ SelectObject(hDC, (HANDLE)hShadowPen);
+ MoveTo(hDC, rc.left+1, rc.bottom-1);
+ LineTo(hDC, rc.left+1, rc.top+1);
+ LineTo(hDC, rc.right-1, rc.top+1);
+
+ /* draw button label, if any: */
+ len = GetWindowText(hButton, text, sizeof text);
+ if (len >= 1) {
+ rc.top++; rc.left++;
+ DrawText(hDC, text, len, &rc,
+ DT_SINGLELINE | DT_CENTER| DT_VCENTER);
+ }
+
+#if 0
+ /* do we have the focus? */
+ if (len >= 1 && GetFocus() == hButton) {
+ dwTextSize = GetTextExtent(hDC, text, len);
+ delta = ((rc.right - rc.left) - LOWORD(dwTextSize)) >> 1;
+ rc.left += delta; rc.right -= delta;
+ GetTextMetrics(hDC, &tm);
+ delta = ((rc.bottom - rc.top) -
+ tm.tmHeight + tm.tmInternalLeading) >> 1;
+ rc.top += delta; rc.bottom -= delta;
+ DrawFocusRect(hDC, &rc);
+ }
+#endif
+
+ SelectObject(hDC, (HANDLE)hOldPen);
+ SelectObject(hDC, (HANDLE)hOldBrush);
+ DeleteObject((HANDLE)hBackgrndBrush);
+ DeleteObject(SelectObject(hDC, (HANDLE)hFramePen));
+ DeleteObject(SelectObject(hDC, (HANDLE)hShadowPen));
}
+
+
+
+
+
+