summaryrefslogtreecommitdiff
path: root/indra/newview/lltoolview.h
blob: 7c7cb581dd6688b8cbc229bd030226ac94db4dc1 (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
/** 
 * @file lltoolview.h
 * @brief UI container for tools.
 *
 * Copyright (c) 2001-$CurrentYear$, Linden Research, Inc.
 * $License$
 */

#ifndef LL_LLTOOLVIEW_H
#define LL_LLTOOLVIEW_H

// requires stdtypes.h
#include "linked_lists.h"
#include "llpanel.h"

// forward declares
class LLTool;
class LLButton;

class LLToolView;


// Utility class, container for the package of information we need about
// each tool.  The package can either point directly to a tool, or indirectly
// to another view of tools.
class LLToolContainer
{
public:
	LLToolContainer(LLToolView* parent);
	~LLToolContainer();

public:
	LLToolView*		mParent;		// toolview that owns this container
	LLButton*		mButton;
	LLPanel*		mPanel;
	LLTool*			mTool;			// if not NULL, this is a tool ref
};


// A view containing automatically arranged button icons representing
// tools.  The icons sit on top of panels containing options for each
// tool.
class LLToolView
:	public LLView
{
public:
	LLToolView(const std::string& name, const LLRect& rect);
	~LLToolView();

	virtual void	draw();			// handle juggling tool button highlights, panel visibility

	static void		onClickToolButton(void* container);

	void			addTool(const LLString& icon_off, const LLString& icon_on, LLPanel* panel, LLTool* tool, LLView* hoverView, const char* label);

	LLView*			getCurrentHoverView();

private:
	LLRect			getButtonRect(S32 button_index);	// return rect for button to add, zero-based index
	LLToolContainer	*findToolContainer(LLTool *tool);


private:
	LLLinkedList
		<LLToolContainer>	mContainList;
	S32						mButtonCount;			// used to compute rectangles
};

#endif