Changeset - r13397:b419679e3595
[Not reviewed]
master
0 1 0
alberth - 15 years ago 2009-10-31 13:01:52
alberth@openttd.org
(svn r17916) -Codechange: Make tooltips window use pure nested widgets.
1 file changed with 40 insertions and 22 deletions:
0 comments (0 inline, 0 general)
src/misc_gui.cpp
Show inline comments
 
@@ -773,26 +773,28 @@ void HideFillingPercent(TextEffectID *te
 
	*te_id = INVALID_TE_ID;
 
}
 

	
 
static const Widget _tooltips_widgets[] = {
 
{      WWT_PANEL,   RESIZE_NONE,  COLOUR_GREY,     0,   199,     0,    31, 0x0, STR_NULL},
 
{   WIDGETS_END},
 
};
 

	
 
static const NWidgetPart _nested_tooltips_widgets[] = {
 
	NWidget(WWT_PANEL, COLOUR_GREY, 0), SetMinimalSize(200, 32), EndContainer(),
 
};
 

	
 
/** Window class for displaying a tooltip. */
 
static const WindowDesc _tool_tips_desc(
 
	100, 100, 0, 0, 0, 0, // Coordinates and sizes are not used,
 
	WC_TOOLTIPS, WC_NONE,
 
	0,
 
	NULL, _nested_tooltips_widgets, lengthof(_nested_tooltips_widgets)
 
);
 

	
 
/** Window for displaying a tooltip. */
 
struct TooltipsWindow : public Window
 
{
 
	StringID string_id;         ///< String to display as tooltip.
 
	byte paramcount;            ///< Number of string parameters in #string_id.
 
	uint64 params[5];           ///< The string parameters.
 
	bool use_left_mouse_button; ///< Wait for left mouse button to close window (else, wait for right button).
 
	Point window_pos;           ///< Position of the window.
 
	Dimension window_size;      ///< Size of the window.
 

	
 
	TooltipsWindow(int x, int y, const Dimension &window_size, const Widget *widget,
 
								 StringID str, uint paramcount, const uint64 params[], bool use_left_mouse_button) :
 
			Window(x, y, window_size.width, window_size.height, WC_TOOLTIPS, widget)
 
	TooltipsWindow(int x, int y, const Dimension &window_size, StringID str, uint paramcount, const uint64 params[], bool use_left_mouse_button) : Window()
 
	{
 
		this->string_id = str;
 
		assert_compile(sizeof(this->params[0]) == sizeof(params[0]));
 
@@ -801,22 +803,42 @@ struct TooltipsWindow : public Window
 
		this->paramcount = paramcount;
 
		this->use_left_mouse_button = use_left_mouse_button;
 

	
 
		this->window_pos.x = x;
 
		this->window_pos.y = y;
 
		this->window_size = window_size;
 

	
 
		this->InitNested(&_tool_tips_desc);
 

	
 
		this->flags4 &= ~WF_WHITE_BORDER_MASK; // remove white-border from tooltip
 
		this->widget[0].right = width;
 
		this->widget[0].bottom = height;
 

	
 
		FindWindowPlacementAndResize(width, height);
 
	}
 

	
 
	virtual void OnPaint()
 
	virtual Point OnInitialPosition(const WindowDesc *desc, int16 sm_width, int16 sm_height, int window_number)
 
	{
 
		return this->window_pos;
 
	}
 

	
 
	virtual void UpdateWidgetSize(int widget, Dimension *size, const Dimension &padding, Dimension *resize)
 
	{
 
		GfxFillRect(0, 0, this->width - 1, this->height - 1, 0);
 
		GfxFillRect(1, 1, this->width - 2, this->height - 2, 0x44);
 
		/* There is only one widget. */
 
		*size = this->window_size;
 
	}
 

	
 
	virtual void DrawWidget(const Rect &r, int widget) const
 
	{
 
		/* There is only one widget. */
 
		GfxFillRect(r.left, r.top, r.right, r.bottom, 0);
 
		GfxFillRect(r.left + 1, r.top + 1, r.right - 1, r.bottom - 1, 0x44);
 

	
 
		for (uint arg = 0; arg < this->paramcount; arg++) {
 
			SetDParam(arg, this->params[arg]);
 
		}
 
		DrawStringMultiLine(3, this->width - 3, 0, this->height, this->string_id, TC_FROMSTRING, SA_CENTER);
 
		DrawStringMultiLine(r.left + WD_FRAMERECT_LEFT, r.right - WD_FRAMERECT_RIGHT, r.top + WD_FRAMERECT_TOP, r.bottom - WD_FRAMERECT_BOTTOM, this->string_id, TC_FROMSTRING, SA_CENTER);
 
	}
 

	
 

	
 
	virtual void OnPaint()
 
	{
 
		this->DrawWidgets();
 
	}
 

	
 
	virtual void OnMouseLoop()
 
@@ -835,8 +857,6 @@ struct TooltipsWindow : public Window
 
 */
 
void GuiShowTooltips(StringID str, uint paramcount, const uint64 params[], bool use_left_mouse_button)
 
{
 
	static Widget *generated_tooltips_widgets = NULL;
 

	
 
	DeleteWindowById(WC_TOOLTIPS, 0);
 

	
 
	if (str == STR_NULL) return;
 
@@ -858,9 +878,7 @@ void GuiShowTooltips(StringID str, uint 
 
	if (y + (int)br.height > _screen.height - 12) y = _cursor.pos.y + _cursor.offs.y - (int)br.height - 5;
 
	int x = Clamp(_cursor.pos.x - (int)(br.width >> 1), 0, _screen.width - (int)br.width);
 

	
 
	const Widget *wid = InitializeWidgetArrayFromNestedWidgets(_nested_tooltips_widgets, lengthof(_nested_tooltips_widgets),
 
													_tooltips_widgets, &generated_tooltips_widgets);
 
	new TooltipsWindow(x, y, br, wid, str, paramcount, params, use_left_mouse_button);
 
	new TooltipsWindow(x, y, br, str, paramcount, params, use_left_mouse_button);
 
}
 

	
 

	
0 comments (0 inline, 0 general)