# HG changeset patch # User alberth # Date 2009-10-18 13:40:11 # Node ID 8b545903c6d89cab4af70d83cc79e787fa7f07ff # Parent 3604b09589ee635db0f79c763a809a9e2e4ab843 (svn r17796) -Codechange: Move drawing of the industry info to its own function. diff --git a/src/industry_gui.cpp b/src/industry_gui.cpp --- a/src/industry_gui.cpp +++ b/src/industry_gui.cpp @@ -495,7 +495,13 @@ public: this->FindWindowPlacementAndResize(desc); } - virtual void OnPaint() + /** Draw the text in the #IVW_INFO panel. + * @param left Left edge of the panel. + * @param right Right edge of the panel. + * @param top Top edge of the panel. + * @return Expected position of the bottom edge of the panel. + */ + int DrawInfo(uint left, uint right, uint top) { Industry *i = Industry::Get(this->window_number); const IndustrySpec *ind = GetIndustrySpec(i->type); @@ -503,9 +509,6 @@ public: bool first = true; bool has_accept = false; - SetDParam(0, this->window_number); - this->DrawWidgets(); - if (HasBit(ind->callback_mask, CBM_IND_PRODUCTION_CARGO_ARRIVAL) || HasBit(ind->callback_mask, CBM_IND_PRODUCTION_256_TICKS)) { for (byte j = 0; j < lengthof(i->accepts_cargo); j++) { if (i->accepts_cargo[j] == CT_INVALID) continue; @@ -581,6 +584,15 @@ public: } } } + return y; + } + + virtual void OnPaint() + { + SetDParam(0, this->window_number); + this->DrawWidgets(); + + int y = this->DrawInfo(this->widget[IVW_INFO].left, this->widget[IVW_INFO].right, this->widget[IVW_INFO].top); if (y > this->widget[IVW_INFO].bottom) { this->SetDirty();