summaryrefslogtreecommitdiff
path: root/redo/sizing_windows.c
blob: 133cbccd8fdbe4d3b9de3b5e23d8bf44e656fb90 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/* 17 july 2014 */

#include "winapi_windows.h"
#include "_cgo_export.h"

BOOL baseUnitsCalculated = FALSE;
int baseX;
int baseY;

/* called by newWindow() so we can calculate base units when we have a window */
void calculateBaseUnits(HWND hwnd)
{
	HDC dc;
	HFONT prevFont;
	TEXTMETRICW tm;

	if (baseUnitsCalculated)
		return;
	dc = GetDC(hwnd);
	if (dc == NULL)
		xpanic("error getting DC for preferred size calculations", GetLastError());
	prevFont = (HFONT) SelectObject(dc, controlFont);
	if (prevFont == NULL)
		xpanic("error loading control font into device context for preferred size calculation", GetLastError());
	if (GetTextMetricsW(dc, &tm) == 0)
		xpanic("error getting text metrics for preferred size calculations", GetLastError());
	baseX = (int) tm.tmAveCharWidth;		/* TODO not optimal; third reference below has better way */
	baseY = (int) tm.tmHeight;
	if (SelectObject(dc, prevFont) != controlFont)
		xpanic("error restoring previous font into device context after preferred size calculations", GetLastError());
	if (ReleaseDC(hwnd, dc) == 0)
		xpanic("error releasing DC for preferred size calculations", GetLastError());
	baseUnitsCalculated = TRUE;
}

void moveWindow(HWND hwnd, int x, int y, int width, int height)
{
	if (MoveWindow(hwnd, x, y, width, height, TRUE) == 0)
		xpanic("error setting window/control rect", GetLastError());
}