aboutsummaryrefslogtreecommitdiff
path: root/src/crepe/api/Button.h
blob: e986c04ed64054e7a9ef30573a77d51d438d1cb4 (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
#pragma once

#include "../types.h"

#include "UIObject.h"

namespace crepe {

/**
 * \brief Button component.
 * 
 * This component creates a clickable surface at the transform location with the specified width and height.
 * 
 * The Button can be used in scripts by subscribing a EventHandler to the following events:
 * - ButtonPressEvent
 * - ButtonEnterEvent
 * - ButtonExitEvent
 * \see EventManager
 * 
 */
class Button : public UIObject {
public:
	struct Data {
		//! variable indicating if transform is relative to camera(false) or world(true)
		bool world_space = false;
	};

public:
	/**
	 * \brief Constructs a Button with the specified game object ID and dimensions.
	 *
	 * \param id The unique ID of the game object associated with this button.
	 * \param dimensions The width and height of the UIObject
	 * \param offset The offset relative this GameObjects Transform
	 * \param data additional data the button has
	 */
	Button(
		game_object_id_t id, const vec2 & dimensions, const Data & data,
		const vec2 & offset = {0, 0}
	);
	/**
	 * \brief Get the maximum number of instances for this component
	 *
	 * Since the button Event transfers the GameObject Metadata it will be the same for each button so only one button is allowed per GameObject	
	 * 
	 * \return 1
	 */
	virtual int get_instances_max() const { return 1; }

public:
	Data data;

private:
	//! friend relation hover variable
	friend class InputSystem;
	//! Indicates whether the mouse is currently hovering over the button
	bool hover = false;
};

} // namespace crepe