From 237cdffee61dae60600b8466105723f287e709d8 Mon Sep 17 00:00:00 2001 From: Pietro Gagliardi Date: Wed, 20 May 2015 17:09:58 -0400 Subject: [PATCH] Added basic uiComboboxes. --- redo/test/page4.c | 10 +++++ redo/ui.idl | 5 +++ redo/windows/GNUmakeinc.mk | 1 + redo/windows/combobox.c | 85 ++++++++++++++++++++++++++++++++++++++ 4 files changed, 101 insertions(+) create mode 100644 redo/windows/combobox.c diff --git a/redo/test/page4.c b/redo/test/page4.c index 8a2c1aaf..f3359b1a 100644 --- a/redo/test/page4.c +++ b/redo/test/page4.c @@ -28,6 +28,8 @@ SETTOO(Spinbox, High, 80) SETTOO(Slider, Low, -80) SETTOO(Slider, High, 80) +uiCombobox *cbox; + uiBox *makePage4(void) { uiBox *page4; @@ -73,5 +75,13 @@ uiBox *makePage4(void) uiBoxAppend(hbox, uiControl(b), 0); uiBoxAppend(page4, uiControl(hbox), 0); + uiBoxAppend(page4, uiControl(uiNewHorizontalSeparator()), 0); + + cbox = uiNewCombobox(); + uiComboboxAppend(cbox, "Item 1"); + uiComboboxAppend(cbox, "Item 2"); + uiComboboxAppend(cbox, "Item 3"); + uiBoxAppend(page4, uiControl(cbox), 0); + return page4; } diff --git a/redo/ui.idl b/redo/ui.idl index 480c83d6..44fc29d8 100644 --- a/redo/ui.idl +++ b/redo/ui.idl @@ -170,6 +170,11 @@ interface Separator from Control { }; func NewHorizontalSeparator(void) *Separator; +interface Combobox from Control { + func Append(text *const char); +}; +func NewCombobox(void) *Combobox; + interface Menu { func AppendItem(name *const char) *MenuItem; func AppendCheckItem(name *const char) *MenuItem; diff --git a/redo/windows/GNUmakeinc.mk b/redo/windows/GNUmakeinc.mk index b57b443c..784c7f35 100644 --- a/redo/windows/GNUmakeinc.mk +++ b/redo/windows/GNUmakeinc.mk @@ -4,6 +4,7 @@ osCFILES = \ windows/alloc.c \ windows/button.c \ windows/checkbox.c \ + windows/combobox.c \ windows/container.c \ windows/control.c \ windows/debug.c \ diff --git a/redo/windows/combobox.c b/redo/windows/combobox.c new file mode 100644 index 00000000..8ba47453 --- /dev/null +++ b/redo/windows/combobox.c @@ -0,0 +1,85 @@ +// 20 may 2015 +#include "uipriv_windows.h" + +struct combobox { + uiCombobox c; + HWND hwnd; +}; + +static BOOL onWM_COMMAND(uiControl *c, WORD code, LRESULT *lResult) +{ + return FALSE; +} + +static BOOL onWM_NOTIFY(uiControl *c, NMHDR *nm, LRESULT *lResult) +{ + return FALSE; +} + +static BOOL onWM_HSCROLL(uiControl *c, WORD code, LRESULT *lResult) +{ + return FALSE; +} + +static void onDestroy(void *data) +{ + struct combobox *c = (struct combobox *) data; + + uiFree(c); +} + +// from http://msdn.microsoft.com/en-us/library/windows/desktop/dn742486.aspx#sizingandspacing +#define comboboxWidth 107 /* this is actually the shorter progress bar width, but Microsoft only indicates as wide as necessary */ +#define comboboxHeight 14 + +static void comboboxPreferredSize(uiControl *c, uiSizing *d, intmax_t *width, intmax_t *height) +{ + *width = uiWindowsDlgUnitsToX(comboboxWidth, d->Sys->BaseX); + *height = uiWindowsDlgUnitsToY(comboboxHeight, d->Sys->BaseY); +} + +static void comboboxAppend(uiCombobox *cc, const char *text) +{ + struct combobox *c = (struct combobox *) cc; + WCHAR *wtext; + LRESULT res; + + wtext = toUTF16(text); + res = SendMessageW(c->hwnd, CB_ADDSTRING, 0, (LPARAM) wtext); + if (res == (LRESULT) CB_ERR) + logLastError("error appending item to uiCombobox"); + else if (res == (LRESULT) CB_ERRSPACE) + logLastError("memory exhausted appending item to uiCombobox"); + uiFree(wtext); +} + +uiCombobox *uiNewCombobox(void) +{ + struct combobox *c; + uiWindowsMakeControlParams p; + + c = uiNew(struct combobox); + uiTyped(c)->Type = uiTypeCombobox(); + + p.dwExStyle = WS_EX_CLIENTEDGE; + p.lpClassName = L"combobox"; + p.lpWindowName = L""; + p.dwStyle = CBS_DROPDOWNLIST | WS_TABSTOP; + p.hInstance = hInstance; + p.lpParam = NULL; + p.useStandardControlFont = TRUE; + p.onWM_COMMAND = onWM_COMMAND; + p.onWM_NOTIFY = onWM_NOTIFY; + p.onWM_HSCROLL = onWM_HSCROLL; + p.onDestroy = onDestroy; + p.onDestroyData = c; + uiWindowsMakeControl(uiControl(c), &p); + + c->hwnd = (HWND) uiControlHandle(uiControl(c)); + + uiControl(c)->PreferredSize = comboboxPreferredSize; + + uiCombobox(c)->Append = comboboxAppend; + + return uiCombobox(c); +}