Project::OSiRiON - Git repositories
Project::OSiRiON
News . About . Screenshots . Downloads . Forum . Wiki . Tracker . Git
summaryrefslogtreecommitdiff
blob: 629863ac4c6c46427121b57ee61268766be79de5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
/*
   ui/tooltip.h
   This file is part of the Osirion project and is distributed under
   the terms of the GNU General Public License version 2
*/

#ifndef __INCLUDED_UI_TOOLTIP_H__
#define __INCLUDED_UI_TOOLTIP_H__

#include "ui/label.h"

namespace ui
{
	/**
	* @brief a widget displaying a tooltip.
	* This class makes sure only one Tooltip is globally visible.
	*/
class Tooltip : public Label
{
	public:
		Tooltip(Widget *parent);
		virtual ~Tooltip();
		
		/**
		 * @brief resize the tooltip
		 * */
		virtual void resize();
		
		/**
		 * @brief show the tooltip
		 * */
		virtual void show();

		/**
		 * @brief hide the tooltip
		 * */
		virtual void hide();
		
		/**
		* @brief draw event distributor
		* The default draw event distributor is overwritten to do nothing.
		* Tooltips are drawn separately because the need to be on top of everything else.
		* @see event_draw_global
		* */
		virtual void event_draw();
		
		/**
		* @brief global draw event distributor
		* This is called by the user interface to draw the tooltip after everything else.
		* */
		static void event_draw_global();
		
		/**
		 * @brief the tooltip that is currently visible, nullptr if no tooltip is currently shown
		 * 
		 * */
		static inline Tooltip *global()
		{
			return tooltip_global;
		}
		
	protected:
		/**
		 * @brief draw the tooltip
		 */
		virtual void draw();
		
		/**
		 * @brief draw the tooltip background
		 */
		virtual void draw_background();
		
	private:
		
		static Tooltip *tooltip_global;
};

}

#endif // __INCLUDED_UI_TOOLTIP_H__