Re #333 (D26 : New / enhanced menu controls) Added GfuiComboboxGetNumberOfChoices + cleaned up the combobox code

git-svn-id: https://svn.code.sf.net/p/speed-dreams/code/trunk@3334 30fe4595-0a0c-4342-8851-515496e4dcbd

Former-commit-id: d43e042a3a934bc74cede329b65e526e100b65a2
Former-commit-id: d2897d7a96131ce406370c6d13550cd2b0ec991e
This commit is contained in:
pouillot 2011-02-07 09:35:37 +00:00
parent 7daa125973
commit 7616446533
2 changed files with 77 additions and 149 deletions

View file

@ -202,30 +202,39 @@ gfuiDrawCombobox(tGfuiObject *obj)
//Do nothing because children already draw themselves
}
static tGfuiCombobox*
gfuiGetCombobox(void *scr, int id)
{
tGfuiScreen *screen = (tGfuiScreen*)scr;
tGfuiObject* curObject = screen->objects;
if (curObject)
{
do
{
curObject = curObject->next;
if (curObject->id == id && curObject->widget == GFUI_COMBOBOX)
return &(curObject->u.combobox);
}
while (curObject != screen->objects);
}
return 0;
}
unsigned int
GfuiComboboxAddText(void *scr, int id, const char *text)
{
tGfuiObject *curObject;
tGfuiScreen *screen = (tGfuiScreen*)scr;
unsigned int index = 0;
tGfuiCombobox* combo = gfuiGetCombobox(scr, id);
curObject = screen->objects;
if (curObject != NULL) {
do {
curObject = curObject->next;
if (curObject->id == id) {
if (curObject->widget == GFUI_COMBOBOX)
if (combo)
{
tGfuiCombobox *combo = &(curObject->u.combobox);
combo->pInfo->vecChoices.push_back(text);
index = combo->pInfo->vecChoices.size();
GfuiLabelSetText(combo->scr, combo->labelId,
combo->pInfo->vecChoices[combo->pInfo->nPos].c_str());
}
return index;
}
} while (curObject != screen->objects);
}
return index;
}
@ -233,53 +242,23 @@ GfuiComboboxAddText(void *scr, int id, const char *text)
void
GfuiComboboxSetSelectedIndex(void *scr, int id, unsigned int index)
{
tGfuiObject *curObject;
tGfuiScreen *screen = (tGfuiScreen*)scr;
tGfuiCombobox* combo = gfuiGetCombobox(scr, id);
curObject = screen->objects;
if (curObject != NULL) {
do {
curObject = curObject->next;
if (curObject->id == id) {
if (curObject->widget == GFUI_COMBOBOX)
if (combo && index < combo->pInfo->vecChoices.size())
{
tGfuiCombobox *combo = &(curObject->u.combobox);
if (combo->pInfo->vecChoices.size()<= index)
return;
combo->pInfo->nPos = index;
GfuiLabelSetText(combo->scr, combo->labelId,
combo->pInfo->vecChoices[combo->pInfo->nPos].c_str());
}
return;
}
} while (curObject != screen->objects);
}
}
void
GfuiComboboxSetTextColor(void *scr, int id, const Color& color)
{
tGfuiObject *curObject;
tGfuiScreen *screen = (tGfuiScreen*)scr;
tGfuiCombobox* combo = gfuiGetCombobox(scr, id);
curObject = screen->objects;
if (curObject != NULL) {
do {
curObject = curObject->next;
if (curObject->id == id) {
if (curObject->widget == GFUI_COMBOBOX)
{
tGfuiCombobox *combo = &(curObject->u.combobox);
if (combo)
GfuiLabelSetColor(combo->scr, combo->labelId, color.GetPtr());
}
return;
}
} while (curObject != screen->objects);
}
return;
}
@ -287,120 +266,68 @@ GfuiComboboxSetTextColor(void *scr, int id, const Color& color)
void
GfuiComboboxSetPosition(void *scr, int id, unsigned int pos)
{
tGfuiObject *curObject;
tGfuiScreen *screen = (tGfuiScreen*)scr;
unsigned int index = 0;
tGfuiCombobox* combo = gfuiGetCombobox(scr, id);
curObject = screen->objects;
if (curObject != NULL)
{
do {
curObject = curObject->next;
if (curObject->id == id)
{
if (curObject->widget == GFUI_COMBOBOX)
{
tGfuiCombobox *combo = &(curObject->u.combobox);
if (combo)
combo->pInfo->nPos = pos;
}
return;
}
} while (curObject != screen->objects);
}
}
unsigned int
GfuiComboboxGetPosition(void *scr, int id)
{
tGfuiObject *curObject;
tGfuiScreen *screen = (tGfuiScreen*)scr;
unsigned int index = 0;
curObject = screen->objects;
if (curObject != NULL)
{
do
{
curObject = curObject->next;
if (curObject->id == id)
{
if (curObject->widget == GFUI_COMBOBOX)
{
tGfuiCombobox *combo = &(curObject->u.combobox);
return combo->pInfo->nPos;
}
return 0;
}
} while (curObject != screen->objects);
}
tGfuiCombobox* combo = gfuiGetCombobox(scr, id);
return 0;
if (combo)
index = combo->pInfo->nPos;
return index;
}
const char*
GfuiComboboxGetText(void *scr, int id)
{
tGfuiObject *curObject;
tGfuiScreen *screen = (tGfuiScreen*)scr;
char* pszText = 0;
const char* pszText = 0;
curObject = screen->objects;
if (curObject != NULL)
{
do
{
curObject = curObject->next;
if (curObject->id == id)
{
if (curObject->widget == GFUI_COMBOBOX)
{
tGfuiCombobox *combo = &(curObject->u.combobox);
if (combo->pInfo->nPos >= 0
&& combo->pInfo->nPos < combo->pInfo->vecChoices.size())
return combo->pInfo->vecChoices[combo->pInfo->nPos].c_str();
}
return 0;
}
} while (curObject != screen->objects);
}
tGfuiCombobox* combo = gfuiGetCombobox(scr, id);
if (combo && combo->pInfo->nPos >= 0 && combo->pInfo->nPos < combo->pInfo->vecChoices.size())
pszText = combo->pInfo->vecChoices[combo->pInfo->nPos].c_str();
return pszText;
}
unsigned
GfuiComboboxGetNumberOfChoices(void *scr, int id)
{
unsigned nChoices = 0;
tGfuiCombobox* combo = gfuiGetCombobox(scr, id);
if (combo)
nChoices = combo->pInfo->vecChoices.size();
return nChoices;
}
void
GfuiComboboxClear(void *scr, int id)
{
tGfuiObject *curObject;
tGfuiScreen *screen = (tGfuiScreen*)scr;
tGfuiCombobox* combo = gfuiGetCombobox(scr, id);
curObject = screen->objects;
if (curObject != NULL)
if (combo)
{
do
{
curObject = curObject->next;
if (curObject->id == id)
{
if (curObject->widget == GFUI_COMBOBOX)
{
tGfuiCombobox *combo = &(curObject->u.combobox);
combo->pInfo->nPos = 0;
combo->pInfo->vecChoices.clear();
GfuiLabelSetText(combo->scr, combo->labelId, "");
}
break;
}
} while (curObject != screen->objects);
}
}
void
gfuiReleaseCombobox(tGfuiObject *obj)
{
tGfuiCombobox *combobox;
combobox = &(obj->u.combobox);
delete combobox->pInfo;
delete obj->u.combobox.pInfo;
free(obj);
}

View file

@ -397,6 +397,7 @@ TGFCLIENT_API void GfuiComboboxSetPosition(void *scr, int id, unsigned int pos);
TGFCLIENT_API unsigned int GfuiComboboxGetPosition(void *scr, int id);
TGFCLIENT_API const char* GfuiComboboxGetText(void *scr, int id);
TGFCLIENT_API void GfuiComboboxClear(void *scr, int id);
TGFCLIENT_API unsigned GfuiComboboxGetNumberOfChoices(void *scr, int id);
TGFCLIENT_API int GfuiProgressbarCreate(void *scr, int x, int y, int w, int h,
const char *pszProgressbackImg, const char *progressbarimg,