Last updated: 17. 1.1998, 21: 2
<* +M2EXTENSIONS *> MODULE EndJoin; (*---------------------------------------- ENDJOIN.C --- Ends and Joins Demo (c) Charles Petzold, 1996 EndJoin.C --- Translation to XDS Modula-2 by (c) Peter Stadler, 1997 ----------------------------------------*) IMPORT Windows; IMPORT SYSTEM; CONST szAppName = "EndJoin"; TYPE iArr = ARRAY[0..2] OF Windows.PS_SET; VAR hwnd : Windows.HWND; msg : Windows.MSG; wc : Windows.WNDCLASSEX; CONST iEnd = iArr { Windows.PS_ENDCAP_ROUND, Windows.PS_ENDCAP_SQUARE, Windows.PS_ENDCAP_FLAT }; iJoin = iArr { Windows.PS_JOIN_ROUND, Windows.PS_JOIN_BEVEL, Windows.PS_JOIN_MITER }; VAR cxClient : INTEGER; cyClient : INTEGER; (*++++*****************************************************************) PROCEDURE [Windows.CALLBACK] WndProc(hwnd : Windows.HWND; (**********************************************************************) iMsg : Windows.UINT; wParam : Windows.WPARAM; lParam : Windows.LPARAM) : Windows.LRESULT; VAR hdc : Windows.HDC; i : INTEGER; lb : Windows.LOGBRUSH; ps : Windows.PAINTSTRUCT; BEGIN CASE (iMsg) OF | Windows.WM_SIZE: cxClient := Windows.LOWORD (lParam); cyClient := Windows.HIWORD (lParam); RETURN 0; | Windows.WM_PAINT: hdc := Windows.BeginPaint (hwnd, ps); Windows.SetMapMode (hdc, Windows.MM_ANISOTROPIC); Windows.SetWindowExtEx (hdc, 100, 100, NIL); Windows.SetViewportExtEx (hdc, cxClient, cyClient, NIL); lb.lbStyle := Windows.BS_SOLID; lb.lbColor := Windows.RGB (128, 128, 128); lb.lbHatch := 0; FOR i := 0 TO 3-1 DO Windows.SelectObject (hdc, SYSTEM.CAST(Windows.HGDIOBJ,Windows.ExtCreatePen (Windows.PS_SOLID + Windows.PS_GEOMETRIC + iEnd [i] + iJoin [i], 10, lb, 0, NIL))); Windows.BeginPath (hdc); Windows.MoveToEx (hdc, 10 + 30 * i, 25, NIL); Windows.LineTo (hdc, 20 + 30 * i, 75); Windows.LineTo (hdc, 30 + 30 * i, 25); Windows.EndPath (hdc); Windows.StrokePath (hdc); Windows.DeleteObject ( Windows.SelectObject (hdc, Windows.GetStockObject (Windows.BLACK_PEN))); Windows.MoveToEx (hdc, 10 + 30 * i, 25, NIL); Windows.LineTo (hdc, 20 + 30 * i, 75); Windows.LineTo (hdc, 30 + 30 * i, 25); END; Windows.EndPaint (hwnd, ps); RETURN 0; | Windows.WM_DESTROY: Windows.PostQuitMessage (0); RETURN 0; ELSE RETURN Windows.DefWindowProc (hwnd, iMsg, wParam, lParam); END; END WndProc; (*++++*****************************************************************) PROCEDURE InitApplication () : BOOLEAN; (**********************************************************************) BEGIN wc.cbSize := SIZE(wc); wc.style := Windows.CS_HREDRAW + Windows.CS_VREDRAW; wc.lpfnWndProc := WndProc; wc.cbClsExtra := 0; wc.cbWndExtra := 0; wc.hInstance := Windows.MyInstance(); wc.hIcon := Windows.LoadIcon (NIL, Windows.IDI_APPLICATION); wc.hCursor := Windows.LoadCursor (NIL, Windows.IDC_ARROW); wc.hbrBackground := SYSTEM.CAST(Windows.HBRUSH, Windows.GetStockObject (Windows.WHITE_BRUSH)); wc.lpszMenuName := NIL; wc.lpszClassName := SYSTEM.ADR(szAppName); wc.hIconSm := Windows.LoadIcon (NIL,Windows.IDI_APPLICATION); RETURN Windows.RegisterClassEx(wc)#0; END InitApplication; (*++++*****************************************************************) PROCEDURE InitMainWindow () : BOOLEAN; (**********************************************************************) BEGIN hwnd := Windows.CreateWindow ( szAppName, (* window class name *) "Ends and Joins Demo: Translation to XDS Modula-2", (* window caption *) Windows.WS_OVERLAPPEDWINDOW, (* window style *) Windows.CW_USEDEFAULT, (* initial x position *) Windows.CW_USEDEFAULT, (* initial y position *) Windows.CW_USEDEFAULT, (* initial x size *) Windows.CW_USEDEFAULT, (* initial y size *) NIL, (* parent window handle *) NIL, (* window menu handle *) wc.hInstance, (* program instance handle *) NIL); (* creation parameters *) IF hwnd = NIL THEN RETURN FALSE; END; Windows.ShowWindow (hwnd, Windows.SW_SHOWDEFAULT); Windows.UpdateWindow (hwnd); RETURN TRUE; END InitMainWindow; BEGIN IF InitApplication() AND InitMainWindow() THEN WHILE (Windows.GetMessage(msg,NIL,0,0)) DO Windows.TranslateMessage(msg); Windows.DispatchMessage(msg); END; END; END EndJoin.