andlabs-ui/redo/sizing_windows.c

41 lines
1.3 KiB
C
Raw Normal View History

2014-07-17 21:47:04 -05:00
/* 17 july 2014 */
#include "winapi_windows.h"
#include "_cgo_export.h"
2014-07-17 21:47:04 -05:00
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)
2014-07-17 21:47:04 -05:00
{
HDC dc;
HFONT prevFont;
TEXTMETRICW tm;
2014-07-17 21:47:04 -05:00
if (baseUnitsCalculated)
return;
2014-07-17 21:47:04 -05:00
dc = GetDC(hwnd);
if (dc == NULL)
xpanic("error getting DC for preferred size calculations", GetLastError());
prevFont = (HFONT) SelectObject(dc, controlFont);
if (prevFont == NULL)
2014-07-17 21:47:04 -05:00
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());
2014-07-17 21:47:04 -05:00
if (ReleaseDC(hwnd, dc) == 0)
xpanic("error releasing DC for preferred size calculations", GetLastError());
baseUnitsCalculated = TRUE;
2014-07-17 21:47:04 -05:00
}
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());
}