(svn r17354) -Codechange: make the subsidy gui nested

replace/41b28d7194a279bdc17475d4fbe2ea6ec885a466
rubidium 15 years ago
parent b2fef7c64e
commit af818b6c09

@ -37,16 +37,16 @@ enum SubsidyListWidgets {
}; };
struct SubsidyListWindow : Window { 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) virtual void OnClick(Point pt, int widget)
{ {
if (widget != SLW_PANEL) return; 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; if (y < 0) return;
@ -69,7 +69,7 @@ struct SubsidyListWindow : Window {
if (y < 0) return; if (y < 0) return;
} }
y -= 11; // "Services already subsidised:" y -= FONT_HEIGHT_NORMAL + WD_FRAMERECT_TOP; // "Services already subsidised:"
if (y < 0) return; if (y < 0) return;
FOR_ALL_SUBSIDIES(s) { FOR_ALL_SUBSIDIES(s) {
@ -113,28 +113,32 @@ struct SubsidyListWindow : Window {
virtual void OnPaint() virtual void OnPaint()
{ {
YearMonthDay ymd;
const Subsidy *s;
this->DrawWidgets(); this->DrawWidgets();
}
virtual void DrawWidget(const Rect &r, int widget) const
{
if (widget != SLW_PANEL) return;
YearMonthDay ymd;
ConvertDateToYMD(_date, &ymd); ConvertDateToYMD(_date, &ymd);
int right = this->widget[SLW_PANEL].right; int right = r.right - WD_FRAMERECT_RIGHT;
int y = this->widget[SLW_PANEL].top + 1; int y = r.top + WD_FRAMERECT_TOP;
int x = this->widget[SLW_PANEL].left + 1; int x = r.left + WD_FRAMERECT_LEFT;
/* Section for drawing the offered subisidies */ /* Section for drawing the offered subisidies */
DrawString(x, right, y, STR_SUBSIDIES_OFFERED_TITLE); DrawString(x, right, y, STR_SUBSIDIES_OFFERED_TITLE);
y += FONT_HEIGHT_NORMAL; y += FONT_HEIGHT_NORMAL;
uint num = 0; uint num = 0;
const Subsidy *s;
FOR_ALL_SUBSIDIES(s) { FOR_ALL_SUBSIDIES(s) {
if (!s->IsAwarded()) { if (!s->IsAwarded()) {
/* Displays the two offered towns */ /* Displays the two offered towns */
SetupSubsidyDecodeParam(s, 1); SetupSubsidyDecodeParam(s, 1);
SetDParam(7, _date - ymd.day + s->remaining * 32); 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; y += FONT_HEIGHT_NORMAL;
num++; num++;
@ -142,13 +146,13 @@ struct SubsidyListWindow : Window {
} }
if (num == 0) { if (num == 0) {
DrawString(x + 2, right - 2, y, STR_SUBSIDIES_NONE); DrawString(x, right, y, STR_SUBSIDIES_NONE);
y += FONT_HEIGHT_NORMAL; y += FONT_HEIGHT_NORMAL;
} }
/* Section for drawing the already granted subisidies */ /* Section for drawing the already granted subisidies */
DrawString(x, right, y + 1, STR_SUBSIDIES_SUBSIDISED_TITLE); DrawString(x, right, y + WD_FRAMERECT_TOP, STR_SUBSIDIES_SUBSIDISED_TITLE);
y += FONT_HEIGHT_NORMAL; y += FONT_HEIGHT_NORMAL + WD_FRAMERECT_TOP;
num = 0; num = 0;
FOR_ALL_SUBSIDIES(s) { FOR_ALL_SUBSIDIES(s) {
@ -158,28 +162,17 @@ struct SubsidyListWindow : Window {
SetDParam(8, _date - ymd.day + s->remaining * 32); SetDParam(8, _date - ymd.day + s->remaining * 32);
/* Displays the two connected stations */ /* 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; y += FONT_HEIGHT_NORMAL;
num++; 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[] = { static const NWidgetPart _nested_subsidies_list_widgets[] = {
NWidget(NWID_HORIZONTAL), NWidget(NWID_HORIZONTAL),
NWidget(WWT_CLOSEBOX, COLOUR_BROWN, SLW_CLOSEBOX), 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, WDP_AUTO, WDP_AUTO, 320, 127, 320, 127,
WC_SUBSIDIES_LIST, WC_NONE, WC_SUBSIDIES_LIST, WC_NONE,
WDF_STD_TOOLTIPS | WDF_STD_BTN | WDF_DEF_WIDGET | WDF_STICKY_BUTTON | WDF_RESIZABLE, 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)
); );

Loading…
Cancel
Save