From af818b6c09f16d8aeb4be4f3c5c339177816a95e Mon Sep 17 00:00:00 2001 From: rubidium Date: Tue, 1 Sep 2009 19:29:16 +0000 Subject: (svn r17354) -Codechange: make the subsidy gui nested --- src/subsidy_gui.cpp | 49 +++++++++++++++++++++---------------------------- 1 file changed, 21 insertions(+), 28 deletions(-) (limited to 'src') diff --git a/src/subsidy_gui.cpp b/src/subsidy_gui.cpp index c2f9f191d..3fae7da99 100644 --- a/src/subsidy_gui.cpp +++ b/src/subsidy_gui.cpp @@ -37,16 +37,16 @@ enum SubsidyListWidgets { }; struct SubsidyListWindow : Window { - SubsidyListWindow(const WindowDesc *desc, WindowNumber window_number) : Window(desc, window_number) + SubsidyListWindow(const WindowDesc *desc, WindowNumber window_number) : Window() { - this->FindWindowPlacementAndResize(desc); + this->InitNested(desc, window_number); } virtual void OnClick(Point pt, int widget) { if (widget != SLW_PANEL) return; - int y = pt.y - this->widget[SLW_PANEL].top - FONT_HEIGHT_NORMAL - 1; // Skip 'subsidies on offer' line + int y = pt.y - this->nested_array[SLW_PANEL]->pos_y - FONT_HEIGHT_NORMAL - WD_FRAMERECT_TOP; // Skip 'subsidies on offer' line if (y < 0) return; @@ -69,7 +69,7 @@ struct SubsidyListWindow : Window { if (y < 0) return; } - y -= 11; // "Services already subsidised:" + y -= FONT_HEIGHT_NORMAL + WD_FRAMERECT_TOP; // "Services already subsidised:" if (y < 0) return; FOR_ALL_SUBSIDIES(s) { @@ -113,28 +113,32 @@ struct SubsidyListWindow : Window { virtual void OnPaint() { - YearMonthDay ymd; - const Subsidy *s; - this->DrawWidgets(); + } + + virtual void DrawWidget(const Rect &r, int widget) const + { + if (widget != SLW_PANEL) return; + YearMonthDay ymd; ConvertDateToYMD(_date, &ymd); - int right = this->widget[SLW_PANEL].right; - int y = this->widget[SLW_PANEL].top + 1; - int x = this->widget[SLW_PANEL].left + 1; + int right = r.right - WD_FRAMERECT_RIGHT; + int y = r.top + WD_FRAMERECT_TOP; + int x = r.left + WD_FRAMERECT_LEFT; /* Section for drawing the offered subisidies */ DrawString(x, right, y, STR_SUBSIDIES_OFFERED_TITLE); y += FONT_HEIGHT_NORMAL; uint num = 0; + const Subsidy *s; FOR_ALL_SUBSIDIES(s) { if (!s->IsAwarded()) { /* Displays the two offered towns */ SetupSubsidyDecodeParam(s, 1); SetDParam(7, _date - ymd.day + s->remaining * 32); - DrawString(x + 2, right - 2, y, STR_SUBSIDIES_OFFERED_FROM_TO); + DrawString(x, right, y, STR_SUBSIDIES_OFFERED_FROM_TO); y += FONT_HEIGHT_NORMAL; num++; @@ -142,13 +146,13 @@ struct SubsidyListWindow : Window { } if (num == 0) { - DrawString(x + 2, right - 2, y, STR_SUBSIDIES_NONE); + DrawString(x, right, y, STR_SUBSIDIES_NONE); y += FONT_HEIGHT_NORMAL; } /* Section for drawing the already granted subisidies */ - DrawString(x, right, y + 1, STR_SUBSIDIES_SUBSIDISED_TITLE); - y += FONT_HEIGHT_NORMAL; + DrawString(x, right, y + WD_FRAMERECT_TOP, STR_SUBSIDIES_SUBSIDISED_TITLE); + y += FONT_HEIGHT_NORMAL + WD_FRAMERECT_TOP; num = 0; FOR_ALL_SUBSIDIES(s) { @@ -158,28 +162,17 @@ struct SubsidyListWindow : Window { SetDParam(8, _date - ymd.day + s->remaining * 32); /* Displays the two connected stations */ - DrawString(x + 2, right - 2, y, STR_SUBSIDIES_SUBSIDISED_FROM_TO); + DrawString(x, right, y, STR_SUBSIDIES_SUBSIDISED_FROM_TO); y += FONT_HEIGHT_NORMAL; num++; } } - if (num == 0) DrawString(x + 2, right - 2, y, STR_SUBSIDIES_NONE); + if (num == 0) DrawString(x, right, y, STR_SUBSIDIES_NONE); } }; -static const Widget _subsidies_list_widgets[] = { -{ WWT_CLOSEBOX, RESIZE_NONE, COLOUR_BROWN, 0, 10, 0, 13, STR_BLACK_CROSS, STR_TOOLTIP_CLOSE_WINDOW}, // SLW_CLOSEBOX -{ WWT_CAPTION, RESIZE_RIGHT, COLOUR_BROWN, 11, 307, 0, 13, STR_SUBSIDIES_CAPTION, STR_TOOLTIP_WINDOW_TITLE_DRAG_THIS}, // SLW_CAPTION -{ WWT_STICKYBOX, RESIZE_LR, COLOUR_BROWN, 308, 319, 0, 13, STR_NULL, STR_TOOLTIP_STICKY}, // SLW_STICKYBOX -{ WWT_PANEL, RESIZE_RB, COLOUR_BROWN, 0, 307, 14, 126, 0x0, STR_SUBSIDIES_TOOLTIP_CLICK_ON_SERVICE_TO_CENTER}, // SLW_PANEL -{ WWT_SCROLLBAR, RESIZE_LRB, COLOUR_BROWN, 308, 319, 14, 114, 0x0, STR_TOOLTIP_VSCROLL_BAR_SCROLLS_LIST}, // SLW_SCROLLBAR -{ WWT_RESIZEBOX, RESIZE_LRTB, COLOUR_BROWN, 308, 319, 115, 126, 0x0, STR_TOOLTIP_RESIZE}, // SLW_RESIZEBOX - -{ WIDGETS_END}, -}; - static const NWidgetPart _nested_subsidies_list_widgets[] = { NWidget(NWID_HORIZONTAL), NWidget(WWT_CLOSEBOX, COLOUR_BROWN, SLW_CLOSEBOX), @@ -199,7 +192,7 @@ static const WindowDesc _subsidies_list_desc( WDP_AUTO, WDP_AUTO, 320, 127, 320, 127, WC_SUBSIDIES_LIST, WC_NONE, WDF_STD_TOOLTIPS | WDF_STD_BTN | WDF_DEF_WIDGET | WDF_STICKY_BUTTON | WDF_RESIZABLE, - _subsidies_list_widgets, _nested_subsidies_list_widgets, lengthof(_nested_subsidies_list_widgets) + NULL, _nested_subsidies_list_widgets, lengthof(_nested_subsidies_list_widgets) ); -- cgit v1.2.3-54-g00ecf