From 98d3d86004520bfb32e8e4d90c9f0c5210828deb Mon Sep 17 00:00:00 2001 From: peter1138 Date: Wed, 6 Aug 2008 07:10:40 +0000 Subject: (svn r14004) -Codechange: Clean of drop down lists. Move empty item drawing to base ListItem Draw() function. Remove String() from base class. Pass correct width to Draw(). --- src/widgets/dropdown.cpp | 48 +++++++++++++++++------------------------------- 1 file changed, 17 insertions(+), 31 deletions(-) (limited to 'src/widgets/dropdown.cpp') diff --git a/src/widgets/dropdown.cpp b/src/widgets/dropdown.cpp index ecdba6a64..41975a59f 100644 --- a/src/widgets/dropdown.cpp +++ b/src/widgets/dropdown.cpp @@ -17,19 +17,18 @@ #include "../table/sprites.h" #include "table/strings.h" -StringID DropDownListItem::String() const +void DropDownListItem::Draw(int x, int y, uint width, uint height, bool sel, int bg_colour) const { - return STR_NULL; -} + int c1 = _colour_gradient[bg_colour][3]; + int c2 = _colour_gradient[bg_colour][7]; -uint DropDownListItem::Height(uint width) const -{ - return 10; + GfxFillRect(x + 1, y + 3, x + width - 2, y + 3, c1); + GfxFillRect(x + 1, y + 4, x + width - 2, y + 4, c2); } -StringID DropDownListStringItem::String() const +void DropDownListStringItem::Draw(int x, int y, uint width, uint height, bool sel, int bg_colour) const { - return this->string; + DrawStringTruncated(x + 2, y, this->String(), sel ? TC_WHITE : TC_BLACK, width); } StringID DropDownListParamStringItem::String() const @@ -38,11 +37,6 @@ StringID DropDownListParamStringItem::String() const return this->string; } -void DropDownListItem::Draw(int x, int y, uint width, uint height, bool sel) const -{ - DrawStringTruncated(x + 2, y, this->String(), sel ? TC_WHITE : TC_BLACK, x + width); -} - /** * Delete all items of a drop down list and the list itself * @param list List to delete. @@ -106,7 +100,7 @@ struct DropdownWindow : Window { int item_height = item->Height(width); if (y < item_height) { - if (item->masked || item->String() == STR_NULL) return false; + if (item->masked || !item->Selectable()) return false; value = item->result; return true; } @@ -125,7 +119,7 @@ struct DropdownWindow : Window { int y = 2; int sel = this->selected_index; - int width = this->widget[0].right - 3; + int width = this->widget[0].right - 2; int height = this->widget[0].bottom; int pos = this->vscroll.pos; @@ -139,22 +133,14 @@ struct DropdownWindow : Window { if (--pos >= 0) continue; if (y + item_height < height) { - if (item->String() != STR_NULL) { - if (sel == item->result) GfxFillRect(x + 1, y, x + width, y + item_height - 1, 0); - - item->Draw(x, y, width, 10, sel == item->result); - - if (item->masked) { - GfxFillRect(x, y, x + width, y + item_height - 1, - _colour_gradient[this->widget[0].color][5], FILLRECT_CHECKER - ); - } - } else { - int c1 = _colour_gradient[this->widget[0].color][3]; - int c2 = _colour_gradient[this->widget[0].color][7]; - - GfxFillRect(x + 1, y + 3, x + this->width - 5, y + 3, c1); - GfxFillRect(x + 1, y + 4, x + this->width - 5, y + 4, c2); + if (sel == item->result) GfxFillRect(x + 1, y, x + width - 1, y + item_height - 1, 0); + + item->Draw(x, y, width, height, sel == item->result, (TextColour)this->widget[0].color); + + if (item->masked) { + GfxFillRect(x, y, x + width - 1, y + item_height - 1, + _colour_gradient[this->widget[0].color][5], FILLRECT_CHECKER + ); } } y += item_height; -- cgit v1.2.3-70-g09d2