Selaa lähdekoodia

Merge pull request #75959 from ShadyChibinko/tab_metadata_3x

[3.x] Add tab Metadata to Tabs & TabContainer
Rémi Verschelde 2 vuotta sitten
vanhempi
commit
f742d98679

+ 15 - 0
doc/classes/TabContainer.xml

@@ -72,6 +72,13 @@
 				Returns the index of the tab at local coordinates [code]point[/code]. Returns [code]-1[/code] if the point is outside the control boundaries or if there's no tab at the queried position.
 			</description>
 		</method>
+		<method name="get_tab_metadata" qualifiers="const">
+			<return type="Variant" />
+			<argument index="0" name="tab_idx" type="int" />
+			<description>
+				Returns the metadata value set to the tab at index [code]tab_idx[/code]. If no metadata was previously set, returns [code]null[/code] by default.
+			</description>
+		</method>
 		<method name="get_tab_title" qualifiers="const">
 			<return type="String" />
 			<argument index="0" name="tab_idx" type="int" />
@@ -116,6 +123,14 @@
 				Sets an icon for the tab at index [code]tab_idx[/code].
 			</description>
 		</method>
+		<method name="set_tab_metadata">
+			<return type="void" />
+			<argument index="0" name="tab_idx" type="int" />
+			<argument index="1" name="metadata" type="Variant" />
+			<description>
+				Sets the metadata value for the tab at index [code]tab_idx[/code].
+			</description>
+		</method>
 		<method name="set_tab_title">
 			<return type="void" />
 			<argument index="0" name="tab_idx" type="int" />

+ 15 - 0
doc/classes/Tabs.xml

@@ -69,6 +69,13 @@
 				Returns the [Texture] for the tab at index [code]tab_idx[/code] or [code]null[/code] if the tab has no [Texture].
 			</description>
 		</method>
+		<method name="get_tab_metadata" qualifiers="const">
+			<return type="Variant" />
+			<argument index="0" name="tab_idx" type="int" />
+			<description>
+				Returns the metadata value set to the tab at index [code]tab_idx[/code]. If no metadata was previously set, returns [code]null[/code] by default.
+			</description>
+		</method>
 		<method name="get_tab_offset" qualifiers="const">
 			<return type="int" />
 			<description>
@@ -141,6 +148,14 @@
 				Sets an [code]icon[/code] for the tab at index [code]tab_idx[/code].
 			</description>
 		</method>
+		<method name="set_tab_metadata">
+			<return type="void" />
+			<argument index="0" name="tab_idx" type="int" />
+			<argument index="1" name="metadata" type="Variant" />
+			<description>
+				Sets the metadata value for the tab at index [code]tab_idx[/code].
+			</description>
+		</method>
 		<method name="set_tab_title">
 			<return type="void" />
 			<argument index="0" name="tab_idx" type="int" />

+ 18 - 0
scene/gui/tab_container.cpp

@@ -931,6 +931,22 @@ bool TabContainer::get_tab_hidden(int p_tab) const {
 	}
 }
 
+void TabContainer::set_tab_metadata(int p_tab, const Variant &p_metadata) {
+	Control *child = get_tab_control(p_tab);
+	ERR_FAIL_COND(!child);
+	child->set_meta("_tab_metadata", p_metadata);
+}
+
+Variant TabContainer::get_tab_metadata(int p_tab) const {
+	Control *child = get_tab_control(p_tab);
+	ERR_FAIL_COND_V(!child, Variant());
+	if (child->has_meta("_tab_metadata")) {
+		return child->get_meta("_tab_metadata");
+	} else {
+		return Variant();
+	}
+}
+
 void TabContainer::get_translatable_strings(List<String> *p_strings) const {
 	Vector<Control *> tabs = _get_tabs();
 	for (int i = 0; i < tabs.size(); i++) {
@@ -1047,6 +1063,8 @@ void TabContainer::_bind_methods() {
 	ClassDB::bind_method(D_METHOD("get_tab_disabled", "tab_idx"), &TabContainer::get_tab_disabled);
 	ClassDB::bind_method(D_METHOD("set_tab_hidden", "tab_idx", "hidden"), &TabContainer::set_tab_hidden);
 	ClassDB::bind_method(D_METHOD("get_tab_hidden", "tab_idx"), &TabContainer::get_tab_hidden);
+	ClassDB::bind_method(D_METHOD("set_tab_metadata", "tab_idx", "metadata"), &TabContainer::set_tab_metadata);
+	ClassDB::bind_method(D_METHOD("get_tab_metadata", "tab_idx"), &TabContainer::get_tab_metadata);
 	ClassDB::bind_method(D_METHOD("get_tab_idx_at_point", "point"), &TabContainer::get_tab_idx_at_point);
 	ClassDB::bind_method(D_METHOD("set_popup", "popup"), &TabContainer::set_popup);
 	ClassDB::bind_method(D_METHOD("get_popup"), &TabContainer::get_popup);

+ 3 - 0
scene/gui/tab_container.h

@@ -107,6 +107,9 @@ public:
 	void set_tab_hidden(int p_tab, bool p_hidden);
 	bool get_tab_hidden(int p_tab) const;
 
+	void set_tab_metadata(int p_tab, const Variant &p_metadata);
+	Variant get_tab_metadata(int p_tab) const;
+
 	int get_tab_count() const;
 	void set_current_tab(int p_current);
 	int get_current_tab() const;

+ 17 - 0
scene/gui/tabs.cpp

@@ -474,6 +474,21 @@ bool Tabs::get_tab_disabled(int p_tab) const {
 	return tabs[p_tab].disabled;
 }
 
+void Tabs::set_tab_metadata(int p_tab, const Variant &p_metadata) {
+	ERR_FAIL_INDEX(p_tab, tabs.size());
+
+	if (tabs[p_tab].metadata == p_metadata) {
+		return;
+	}
+
+	tabs.write[p_tab].metadata = p_metadata;
+}
+
+Variant Tabs::get_tab_metadata(int p_tab) const {
+	ERR_FAIL_INDEX_V(p_tab, tabs.size(), Variant());
+	return tabs[p_tab].metadata;
+}
+
 void Tabs::set_tab_right_button(int p_tab, const Ref<Texture> &p_right_button) {
 	ERR_FAIL_INDEX(p_tab, tabs.size());
 	tabs.write[p_tab].right_button = p_right_button;
@@ -963,6 +978,8 @@ void Tabs::_bind_methods() {
 	ClassDB::bind_method(D_METHOD("get_tab_button_icon", "tab_idx"), &Tabs::get_tab_right_button);
 	ClassDB::bind_method(D_METHOD("set_tab_disabled", "tab_idx", "disabled"), &Tabs::set_tab_disabled);
 	ClassDB::bind_method(D_METHOD("get_tab_disabled", "tab_idx"), &Tabs::get_tab_disabled);
+	ClassDB::bind_method(D_METHOD("set_tab_metadata", "tab_idx", "metadata"), &Tabs::set_tab_metadata);
+	ClassDB::bind_method(D_METHOD("get_tab_metadata", "tab_idx"), &Tabs::get_tab_metadata);
 	ClassDB::bind_method(D_METHOD("remove_tab", "tab_idx"), &Tabs::remove_tab);
 	ClassDB::bind_method(D_METHOD("add_tab", "title", "icon"), &Tabs::add_tab, DEFVAL(""), DEFVAL(Ref<Texture>()));
 	ClassDB::bind_method(D_METHOD("set_tab_align", "align"), &Tabs::set_tab_align);

+ 4 - 0
scene/gui/tabs.h

@@ -60,6 +60,7 @@ private:
 		Ref<Texture> icon;
 		int ofs_cache;
 		bool disabled;
+		Variant metadata;
 		int size_cache;
 		int size_text;
 		int x_cache;
@@ -124,6 +125,9 @@ public:
 	void set_tab_disabled(int p_tab, bool p_disabled);
 	bool get_tab_disabled(int p_tab) const;
 
+	void set_tab_metadata(int p_tab, const Variant &p_metadata);
+	Variant get_tab_metadata(int p_tab) const;
+
 	void set_tab_right_button(int p_tab, const Ref<Texture> &p_right_button);
 	Ref<Texture> get_tab_right_button(int p_tab) const;