2014-02-10 02:10:30 +01:00
/*************************************************************************/
/* theme.cpp */
/*************************************************************************/
/* This file is part of: */
/* GODOT ENGINE */
2017-08-27 14:16:55 +02:00
/* https://godotengine.org */
2014-02-10 02:10:30 +01:00
/*************************************************************************/
2021-01-01 20:13:46 +01:00
/* Copyright (c) 2007-2021 Juan Linietsky, Ariel Manzur. */
/* Copyright (c) 2014-2021 Godot Engine contributors (cf. AUTHORS.md). */
2014-02-10 02:10:30 +01:00
/* */
/* Permission is hereby granted, free of charge, to any person obtaining */
/* a copy of this software and associated documentation files (the */
/* "Software"), to deal in the Software without restriction, including */
/* without limitation the rights to use, copy, modify, merge, publish, */
/* distribute, sublicense, and/or sell copies of the Software, and to */
/* permit persons to whom the Software is furnished to do so, subject to */
/* the following conditions: */
/* */
/* The above copyright notice and this permission notice shall be */
/* included in all copies or substantial portions of the Software. */
/* */
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/*************************************************************************/
2018-01-05 00:50:27 +01:00
2014-02-10 02:10:30 +01:00
# include "theme.h"
2018-09-11 18:13:45 +02:00
# include "core/print_string.h"
2014-02-10 02:10:30 +01:00
2021-10-04 16:09:32 +02:00
// Universal Theme resources used when no other theme has the item.
Ref < Theme > Theme : : default_theme ;
Ref < Theme > Theme : : project_default_theme ;
2019-11-09 00:13:28 +01:00
2021-10-04 16:09:32 +02:00
// Universal default values, final fallback for every theme.
Ref < Texture > Theme : : default_icon ;
Ref < StyleBox > Theme : : default_style ;
Ref < Font > Theme : : default_font ;
2019-10-23 04:08:23 +02:00
2021-10-04 16:09:32 +02:00
// Dynamic properties.
2017-03-05 16:44:50 +01:00
bool Theme : : _set ( const StringName & p_name , const Variant & p_value ) {
String sname = p_name ;
2014-02-10 02:10:30 +01:00
2017-03-05 16:44:50 +01:00
if ( sname . find ( " / " ) ! = - 1 ) {
String type = sname . get_slicec ( ' / ' , 1 ) ;
String node_type = sname . get_slicec ( ' / ' , 0 ) ;
String name = sname . get_slicec ( ' / ' , 2 ) ;
2014-02-10 02:10:30 +01:00
2017-03-05 16:44:50 +01:00
if ( type = = " icons " ) {
set_icon ( name , node_type , p_value ) ;
} else if ( type = = " styles " ) {
set_stylebox ( name , node_type , p_value ) ;
} else if ( type = = " fonts " ) {
set_font ( name , node_type , p_value ) ;
} else if ( type = = " colors " ) {
set_color ( name , node_type , p_value ) ;
} else if ( type = = " constants " ) {
set_constant ( name , node_type , p_value ) ;
2021-05-05 12:44:11 +02:00
} else {
2014-02-10 02:10:30 +01:00
return false ;
2021-05-05 12:44:11 +02:00
}
2014-02-10 02:10:30 +01:00
return true ;
}
return false ;
}
2017-03-05 16:44:50 +01:00
bool Theme : : _get ( const StringName & p_name , Variant & r_ret ) const {
String sname = p_name ;
2014-02-10 02:10:30 +01:00
2017-03-05 16:44:50 +01:00
if ( sname . find ( " / " ) ! = - 1 ) {
String type = sname . get_slicec ( ' / ' , 1 ) ;
String node_type = sname . get_slicec ( ' / ' , 0 ) ;
String name = sname . get_slicec ( ' / ' , 2 ) ;
2014-02-10 02:10:30 +01:00
2017-03-05 16:44:50 +01:00
if ( type = = " icons " ) {
2021-05-05 12:44:11 +02:00
if ( ! has_icon ( name , node_type ) ) {
2017-03-05 16:44:50 +01:00
r_ret = Ref < Texture > ( ) ;
2021-05-05 12:44:11 +02:00
} else {
2017-03-05 16:44:50 +01:00
r_ret = get_icon ( name , node_type ) ;
2021-05-05 12:44:11 +02:00
}
2017-03-05 16:44:50 +01:00
} else if ( type = = " styles " ) {
2021-05-05 12:44:11 +02:00
if ( ! has_stylebox ( name , node_type ) ) {
2017-03-05 16:44:50 +01:00
r_ret = Ref < StyleBox > ( ) ;
2021-05-05 12:44:11 +02:00
} else {
2017-03-05 16:44:50 +01:00
r_ret = get_stylebox ( name , node_type ) ;
2021-05-05 12:44:11 +02:00
}
2017-03-05 16:44:50 +01:00
} else if ( type = = " fonts " ) {
2021-05-05 12:44:11 +02:00
if ( ! has_font ( name , node_type ) ) {
2017-03-05 16:44:50 +01:00
r_ret = Ref < Font > ( ) ;
2021-05-05 12:44:11 +02:00
} else {
2017-03-05 16:44:50 +01:00
r_ret = get_font ( name , node_type ) ;
2021-05-05 12:44:11 +02:00
}
2017-03-05 16:44:50 +01:00
} else if ( type = = " colors " ) {
r_ret = get_color ( name , node_type ) ;
} else if ( type = = " constants " ) {
r_ret = get_constant ( name , node_type ) ;
2021-05-05 12:44:11 +02:00
} else {
2014-02-10 02:10:30 +01:00
return false ;
2021-05-05 12:44:11 +02:00
}
2014-02-10 02:10:30 +01:00
return true ;
}
return false ;
}
2017-03-05 16:44:50 +01:00
void Theme : : _get_property_list ( List < PropertyInfo > * p_list ) const {
2015-05-04 03:37:10 +02:00
List < PropertyInfo > list ;
2021-05-04 16:00:45 +02:00
const StringName * key = nullptr ;
2016-03-09 00:00:52 +01:00
2017-03-05 16:44:50 +01:00
while ( ( key = icon_map . next ( key ) ) ) {
2021-05-04 16:00:45 +02:00
const StringName * key2 = nullptr ;
2016-03-09 00:00:52 +01:00
2017-03-05 16:44:50 +01:00
while ( ( key2 = icon_map [ * key ] . next ( key2 ) ) ) {
list . push_back ( PropertyInfo ( Variant : : OBJECT , String ( ) + * key + " /icons/ " + * key2 , PROPERTY_HINT_RESOURCE_TYPE , " Texture " , PROPERTY_USAGE_DEFAULT | PROPERTY_USAGE_STORE_IF_NULL ) ) ;
2014-02-10 02:10:30 +01:00
}
}
2016-03-09 00:00:52 +01:00
2021-05-04 16:00:45 +02:00
key = nullptr ;
2016-03-09 00:00:52 +01:00
2017-03-05 16:44:50 +01:00
while ( ( key = style_map . next ( key ) ) ) {
2021-05-04 16:00:45 +02:00
const StringName * key2 = nullptr ;
2016-03-09 00:00:52 +01:00
2017-03-05 16:44:50 +01:00
while ( ( key2 = style_map [ * key ] . next ( key2 ) ) ) {
list . push_back ( PropertyInfo ( Variant : : OBJECT , String ( ) + * key + " /styles/ " + * key2 , PROPERTY_HINT_RESOURCE_TYPE , " StyleBox " , PROPERTY_USAGE_DEFAULT | PROPERTY_USAGE_STORE_IF_NULL ) ) ;
2014-02-10 02:10:30 +01:00
}
}
2016-03-09 00:00:52 +01:00
2021-05-04 16:00:45 +02:00
key = nullptr ;
2014-02-15 06:01:39 +01:00
2017-03-05 16:44:50 +01:00
while ( ( key = font_map . next ( key ) ) ) {
2021-05-04 16:00:45 +02:00
const StringName * key2 = nullptr ;
2016-03-09 00:00:52 +01:00
2017-03-05 16:44:50 +01:00
while ( ( key2 = font_map [ * key ] . next ( key2 ) ) ) {
list . push_back ( PropertyInfo ( Variant : : OBJECT , String ( ) + * key + " /fonts/ " + * key2 , PROPERTY_HINT_RESOURCE_TYPE , " Font " , PROPERTY_USAGE_DEFAULT | PROPERTY_USAGE_STORE_IF_NULL ) ) ;
2014-02-10 02:10:30 +01:00
}
}
2016-03-09 00:00:52 +01:00
2021-05-04 16:00:45 +02:00
key = nullptr ;
2016-03-09 00:00:52 +01:00
2017-03-05 16:44:50 +01:00
while ( ( key = color_map . next ( key ) ) ) {
2021-05-04 16:00:45 +02:00
const StringName * key2 = nullptr ;
2016-03-09 00:00:52 +01:00
2017-03-05 16:44:50 +01:00
while ( ( key2 = color_map [ * key ] . next ( key2 ) ) ) {
list . push_back ( PropertyInfo ( Variant : : COLOR , String ( ) + * key + " /colors/ " + * key2 ) ) ;
2014-02-10 02:10:30 +01:00
}
}
2016-03-09 00:00:52 +01:00
2021-05-04 16:00:45 +02:00
key = nullptr ;
2016-03-09 00:00:52 +01:00
2017-03-05 16:44:50 +01:00
while ( ( key = constant_map . next ( key ) ) ) {
2021-05-04 16:00:45 +02:00
const StringName * key2 = nullptr ;
2016-03-09 00:00:52 +01:00
2017-03-05 16:44:50 +01:00
while ( ( key2 = constant_map [ * key ] . next ( key2 ) ) ) {
list . push_back ( PropertyInfo ( Variant : : INT , String ( ) + * key + " /constants/ " + * key2 ) ) ;
2014-02-10 02:10:30 +01:00
}
}
2015-05-04 03:37:10 +02:00
list . sort ( ) ;
2017-03-05 16:44:50 +01:00
for ( List < PropertyInfo > : : Element * E = list . front ( ) ; E ; E = E - > next ( ) ) {
2015-05-04 03:37:10 +02:00
p_list - > push_back ( E - > get ( ) ) ;
}
2014-02-10 02:10:30 +01:00
}
2021-10-04 16:09:32 +02:00
// Universal fallback Theme resources.
2019-07-05 22:32:52 +02:00
Ref < Theme > Theme : : get_default ( ) {
return default_theme ;
}
2017-03-05 16:44:50 +01:00
void Theme : : set_default ( const Ref < Theme > & p_default ) {
default_theme = p_default ;
2014-02-10 02:10:30 +01:00
}
2019-07-05 22:32:52 +02:00
Ref < Theme > Theme : : get_project_default ( ) {
return project_default_theme ;
}
void Theme : : set_project_default ( const Ref < Theme > & p_project_default ) {
project_default_theme = p_project_default ;
}
2014-02-10 02:10:30 +01:00
2021-10-04 16:09:32 +02:00
// Universal fallback values for theme item types.
2017-03-05 16:44:50 +01:00
void Theme : : set_default_icon ( const Ref < Texture > & p_icon ) {
default_icon = p_icon ;
2014-02-10 02:10:30 +01:00
}
2021-06-10 14:28:47 +02:00
2017-03-05 16:44:50 +01:00
void Theme : : set_default_style ( const Ref < StyleBox > & p_style ) {
default_style = p_style ;
2014-02-10 02:10:30 +01:00
}
2021-06-10 14:28:47 +02:00
2017-03-05 16:44:50 +01:00
void Theme : : set_default_font ( const Ref < Font > & p_font ) {
default_font = p_font ;
2014-02-10 02:10:30 +01:00
}
2021-10-04 16:09:32 +02:00
// Fallback values for theme item types, configurable per theme.
void Theme : : set_default_theme_font ( const Ref < Font > & p_default_font ) {
if ( default_theme_font = = p_default_font ) {
return ;
2018-11-27 18:33:14 +01:00
}
2021-10-04 16:09:32 +02:00
if ( default_theme_font . is_valid ( ) ) {
default_theme_font - > disconnect ( " changed " , this , " _emit_theme_changed " ) ;
2018-11-27 18:33:14 +01:00
}
2021-10-04 16:09:32 +02:00
default_theme_font = p_default_font ;
if ( default_theme_font . is_valid ( ) ) {
default_theme_font - > connect ( " changed " , this , " _emit_theme_changed " , varray ( ) , CONNECT_REFERENCE_COUNTED ) ;
}
_emit_theme_changed ( ) ;
}
Ref < Font > Theme : : get_default_theme_font ( ) const {
return default_theme_font ;
}
// Icons.
void Theme : : set_icon ( const StringName & p_name , const StringName & p_node_type , const Ref < Texture > & p_icon ) {
if ( icon_map [ p_node_type ] . has ( p_name ) & & icon_map [ p_node_type ] [ p_name ] . is_valid ( ) ) {
icon_map [ p_node_type ] [ p_name ] - > disconnect ( " changed " , this , " _emit_theme_changed " ) ;
}
icon_map [ p_node_type ] [ p_name ] = p_icon ;
if ( p_icon . is_valid ( ) ) {
icon_map [ p_node_type ] [ p_name ] - > connect ( " changed " , this , " _emit_theme_changed " , varray ( ) , CONNECT_REFERENCE_COUNTED ) ;
}
_emit_theme_changed ( ) ;
2014-02-10 02:10:30 +01:00
}
2021-06-10 14:28:47 +02:00
2020-09-12 18:30:40 +02:00
Ref < Texture > Theme : : get_icon ( const StringName & p_name , const StringName & p_node_type ) const {
if ( icon_map . has ( p_node_type ) & & icon_map [ p_node_type ] . has ( p_name ) & & icon_map [ p_node_type ] [ p_name ] . is_valid ( ) ) {
return icon_map [ p_node_type ] [ p_name ] ;
2014-02-10 02:10:30 +01:00
} else {
return default_icon ;
}
}
2020-09-12 18:30:40 +02:00
bool Theme : : has_icon ( const StringName & p_name , const StringName & p_node_type ) const {
return ( icon_map . has ( p_node_type ) & & icon_map [ p_node_type ] . has ( p_name ) & & icon_map [ p_node_type ] [ p_name ] . is_valid ( ) ) ;
2014-02-10 02:10:30 +01:00
}
2021-06-10 23:44:42 +02:00
bool Theme : : has_icon_nocheck ( const StringName & p_name , const StringName & p_node_type ) const {
return ( icon_map . has ( p_node_type ) & & icon_map [ p_node_type ] . has ( p_name ) ) ;
}
2021-06-10 15:23:00 +02:00
void Theme : : rename_icon ( const StringName & p_old_name , const StringName & p_name , const StringName & p_node_type ) {
ERR_FAIL_COND_MSG ( ! icon_map . has ( p_node_type ) , " Cannot rename the icon ' " + String ( p_old_name ) + " ' because the node type ' " + String ( p_node_type ) + " ' does not exist. " ) ;
ERR_FAIL_COND_MSG ( icon_map [ p_node_type ] . has ( p_name ) , " Cannot rename the icon ' " + String ( p_old_name ) + " ' because the new name ' " + String ( p_name ) + " ' already exists. " ) ;
ERR_FAIL_COND_MSG ( ! icon_map [ p_node_type ] . has ( p_old_name ) , " Cannot rename the icon ' " + String ( p_old_name ) + " ' because it does not exist. " ) ;
icon_map [ p_node_type ] [ p_name ] = icon_map [ p_node_type ] [ p_old_name ] ;
icon_map [ p_node_type ] . erase ( p_old_name ) ;
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2021-06-10 15:23:00 +02:00
}
2020-09-12 18:30:40 +02:00
void Theme : : clear_icon ( const StringName & p_name , const StringName & p_node_type ) {
2021-06-10 15:23:00 +02:00
ERR_FAIL_COND_MSG ( ! icon_map . has ( p_node_type ) , " Cannot clear the icon ' " + String ( p_name ) + " ' because the node type ' " + String ( p_node_type ) + " ' does not exist. " ) ;
ERR_FAIL_COND_MSG ( ! icon_map [ p_node_type ] . has ( p_name ) , " Cannot clear the icon ' " + String ( p_name ) + " ' because it does not exist. " ) ;
2014-02-10 02:10:30 +01:00
2020-09-12 18:30:40 +02:00
if ( icon_map [ p_node_type ] [ p_name ] . is_valid ( ) ) {
icon_map [ p_node_type ] [ p_name ] - > disconnect ( " changed " , this , " _emit_theme_changed " ) ;
2018-11-27 18:33:14 +01:00
}
2020-09-12 18:30:40 +02:00
icon_map [ p_node_type ] . erase ( p_name ) ;
2018-11-27 18:33:14 +01:00
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2014-02-10 02:10:30 +01:00
}
2020-09-12 18:30:40 +02:00
void Theme : : get_icon_list ( StringName p_node_type , List < StringName > * p_list ) const {
2019-10-23 04:08:23 +02:00
ERR_FAIL_NULL ( p_list ) ;
2021-05-05 12:44:11 +02:00
if ( ! icon_map . has ( p_node_type ) ) {
2014-02-10 02:10:30 +01:00
return ;
2021-05-05 12:44:11 +02:00
}
2014-02-10 02:10:30 +01:00
2021-05-04 16:00:45 +02:00
const StringName * key = nullptr ;
2014-02-10 02:10:30 +01:00
2020-09-12 18:30:40 +02:00
while ( ( key = icon_map [ p_node_type ] . next ( key ) ) ) {
2014-02-10 02:10:30 +01:00
p_list - > push_back ( * key ) ;
}
2015-12-20 22:21:53 +01:00
}
2021-06-10 15:23:00 +02:00
void Theme : : add_icon_type ( const StringName & p_node_type ) {
if ( icon_map . has ( p_node_type ) ) {
return ;
}
icon_map [ p_node_type ] = HashMap < StringName , Ref < Texture > > ( ) ;
}
2021-06-10 14:28:47 +02:00
void Theme : : get_icon_types ( List < StringName > * p_list ) const {
ERR_FAIL_NULL ( p_list ) ;
const StringName * key = nullptr ;
while ( ( key = icon_map . next ( key ) ) ) {
p_list - > push_back ( * key ) ;
}
}
2021-10-04 16:09:32 +02:00
// Shaders.
2020-09-12 18:30:40 +02:00
void Theme : : set_shader ( const StringName & p_name , const StringName & p_node_type , const Ref < Shader > & p_shader ) {
shader_map [ p_node_type ] [ p_name ] = p_shader ;
2014-02-10 02:10:30 +01:00
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2015-12-20 22:21:53 +01:00
}
2020-09-12 18:30:40 +02:00
Ref < Shader > Theme : : get_shader ( const StringName & p_name , const StringName & p_node_type ) const {
if ( shader_map . has ( p_node_type ) & & shader_map [ p_node_type ] . has ( p_name ) & & shader_map [ p_node_type ] [ p_name ] . is_valid ( ) ) {
return shader_map [ p_node_type ] [ p_name ] ;
2015-12-20 22:21:53 +01:00
} else {
2021-05-04 16:00:45 +02:00
return nullptr ;
2015-12-20 22:21:53 +01:00
}
}
2020-09-12 18:30:40 +02:00
bool Theme : : has_shader ( const StringName & p_name , const StringName & p_node_type ) const {
return ( shader_map . has ( p_node_type ) & & shader_map [ p_node_type ] . has ( p_name ) & & shader_map [ p_node_type ] [ p_name ] . is_valid ( ) ) ;
2015-12-20 22:21:53 +01:00
}
2020-09-12 18:30:40 +02:00
void Theme : : clear_shader ( const StringName & p_name , const StringName & p_node_type ) {
ERR_FAIL_COND ( ! shader_map . has ( p_node_type ) ) ;
ERR_FAIL_COND ( ! shader_map [ p_node_type ] . has ( p_name ) ) ;
2015-12-20 22:21:53 +01:00
2020-09-12 18:30:40 +02:00
shader_map [ p_node_type ] . erase ( p_name ) ;
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2015-12-20 22:21:53 +01:00
}
2020-09-12 18:30:40 +02:00
void Theme : : get_shader_list ( const StringName & p_node_type , List < StringName > * p_list ) const {
2019-10-23 04:08:23 +02:00
ERR_FAIL_NULL ( p_list ) ;
2021-05-05 12:44:11 +02:00
if ( ! shader_map . has ( p_node_type ) ) {
2015-12-20 22:21:53 +01:00
return ;
2021-05-05 12:44:11 +02:00
}
2015-12-20 22:21:53 +01:00
2021-05-04 16:00:45 +02:00
const StringName * key = nullptr ;
2015-12-20 22:21:53 +01:00
2020-09-12 18:30:40 +02:00
while ( ( key = shader_map [ p_node_type ] . next ( key ) ) ) {
2015-12-20 22:21:53 +01:00
p_list - > push_back ( * key ) ;
}
2014-02-10 02:10:30 +01:00
}
2021-10-04 16:09:32 +02:00
// Styleboxes.
2020-09-12 18:30:40 +02:00
void Theme : : set_stylebox ( const StringName & p_name , const StringName & p_node_type , const Ref < StyleBox > & p_style ) {
if ( style_map [ p_node_type ] . has ( p_name ) & & style_map [ p_node_type ] [ p_name ] . is_valid ( ) ) {
style_map [ p_node_type ] [ p_name ] - > disconnect ( " changed " , this , " _emit_theme_changed " ) ;
2018-11-27 18:33:14 +01:00
}
2020-09-12 18:30:40 +02:00
style_map [ p_node_type ] [ p_name ] = p_style ;
2014-02-10 02:10:30 +01:00
2018-11-27 18:33:14 +01:00
if ( p_style . is_valid ( ) ) {
2020-09-12 18:30:40 +02:00
style_map [ p_node_type ] [ p_name ] - > connect ( " changed " , this , " _emit_theme_changed " , varray ( ) , CONNECT_REFERENCE_COUNTED ) ;
2018-11-27 18:33:14 +01:00
}
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2014-02-10 02:10:30 +01:00
}
2020-09-12 18:30:40 +02:00
Ref < StyleBox > Theme : : get_stylebox ( const StringName & p_name , const StringName & p_node_type ) const {
if ( style_map . has ( p_node_type ) & & style_map [ p_node_type ] . has ( p_name ) & & style_map [ p_node_type ] [ p_name ] . is_valid ( ) ) {
return style_map [ p_node_type ] [ p_name ] ;
2014-02-10 02:10:30 +01:00
} else {
return default_style ;
}
}
2020-09-12 18:30:40 +02:00
bool Theme : : has_stylebox ( const StringName & p_name , const StringName & p_node_type ) const {
return ( style_map . has ( p_node_type ) & & style_map [ p_node_type ] . has ( p_name ) & & style_map [ p_node_type ] [ p_name ] . is_valid ( ) ) ;
2014-02-10 02:10:30 +01:00
}
2021-06-10 23:44:42 +02:00
bool Theme : : has_stylebox_nocheck ( const StringName & p_name , const StringName & p_node_type ) const {
return ( style_map . has ( p_node_type ) & & style_map [ p_node_type ] . has ( p_name ) ) ;
}
2021-06-10 15:23:00 +02:00
void Theme : : rename_stylebox ( const StringName & p_old_name , const StringName & p_name , const StringName & p_node_type ) {
ERR_FAIL_COND_MSG ( ! style_map . has ( p_node_type ) , " Cannot rename the stylebox ' " + String ( p_old_name ) + " ' because the node type ' " + String ( p_node_type ) + " ' does not exist. " ) ;
ERR_FAIL_COND_MSG ( style_map [ p_node_type ] . has ( p_name ) , " Cannot rename the stylebox ' " + String ( p_old_name ) + " ' because the new name ' " + String ( p_name ) + " ' already exists. " ) ;
ERR_FAIL_COND_MSG ( ! style_map [ p_node_type ] . has ( p_old_name ) , " Cannot rename the stylebox ' " + String ( p_old_name ) + " ' because it does not exist. " ) ;
style_map [ p_node_type ] [ p_name ] = style_map [ p_node_type ] [ p_old_name ] ;
style_map [ p_node_type ] . erase ( p_old_name ) ;
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2021-06-10 15:23:00 +02:00
}
2020-09-12 18:30:40 +02:00
void Theme : : clear_stylebox ( const StringName & p_name , const StringName & p_node_type ) {
2021-06-10 15:23:00 +02:00
ERR_FAIL_COND_MSG ( ! style_map . has ( p_node_type ) , " Cannot clear the stylebox ' " + String ( p_name ) + " ' because the node type ' " + String ( p_node_type ) + " ' does not exist. " ) ;
ERR_FAIL_COND_MSG ( ! style_map [ p_node_type ] . has ( p_name ) , " Cannot clear the stylebox ' " + String ( p_name ) + " ' because it does not exist. " ) ;
2014-02-10 02:10:30 +01:00
2020-09-12 18:30:40 +02:00
if ( style_map [ p_node_type ] [ p_name ] . is_valid ( ) ) {
style_map [ p_node_type ] [ p_name ] - > disconnect ( " changed " , this , " _emit_theme_changed " ) ;
2018-11-27 18:33:14 +01:00
}
2020-09-12 18:30:40 +02:00
style_map [ p_node_type ] . erase ( p_name ) ;
2018-11-27 18:33:14 +01:00
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2014-02-10 02:10:30 +01:00
}
2020-09-12 18:30:40 +02:00
void Theme : : get_stylebox_list ( StringName p_node_type , List < StringName > * p_list ) const {
2019-10-23 04:08:23 +02:00
ERR_FAIL_NULL ( p_list ) ;
2021-05-05 12:44:11 +02:00
if ( ! style_map . has ( p_node_type ) ) {
2014-02-10 02:10:30 +01:00
return ;
2021-05-05 12:44:11 +02:00
}
2014-02-10 02:10:30 +01:00
2021-05-04 16:00:45 +02:00
const StringName * key = nullptr ;
2014-02-10 02:10:30 +01:00
2020-09-12 18:30:40 +02:00
while ( ( key = style_map [ p_node_type ] . next ( key ) ) ) {
2014-02-10 02:10:30 +01:00
p_list - > push_back ( * key ) ;
}
}
2021-06-10 15:23:00 +02:00
void Theme : : add_stylebox_type ( const StringName & p_node_type ) {
if ( style_map . has ( p_node_type ) ) {
return ;
}
style_map [ p_node_type ] = HashMap < StringName , Ref < StyleBox > > ( ) ;
}
2016-04-21 03:58:53 +02:00
void Theme : : get_stylebox_types ( List < StringName > * p_list ) const {
2019-10-23 04:08:23 +02:00
ERR_FAIL_NULL ( p_list ) ;
2021-05-04 16:00:45 +02:00
const StringName * key = nullptr ;
2017-03-05 16:44:50 +01:00
while ( ( key = style_map . next ( key ) ) ) {
2016-04-21 03:58:53 +02:00
p_list - > push_back ( * key ) ;
2016-05-21 15:29:25 +02:00
}
2016-04-21 03:58:53 +02:00
}
2021-10-04 16:09:32 +02:00
// Fonts.
2020-09-12 18:30:40 +02:00
void Theme : : set_font ( const StringName & p_name , const StringName & p_node_type , const Ref < Font > & p_font ) {
if ( font_map [ p_node_type ] [ p_name ] . is_valid ( ) ) {
font_map [ p_node_type ] [ p_name ] - > disconnect ( " changed " , this , " _emit_theme_changed " ) ;
2016-06-17 21:00:27 +02:00
}
2018-11-27 18:33:14 +01:00
2020-09-12 18:30:40 +02:00
font_map [ p_node_type ] [ p_name ] = p_font ;
2014-02-10 02:10:30 +01:00
2016-06-17 21:00:27 +02:00
if ( p_font . is_valid ( ) ) {
2020-09-12 18:30:40 +02:00
font_map [ p_node_type ] [ p_name ] - > connect ( " changed " , this , " _emit_theme_changed " , varray ( ) , CONNECT_REFERENCE_COUNTED ) ;
2016-06-17 21:00:27 +02:00
}
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2014-02-10 02:10:30 +01:00
}
2021-06-10 14:28:47 +02:00
2020-09-12 18:30:40 +02:00
Ref < Font > Theme : : get_font ( const StringName & p_name , const StringName & p_node_type ) const {
2021-05-05 12:44:11 +02:00
if ( font_map . has ( p_node_type ) & & font_map [ p_node_type ] . has ( p_name ) & & font_map [ p_node_type ] [ p_name ] . is_valid ( ) ) {
2020-09-12 18:30:40 +02:00
return font_map [ p_node_type ] [ p_name ] ;
2021-05-05 12:44:11 +02:00
} else if ( default_theme_font . is_valid ( ) ) {
2014-02-15 06:01:39 +01:00
return default_theme_font ;
2021-05-05 12:44:11 +02:00
} else {
2014-02-10 02:10:30 +01:00
return default_font ;
2021-05-05 12:44:11 +02:00
}
2014-02-10 02:10:30 +01:00
}
2020-09-12 18:30:40 +02:00
bool Theme : : has_font ( const StringName & p_name , const StringName & p_node_type ) const {
return ( font_map . has ( p_node_type ) & & font_map [ p_node_type ] . has ( p_name ) & & font_map [ p_node_type ] [ p_name ] . is_valid ( ) ) ;
2014-02-10 02:10:30 +01:00
}
2021-06-10 23:44:42 +02:00
bool Theme : : has_font_nocheck ( const StringName & p_name , const StringName & p_node_type ) const {
return ( font_map . has ( p_node_type ) & & font_map [ p_node_type ] . has ( p_name ) ) ;
}
2021-06-10 15:23:00 +02:00
void Theme : : rename_font ( const StringName & p_old_name , const StringName & p_name , const StringName & p_node_type ) {
ERR_FAIL_COND_MSG ( ! font_map . has ( p_node_type ) , " Cannot rename the font ' " + String ( p_old_name ) + " ' because the node type ' " + String ( p_node_type ) + " ' does not exist. " ) ;
ERR_FAIL_COND_MSG ( font_map [ p_node_type ] . has ( p_name ) , " Cannot rename the font ' " + String ( p_old_name ) + " ' because the new name ' " + String ( p_name ) + " ' already exists. " ) ;
ERR_FAIL_COND_MSG ( ! font_map [ p_node_type ] . has ( p_old_name ) , " Cannot rename the font ' " + String ( p_old_name ) + " ' because it does not exist. " ) ;
font_map [ p_node_type ] [ p_name ] = font_map [ p_node_type ] [ p_old_name ] ;
font_map [ p_node_type ] . erase ( p_old_name ) ;
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2021-06-10 15:23:00 +02:00
}
2020-09-12 18:30:40 +02:00
void Theme : : clear_font ( const StringName & p_name , const StringName & p_node_type ) {
2021-06-10 15:23:00 +02:00
ERR_FAIL_COND_MSG ( ! font_map . has ( p_node_type ) , " Cannot clear the font ' " + String ( p_name ) + " ' because the node type ' " + String ( p_node_type ) + " ' does not exist. " ) ;
ERR_FAIL_COND_MSG ( ! font_map [ p_node_type ] . has ( p_name ) , " Cannot clear the font ' " + String ( p_name ) + " ' because it does not exist. " ) ;
2014-02-10 02:10:30 +01:00
2020-09-12 18:30:40 +02:00
if ( font_map [ p_node_type ] [ p_name ] . is_valid ( ) ) {
font_map [ p_node_type ] [ p_name ] - > disconnect ( " changed " , this , " _emit_theme_changed " ) ;
2016-06-17 21:00:27 +02:00
}
2020-09-12 18:30:40 +02:00
font_map [ p_node_type ] . erase ( p_name ) ;
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2014-02-10 02:10:30 +01:00
}
2020-09-12 18:30:40 +02:00
void Theme : : get_font_list ( StringName p_node_type , List < StringName > * p_list ) const {
2019-10-23 04:08:23 +02:00
ERR_FAIL_NULL ( p_list ) ;
2021-05-05 12:44:11 +02:00
if ( ! font_map . has ( p_node_type ) ) {
2014-02-10 02:10:30 +01:00
return ;
2021-05-05 12:44:11 +02:00
}
2014-02-10 02:10:30 +01:00
2021-05-04 16:00:45 +02:00
const StringName * key = nullptr ;
2014-02-10 02:10:30 +01:00
2020-09-12 18:30:40 +02:00
while ( ( key = font_map [ p_node_type ] . next ( key ) ) ) {
2014-02-10 02:10:30 +01:00
p_list - > push_back ( * key ) ;
}
}
2021-06-10 15:23:00 +02:00
void Theme : : add_font_type ( const StringName & p_node_type ) {
if ( font_map . has ( p_node_type ) ) {
return ;
}
font_map [ p_node_type ] = HashMap < StringName , Ref < Font > > ( ) ;
}
2021-06-10 14:28:47 +02:00
void Theme : : get_font_types ( List < StringName > * p_list ) const {
ERR_FAIL_NULL ( p_list ) ;
const StringName * key = nullptr ;
while ( ( key = font_map . next ( key ) ) ) {
p_list - > push_back ( * key ) ;
}
}
2021-10-04 16:09:32 +02:00
// Colors.
2020-09-12 18:30:40 +02:00
void Theme : : set_color ( const StringName & p_name , const StringName & p_node_type , const Color & p_color ) {
color_map [ p_node_type ] [ p_name ] = p_color ;
2014-02-10 02:10:30 +01:00
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2014-02-10 02:10:30 +01:00
}
2020-09-12 18:30:40 +02:00
Color Theme : : get_color ( const StringName & p_name , const StringName & p_node_type ) const {
2021-05-05 12:44:11 +02:00
if ( color_map . has ( p_node_type ) & & color_map [ p_node_type ] . has ( p_name ) ) {
2020-09-12 18:30:40 +02:00
return color_map [ p_node_type ] [ p_name ] ;
2021-05-05 12:44:11 +02:00
} else {
2014-02-10 02:10:30 +01:00
return Color ( ) ;
2021-05-05 12:44:11 +02:00
}
2014-02-10 02:10:30 +01:00
}
2020-09-12 18:30:40 +02:00
bool Theme : : has_color ( const StringName & p_name , const StringName & p_node_type ) const {
return ( color_map . has ( p_node_type ) & & color_map [ p_node_type ] . has ( p_name ) ) ;
2014-02-10 02:10:30 +01:00
}
2021-06-10 23:44:42 +02:00
bool Theme : : has_color_nocheck ( const StringName & p_name , const StringName & p_node_type ) const {
return ( color_map . has ( p_node_type ) & & color_map [ p_node_type ] . has ( p_name ) ) ;
}
2021-06-10 15:23:00 +02:00
void Theme : : rename_color ( const StringName & p_old_name , const StringName & p_name , const StringName & p_node_type ) {
ERR_FAIL_COND_MSG ( ! color_map . has ( p_node_type ) , " Cannot rename the color ' " + String ( p_old_name ) + " ' because the node type ' " + String ( p_node_type ) + " ' does not exist. " ) ;
ERR_FAIL_COND_MSG ( color_map [ p_node_type ] . has ( p_name ) , " Cannot rename the color ' " + String ( p_old_name ) + " ' because the new name ' " + String ( p_name ) + " ' already exists. " ) ;
ERR_FAIL_COND_MSG ( ! color_map [ p_node_type ] . has ( p_old_name ) , " Cannot rename the color ' " + String ( p_old_name ) + " ' because it does not exist. " ) ;
color_map [ p_node_type ] [ p_name ] = color_map [ p_node_type ] [ p_old_name ] ;
color_map [ p_node_type ] . erase ( p_old_name ) ;
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2021-06-10 15:23:00 +02:00
}
2020-09-12 18:30:40 +02:00
void Theme : : clear_color ( const StringName & p_name , const StringName & p_node_type ) {
2021-06-10 15:23:00 +02:00
ERR_FAIL_COND_MSG ( ! color_map . has ( p_node_type ) , " Cannot clear the color ' " + String ( p_name ) + " ' because the node type ' " + String ( p_node_type ) + " ' does not exist. " ) ;
ERR_FAIL_COND_MSG ( ! color_map [ p_node_type ] . has ( p_name ) , " Cannot clear the color ' " + String ( p_name ) + " ' because it does not exist. " ) ;
2014-02-10 02:10:30 +01:00
2020-09-12 18:30:40 +02:00
color_map [ p_node_type ] . erase ( p_name ) ;
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2014-02-10 02:10:30 +01:00
}
2020-09-12 18:30:40 +02:00
void Theme : : get_color_list ( StringName p_node_type , List < StringName > * p_list ) const {
2019-10-23 04:08:23 +02:00
ERR_FAIL_NULL ( p_list ) ;
2021-05-05 12:44:11 +02:00
if ( ! color_map . has ( p_node_type ) ) {
2014-02-10 02:10:30 +01:00
return ;
2021-05-05 12:44:11 +02:00
}
2014-02-10 02:10:30 +01:00
2021-05-04 16:00:45 +02:00
const StringName * key = nullptr ;
2014-02-10 02:10:30 +01:00
2020-09-12 18:30:40 +02:00
while ( ( key = color_map [ p_node_type ] . next ( key ) ) ) {
2014-02-10 02:10:30 +01:00
p_list - > push_back ( * key ) ;
}
}
2021-06-10 15:23:00 +02:00
void Theme : : add_color_type ( const StringName & p_node_type ) {
if ( color_map . has ( p_node_type ) ) {
return ;
}
color_map [ p_node_type ] = HashMap < StringName , Color > ( ) ;
}
2021-06-10 14:28:47 +02:00
void Theme : : get_color_types ( List < StringName > * p_list ) const {
ERR_FAIL_NULL ( p_list ) ;
const StringName * key = nullptr ;
while ( ( key = color_map . next ( key ) ) ) {
p_list - > push_back ( * key ) ;
}
}
2021-10-04 16:09:32 +02:00
// Theme constants.
2020-09-12 18:30:40 +02:00
void Theme : : set_constant ( const StringName & p_name , const StringName & p_node_type , int p_constant ) {
constant_map [ p_node_type ] [ p_name ] = p_constant ;
2014-02-10 02:10:30 +01:00
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2014-02-10 02:10:30 +01:00
}
2020-09-12 18:30:40 +02:00
int Theme : : get_constant ( const StringName & p_name , const StringName & p_node_type ) const {
2021-05-05 12:44:11 +02:00
if ( constant_map . has ( p_node_type ) & & constant_map [ p_node_type ] . has ( p_name ) ) {
2020-09-12 18:30:40 +02:00
return constant_map [ p_node_type ] [ p_name ] ;
2021-05-05 12:44:11 +02:00
} else {
2014-02-10 02:10:30 +01:00
return 0 ;
}
}
2020-09-12 18:30:40 +02:00
bool Theme : : has_constant ( const StringName & p_name , const StringName & p_node_type ) const {
return ( constant_map . has ( p_node_type ) & & constant_map [ p_node_type ] . has ( p_name ) ) ;
2014-02-10 02:10:30 +01:00
}
2021-06-10 23:44:42 +02:00
bool Theme : : has_constant_nocheck ( const StringName & p_name , const StringName & p_node_type ) const {
return ( constant_map . has ( p_node_type ) & & constant_map [ p_node_type ] . has ( p_name ) ) ;
}
2021-06-10 15:23:00 +02:00
void Theme : : rename_constant ( const StringName & p_old_name , const StringName & p_name , const StringName & p_node_type ) {
ERR_FAIL_COND_MSG ( ! constant_map . has ( p_node_type ) , " Cannot rename the constant ' " + String ( p_old_name ) + " ' because the node type ' " + String ( p_node_type ) + " ' does not exist. " ) ;
ERR_FAIL_COND_MSG ( constant_map [ p_node_type ] . has ( p_name ) , " Cannot rename the constant ' " + String ( p_old_name ) + " ' because the new name ' " + String ( p_name ) + " ' already exists. " ) ;
ERR_FAIL_COND_MSG ( ! constant_map [ p_node_type ] . has ( p_old_name ) , " Cannot rename the constant ' " + String ( p_old_name ) + " ' because it does not exist. " ) ;
constant_map [ p_node_type ] [ p_name ] = constant_map [ p_node_type ] [ p_old_name ] ;
constant_map [ p_node_type ] . erase ( p_old_name ) ;
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2021-06-10 15:23:00 +02:00
}
2020-09-12 18:30:40 +02:00
void Theme : : clear_constant ( const StringName & p_name , const StringName & p_node_type ) {
2021-06-10 15:23:00 +02:00
ERR_FAIL_COND_MSG ( ! constant_map . has ( p_node_type ) , " Cannot clear the constant ' " + String ( p_name ) + " ' because the node type ' " + String ( p_node_type ) + " ' does not exist. " ) ;
ERR_FAIL_COND_MSG ( ! constant_map [ p_node_type ] . has ( p_name ) , " Cannot clear the constant ' " + String ( p_name ) + " ' because it does not exist. " ) ;
2014-02-10 02:10:30 +01:00
2020-09-12 18:30:40 +02:00
constant_map [ p_node_type ] . erase ( p_name ) ;
2021-06-10 23:44:42 +02:00
_emit_theme_changed ( ) ;
2014-02-10 02:10:30 +01:00
}
2020-09-12 18:30:40 +02:00
void Theme : : get_constant_list ( StringName p_node_type , List < StringName > * p_list ) const {
2019-10-23 04:08:23 +02:00
ERR_FAIL_NULL ( p_list ) ;
2021-05-05 12:44:11 +02:00
if ( ! constant_map . has ( p_node_type ) ) {
2014-02-10 02:10:30 +01:00
return ;
2021-05-05 12:44:11 +02:00
}
2014-02-10 02:10:30 +01:00
2021-05-04 16:00:45 +02:00
const StringName * key = nullptr ;
2014-02-10 02:10:30 +01:00
2020-09-12 18:30:40 +02:00
while ( ( key = constant_map [ p_node_type ] . next ( key ) ) ) {
2014-02-10 02:10:30 +01:00
p_list - > push_back ( * key ) ;
}
}
2021-06-10 15:23:00 +02:00
void Theme : : add_constant_type ( const StringName & p_node_type ) {
if ( constant_map . has ( p_node_type ) ) {
return ;
}
constant_map [ p_node_type ] = HashMap < StringName , int > ( ) ;
}
2021-06-10 14:28:47 +02:00
void Theme : : get_constant_types ( List < StringName > * p_list ) const {
ERR_FAIL_NULL ( p_list ) ;
const StringName * key = nullptr ;
while ( ( key = constant_map . next ( key ) ) ) {
p_list - > push_back ( * key ) ;
}
}
2021-10-04 16:09:32 +02:00
// Generic methods for managing theme items.
2021-06-10 15:23:00 +02:00
void Theme : : set_theme_item ( DataType p_data_type , const StringName & p_name , const StringName & p_node_type , const Variant & p_value ) {
switch ( p_data_type ) {
case DATA_TYPE_COLOR : {
ERR_FAIL_COND_MSG ( p_value . get_type ( ) ! = Variant : : COLOR , " Theme item's data type (Color) does not match Variant's type ( " + Variant : : get_type_name ( p_value . get_type ( ) ) + " ). " ) ;
Color color_value = p_value ;
set_color ( p_name , p_node_type , color_value ) ;
} break ;
case DATA_TYPE_CONSTANT : {
ERR_FAIL_COND_MSG ( p_value . get_type ( ) ! = Variant : : INT , " Theme item's data type (int) does not match Variant's type ( " + Variant : : get_type_name ( p_value . get_type ( ) ) + " ). " ) ;
int constant_value = p_value ;
set_constant ( p_name , p_node_type , constant_value ) ;
} break ;
case DATA_TYPE_FONT : {
ERR_FAIL_COND_MSG ( p_value . get_type ( ) ! = Variant : : OBJECT , " Theme item's data type (Object) does not match Variant's type ( " + Variant : : get_type_name ( p_value . get_type ( ) ) + " ). " ) ;
Ref < Font > font_value = Object : : cast_to < Font > ( p_value ) ;
set_font ( p_name , p_node_type , font_value ) ;
} break ;
case DATA_TYPE_ICON : {
ERR_FAIL_COND_MSG ( p_value . get_type ( ) ! = Variant : : OBJECT , " Theme item's data type (Object) does not match Variant's type ( " + Variant : : get_type_name ( p_value . get_type ( ) ) + " ). " ) ;
Ref < Texture > icon_value = Object : : cast_to < Texture > ( p_value ) ;
set_icon ( p_name , p_node_type , icon_value ) ;
} break ;
case DATA_TYPE_STYLEBOX : {
ERR_FAIL_COND_MSG ( p_value . get_type ( ) ! = Variant : : OBJECT , " Theme item's data type (Object) does not match Variant's type ( " + Variant : : get_type_name ( p_value . get_type ( ) ) + " ). " ) ;
Ref < StyleBox > stylebox_value = Object : : cast_to < StyleBox > ( p_value ) ;
set_stylebox ( p_name , p_node_type , stylebox_value ) ;
} break ;
case DATA_TYPE_MAX :
break ; // Can't happen, but silences warning.
}
}
Variant Theme : : get_theme_item ( DataType p_data_type , const StringName & p_name , const StringName & p_node_type ) const {
switch ( p_data_type ) {
case DATA_TYPE_COLOR :
return get_color ( p_name , p_node_type ) ;
case DATA_TYPE_CONSTANT :
return get_constant ( p_name , p_node_type ) ;
case DATA_TYPE_FONT :
return get_font ( p_name , p_node_type ) ;
case DATA_TYPE_ICON :
return get_icon ( p_name , p_node_type ) ;
case DATA_TYPE_STYLEBOX :
return get_stylebox ( p_name , p_node_type ) ;
case DATA_TYPE_MAX :
break ; // Can't happen, but silences warning.
}
return Variant ( ) ;
}
bool Theme : : has_theme_item ( DataType p_data_type , const StringName & p_name , const StringName & p_node_type ) const {
switch ( p_data_type ) {
case DATA_TYPE_COLOR :
return has_color ( p_name , p_node_type ) ;
case DATA_TYPE_CONSTANT :
return has_constant ( p_name , p_node_type ) ;
case DATA_TYPE_FONT :
return has_font ( p_name , p_node_type ) ;
case DATA_TYPE_ICON :
return has_icon ( p_name , p_node_type ) ;
case DATA_TYPE_STYLEBOX :
return has_stylebox ( p_name , p_node_type ) ;
case DATA_TYPE_MAX :
break ; // Can't happen, but silences warning.
}
return false ;
}
2021-06-10 23:44:42 +02:00
bool Theme : : has_theme_item_nocheck ( DataType p_data_type , const StringName & p_name , const StringName & p_node_type ) const {
switch ( p_data_type ) {
case DATA_TYPE_COLOR :
return has_color_nocheck ( p_name , p_node_type ) ;
case DATA_TYPE_CONSTANT :
return has_constant_nocheck ( p_name , p_node_type ) ;
case DATA_TYPE_FONT :
return has_font_nocheck ( p_name , p_node_type ) ;
case DATA_TYPE_ICON :
return has_icon_nocheck ( p_name , p_node_type ) ;
case DATA_TYPE_STYLEBOX :
return has_stylebox_nocheck ( p_name , p_node_type ) ;
case DATA_TYPE_MAX :
break ; // Can't happen, but silences warning.
}
2021-10-04 16:09:32 +02:00
return false ;
}
void Theme : : rename_theme_item ( DataType p_data_type , const StringName & p_old_name , const StringName & p_name , const StringName & p_node_type ) {
switch ( p_data_type ) {
case DATA_TYPE_COLOR :
rename_color ( p_old_name , p_name , p_node_type ) ;
break ;
case DATA_TYPE_CONSTANT :
rename_constant ( p_old_name , p_name , p_node_type ) ;
break ;
case DATA_TYPE_FONT :
rename_font ( p_old_name , p_name , p_node_type ) ;
break ;
case DATA_TYPE_ICON :
rename_icon ( p_old_name , p_name , p_node_type ) ;
break ;
case DATA_TYPE_STYLEBOX :
rename_stylebox ( p_old_name , p_name , p_node_type ) ;
break ;
case DATA_TYPE_MAX :
break ; // Can't happen, but silences warning.
}
}
void Theme : : clear_theme_item ( DataType p_data_type , const StringName & p_name , const StringName & p_node_type ) {
switch ( p_data_type ) {
case DATA_TYPE_COLOR :
clear_color ( p_name , p_node_type ) ;
break ;
case DATA_TYPE_CONSTANT :
clear_constant ( p_name , p_node_type ) ;
break ;
case DATA_TYPE_FONT :
clear_font ( p_name , p_node_type ) ;
break ;
case DATA_TYPE_ICON :
clear_icon ( p_name , p_node_type ) ;
break ;
case DATA_TYPE_STYLEBOX :
clear_stylebox ( p_name , p_node_type ) ;
break ;
case DATA_TYPE_MAX :
break ; // Can't happen, but silences warning.
}
}
void Theme : : get_theme_item_list ( DataType p_data_type , StringName p_node_type , List < StringName > * p_list ) const {
switch ( p_data_type ) {
case DATA_TYPE_COLOR :
get_color_list ( p_node_type , p_list ) ;
break ;
case DATA_TYPE_CONSTANT :
get_constant_list ( p_node_type , p_list ) ;
break ;
case DATA_TYPE_FONT :
get_font_list ( p_node_type , p_list ) ;
break ;
case DATA_TYPE_ICON :
get_icon_list ( p_node_type , p_list ) ;
break ;
case DATA_TYPE_STYLEBOX :
get_stylebox_list ( p_node_type , p_list ) ;
break ;
case DATA_TYPE_MAX :
break ; // Can't happen, but silences warning.
}
}
void Theme : : add_theme_item_type ( DataType p_data_type , const StringName & p_node_type ) {
switch ( p_data_type ) {
case DATA_TYPE_COLOR :
add_color_type ( p_node_type ) ;
break ;
case DATA_TYPE_CONSTANT :
add_constant_type ( p_node_type ) ;
break ;
case DATA_TYPE_FONT :
add_font_type ( p_node_type ) ;
break ;
case DATA_TYPE_ICON :
add_icon_type ( p_node_type ) ;
break ;
case DATA_TYPE_STYLEBOX :
add_stylebox_type ( p_node_type ) ;
break ;
case DATA_TYPE_MAX :
break ; // Can't happen, but silences warning.
}
}
void Theme : : get_theme_item_types ( DataType p_data_type , List < StringName > * p_list ) const {
switch ( p_data_type ) {
case DATA_TYPE_COLOR :
get_color_types ( p_list ) ;
break ;
case DATA_TYPE_CONSTANT :
get_constant_types ( p_list ) ;
break ;
case DATA_TYPE_FONT :
get_font_types ( p_list ) ;
break ;
case DATA_TYPE_ICON :
get_icon_types ( p_list ) ;
break ;
case DATA_TYPE_STYLEBOX :
get_stylebox_types ( p_list ) ;
break ;
case DATA_TYPE_MAX :
break ; // Can't happen, but silences warning.
}
}
// Theme types.
void Theme : : get_type_list ( List < StringName > * p_list ) const {
ERR_FAIL_NULL ( p_list ) ;
Set < StringName > types ;
const StringName * key = nullptr ;
while ( ( key = icon_map . next ( key ) ) ) {
types . insert ( * key ) ;
}
key = nullptr ;
while ( ( key = style_map . next ( key ) ) ) {
types . insert ( * key ) ;
}
key = nullptr ;
while ( ( key = font_map . next ( key ) ) ) {
types . insert ( * key ) ;
}
key = nullptr ;
while ( ( key = color_map . next ( key ) ) ) {
types . insert ( * key ) ;
}
key = nullptr ;
while ( ( key = constant_map . next ( key ) ) ) {
types . insert ( * key ) ;
}
for ( Set < StringName > : : Element * E = types . front ( ) ; E ; E = E - > next ( ) ) {
p_list - > push_back ( E - > get ( ) ) ;
}
}
// Internal methods for getting lists as a Vector of String (compatible with public API).
PoolVector < String > Theme : : _get_icon_list ( const String & p_node_type ) const {
PoolVector < String > ilret ;
List < StringName > il ;
get_icon_list ( p_node_type , & il ) ;
ilret . resize ( il . size ( ) ) ;
int i = 0 ;
PoolVector < String > : : Write w = ilret . write ( ) ;
for ( List < StringName > : : Element * E = il . front ( ) ; E ; E = E - > next ( ) , i + + ) {
w [ i ] = E - > get ( ) ;
}
return ilret ;
}
PoolVector < String > Theme : : _get_icon_types ( ) const {
PoolVector < String > ilret ;
List < StringName > il ;
get_icon_types ( & il ) ;
ilret . resize ( il . size ( ) ) ;
int i = 0 ;
PoolVector < String > : : Write w = ilret . write ( ) ;
for ( List < StringName > : : Element * E = il . front ( ) ; E ; E = E - > next ( ) , i + + ) {
w [ i ] = E - > get ( ) ;
}
return ilret ;
}
PoolVector < String > Theme : : _get_stylebox_list ( const String & p_node_type ) const {
PoolVector < String > ilret ;
List < StringName > il ;
get_stylebox_list ( p_node_type , & il ) ;
ilret . resize ( il . size ( ) ) ;
int i = 0 ;
PoolVector < String > : : Write w = ilret . write ( ) ;
for ( List < StringName > : : Element * E = il . front ( ) ; E ; E = E - > next ( ) , i + + ) {
w [ i ] = E - > get ( ) ;
}
return ilret ;
}
PoolVector < String > Theme : : _get_stylebox_types ( ) const {
PoolVector < String > ilret ;
List < StringName > il ;
get_stylebox_types ( & il ) ;
ilret . resize ( il . size ( ) ) ;
int i = 0 ;
PoolVector < String > : : Write w = ilret . write ( ) ;
for ( List < StringName > : : Element * E = il . front ( ) ; E ; E = E - > next ( ) , i + + ) {
w [ i ] = E - > get ( ) ;
}
return ilret ;
}
PoolVector < String > Theme : : _get_font_list ( const String & p_node_type ) const {
PoolVector < String > ilret ;
List < StringName > il ;
get_font_list ( p_node_type , & il ) ;
ilret . resize ( il . size ( ) ) ;
int i = 0 ;
PoolVector < String > : : Write w = ilret . write ( ) ;
for ( List < StringName > : : Element * E = il . front ( ) ; E ; E = E - > next ( ) , i + + ) {
w [ i ] = E - > get ( ) ;
}
return ilret ;
}
PoolVector < String > Theme : : _get_font_types ( ) const {
PoolVector < String > ilret ;
List < StringName > il ;
get_font_types ( & il ) ;
ilret . resize ( il . size ( ) ) ;
int i = 0 ;
PoolVector < String > : : Write w = ilret . write ( ) ;
for ( List < StringName > : : Element * E = il . front ( ) ; E ; E = E - > next ( ) , i + + ) {
w [ i ] = E - > get ( ) ;
}
return ilret ;
}
PoolVector < String > Theme : : _get_color_list ( const String & p_node_type ) const {
PoolVector < String > ilret ;
List < StringName > il ;
get_color_list ( p_node_type , & il ) ;
ilret . resize ( il . size ( ) ) ;
int i = 0 ;
PoolVector < String > : : Write w = ilret . write ( ) ;
for ( List < StringName > : : Element * E = il . front ( ) ; E ; E = E - > next ( ) , i + + ) {
w [ i ] = E - > get ( ) ;
}
return ilret ;
}
PoolVector < String > Theme : : _get_color_types ( ) const {
PoolVector < String > ilret ;
List < StringName > il ;
get_color_types ( & il ) ;
ilret . resize ( il . size ( ) ) ;
int i = 0 ;
PoolVector < String > : : Write w = ilret . write ( ) ;
for ( List < StringName > : : Element * E = il . front ( ) ; E ; E = E - > next ( ) , i + + ) {
w [ i ] = E - > get ( ) ;
}
return ilret ;
}
PoolVector < String > Theme : : _get_constant_list ( const String & p_node_type ) const {
PoolVector < String > ilret ;
List < StringName > il ;
get_constant_list ( p_node_type , & il ) ;
ilret . resize ( il . size ( ) ) ;
int i = 0 ;
PoolVector < String > : : Write w = ilret . write ( ) ;
for ( List < StringName > : : Element * E = il . front ( ) ; E ; E = E - > next ( ) , i + + ) {
w [ i ] = E - > get ( ) ;
}
return ilret ;
2021-06-10 23:44:42 +02:00
}
2021-10-04 16:09:32 +02:00
PoolVector < String > Theme : : _get_constant_types ( ) const {
PoolVector < String > ilret ;
List < StringName > il ;
get_constant_types ( & il ) ;
ilret . resize ( il . size ( ) ) ;
int i = 0 ;
PoolVector < String > : : Write w = ilret . write ( ) ;
for ( List < StringName > : : Element * E = il . front ( ) ; E ; E = E - > next ( ) , i + + ) {
w [ i ] = E - > get ( ) ;
2021-06-10 15:23:00 +02:00
}
2021-10-04 16:09:32 +02:00
return ilret ;
2021-06-10 15:23:00 +02:00
}
2021-10-04 16:09:32 +02:00
PoolVector < String > Theme : : _get_theme_item_list ( DataType p_data_type , const String & p_node_type ) const {
2021-06-10 15:23:00 +02:00
switch ( p_data_type ) {
case DATA_TYPE_COLOR :
2021-10-04 16:09:32 +02:00
return _get_color_list ( p_node_type ) ;
2021-06-10 15:23:00 +02:00
case DATA_TYPE_CONSTANT :
2021-10-04 16:09:32 +02:00
return _get_constant_list ( p_node_type ) ;
2021-06-10 15:23:00 +02:00
case DATA_TYPE_FONT :
2021-10-04 16:09:32 +02:00
return _get_font_list ( p_node_type ) ;
2021-06-10 15:23:00 +02:00
case DATA_TYPE_ICON :
2021-10-04 16:09:32 +02:00
return _get_icon_list ( p_node_type ) ;
2021-06-10 15:23:00 +02:00
case DATA_TYPE_STYLEBOX :
2021-10-04 16:09:32 +02:00
return _get_stylebox_list ( p_node_type ) ;
2021-06-10 15:23:00 +02:00
case DATA_TYPE_MAX :
break ; // Can't happen, but silences warning.
}
2021-10-04 16:09:32 +02:00
return PoolVector < String > ( ) ;
2021-06-10 15:23:00 +02:00
}
2021-10-04 16:09:32 +02:00
PoolVector < String > Theme : : _get_theme_item_types ( DataType p_data_type ) const {
2021-06-10 15:23:00 +02:00
switch ( p_data_type ) {
case DATA_TYPE_COLOR :
2021-10-04 16:09:32 +02:00
return _get_color_types ( ) ;
2021-06-10 15:23:00 +02:00
case DATA_TYPE_CONSTANT :
2021-10-04 16:09:32 +02:00
return _get_constant_types ( ) ;
2021-06-10 15:23:00 +02:00
case DATA_TYPE_FONT :
2021-10-04 16:09:32 +02:00
return _get_font_types ( ) ;
2021-06-10 15:23:00 +02:00
case DATA_TYPE_ICON :
2021-10-04 16:09:32 +02:00
return _get_icon_types ( ) ;
2021-06-10 15:23:00 +02:00
case DATA_TYPE_STYLEBOX :
2021-10-04 16:09:32 +02:00
return _get_stylebox_types ( ) ;
2021-06-10 15:23:00 +02:00
case DATA_TYPE_MAX :
break ; // Can't happen, but silences warning.
}
2021-10-04 16:09:32 +02:00
return PoolVector < String > ( ) ;
2021-06-10 15:23:00 +02:00
}
2021-10-04 16:09:32 +02:00
PoolVector < String > Theme : : _get_type_list ( const String & p_node_type ) const {
PoolVector < String > ilret ;
List < StringName > il ;
get_type_list ( & il ) ;
ilret . resize ( il . size ( ) ) ;
int i = 0 ;
PoolVector < String > : : Write w = ilret . write ( ) ;
for ( List < StringName > : : Element * E = il . front ( ) ; E ; E = E - > next ( ) , i + + ) {
w [ i ] = E - > get ( ) ;
2021-06-10 15:23:00 +02:00
}
2021-10-04 16:09:32 +02:00
return ilret ;
2021-06-10 15:23:00 +02:00
}
2021-10-04 16:09:32 +02:00
// Theme bulk manipulations.
void Theme : : _emit_theme_changed ( ) {
if ( no_change_propagation ) {
return ;
2021-06-10 15:23:00 +02:00
}
2021-10-04 16:09:32 +02:00
_change_notify ( ) ;
emit_changed ( ) ;
2021-06-10 15:23:00 +02:00
}
2021-06-10 23:44:42 +02:00
void Theme : : _freeze_change_propagation ( ) {
no_change_propagation = true ;
}
void Theme : : _unfreeze_and_propagate_changes ( ) {
no_change_propagation = false ;
_emit_theme_changed ( ) ;
}
2014-02-10 02:10:30 +01:00
void Theme : : copy_default_theme ( ) {
2019-02-12 21:10:08 +01:00
Ref < Theme > default_theme2 = get_default ( ) ;
copy_theme ( default_theme2 ) ;
2019-01-25 02:40:56 +01:00
}
void Theme : : copy_theme ( const Ref < Theme > & p_other ) {
2019-10-23 04:08:23 +02:00
if ( p_other . is_null ( ) ) {
clear ( ) ;
return ;
}
2021-06-10 23:44:42 +02:00
_freeze_change_propagation ( ) ;
2021-06-10 15:23:00 +02:00
// These items need reconnecting, so add them normally.
2018-11-27 18:33:14 +01:00
{
2021-05-04 16:00:45 +02:00
const StringName * K = nullptr ;
2019-01-25 02:40:56 +01:00
while ( ( K = p_other - > icon_map . next ( K ) ) ) {
2021-05-04 16:00:45 +02:00
const StringName * L = nullptr ;
2019-01-25 02:40:56 +01:00
while ( ( L = p_other - > icon_map [ * K ] . next ( L ) ) ) {
set_icon ( * L , * K , p_other - > icon_map [ * K ] [ * L ] ) ;
2018-11-27 18:33:14 +01:00
}
}
}
{
2021-05-04 16:00:45 +02:00
const StringName * K = nullptr ;
2019-01-25 02:40:56 +01:00
while ( ( K = p_other - > style_map . next ( K ) ) ) {
2021-05-04 16:00:45 +02:00
const StringName * L = nullptr ;
2019-01-25 02:40:56 +01:00
while ( ( L = p_other - > style_map [ * K ] . next ( L ) ) ) {
set_stylebox ( * L , * K , p_other - > style_map [ * K ] [ * L ] ) ;
2018-11-27 18:33:14 +01:00
}
}
}
{
2021-05-04 16:00:45 +02:00
const StringName * K = nullptr ;
2019-01-25 02:40:56 +01:00
while ( ( K = p_other - > font_map . next ( K ) ) ) {
2021-05-04 16:00:45 +02:00
const StringName * L = nullptr ;
2019-01-25 02:40:56 +01:00
while ( ( L = p_other - > font_map [ * K ] . next ( L ) ) ) {
set_font ( * L , * K , p_other - > font_map [ * K ] [ * L ] ) ;
2018-11-27 18:33:14 +01:00
}
}
}
2021-06-10 15:23:00 +02:00
// These items can be simply copied.
2019-01-25 02:40:56 +01:00
color_map = p_other - > color_map ;
constant_map = p_other - > constant_map ;
shader_map = p_other - > shader_map ;
2018-11-27 18:33:14 +01:00
2021-06-10 23:44:42 +02:00
_unfreeze_and_propagate_changes ( ) ;
2014-02-10 02:10:30 +01:00
}
2021-08-14 00:06:21 +02:00
void Theme : : merge_with ( const Ref < Theme > & p_other ) {
if ( p_other . is_null ( ) ) {
return ;
}
_freeze_change_propagation ( ) ;
// Colors.
{
const StringName * K = nullptr ;
while ( ( K = p_other - > color_map . next ( K ) ) ) {
const StringName * L = nullptr ;
while ( ( L = p_other - > color_map [ * K ] . next ( L ) ) ) {
set_color ( * L , * K , p_other - > color_map [ * K ] [ * L ] ) ;
}
}
}
// Constants.
{
const StringName * K = nullptr ;
while ( ( K = p_other - > constant_map . next ( K ) ) ) {
const StringName * L = nullptr ;
while ( ( L = p_other - > constant_map [ * K ] . next ( L ) ) ) {
set_constant ( * L , * K , p_other - > constant_map [ * K ] [ * L ] ) ;
}
}
}
// Fonts.
{
const StringName * K = nullptr ;
while ( ( K = p_other - > font_map . next ( K ) ) ) {
const StringName * L = nullptr ;
while ( ( L = p_other - > font_map [ * K ] . next ( L ) ) ) {
set_font ( * L , * K , p_other - > font_map [ * K ] [ * L ] ) ;
}
}
}
// Icons.
{
const StringName * K = nullptr ;
while ( ( K = p_other - > icon_map . next ( K ) ) ) {
const StringName * L = nullptr ;
while ( ( L = p_other - > icon_map [ * K ] . next ( L ) ) ) {
set_icon ( * L , * K , p_other - > icon_map [ * K ] [ * L ] ) ;
}
}
}
// Shaders.
{
const StringName * K = nullptr ;
while ( ( K = p_other - > shader_map . next ( K ) ) ) {
const StringName * L = nullptr ;
while ( ( L = p_other - > shader_map [ * K ] . next ( L ) ) ) {
set_shader ( * L , * K , p_other - > shader_map [ * K ] [ * L ] ) ;
}
}
}
// Styleboxes.
{
const StringName * K = nullptr ;
while ( ( K = p_other - > style_map . next ( K ) ) ) {
const StringName * L = nullptr ;
while ( ( L = p_other - > style_map [ * K ] . next ( L ) ) ) {
set_stylebox ( * L , * K , p_other - > style_map [ * K ] [ * L ] ) ;
}
}
}
_unfreeze_and_propagate_changes ( ) ;
}
2021-10-04 16:09:32 +02:00
void Theme : : clear ( ) {
//these need disconnecting
{
const StringName * K = nullptr ;
while ( ( K = icon_map . next ( K ) ) ) {
const StringName * L = nullptr ;
while ( ( L = icon_map [ * K ] . next ( L ) ) ) {
Ref < Texture > icon = icon_map [ * K ] [ * L ] ;
if ( icon . is_valid ( ) ) {
icon - > disconnect ( " changed " , this , " _emit_theme_changed " ) ;
}
}
}
2014-02-10 02:10:30 +01:00
}
2021-10-04 16:09:32 +02:00
{
const StringName * K = nullptr ;
while ( ( K = style_map . next ( K ) ) ) {
const StringName * L = nullptr ;
while ( ( L = style_map [ * K ] . next ( L ) ) ) {
Ref < StyleBox > style = style_map [ * K ] [ * L ] ;
if ( style . is_valid ( ) ) {
style - > disconnect ( " changed " , this , " _emit_theme_changed " ) ;
}
}
}
2014-02-10 02:10:30 +01:00
}
2021-10-04 16:09:32 +02:00
{
const StringName * K = nullptr ;
while ( ( K = font_map . next ( K ) ) ) {
const StringName * L = nullptr ;
while ( ( L = font_map [ * K ] . next ( L ) ) ) {
Ref < Font > font = font_map [ * K ] [ * L ] ;
if ( font . is_valid ( ) ) {
font - > disconnect ( " changed " , this , " _emit_theme_changed " ) ;
}
}
}
2014-02-10 02:10:30 +01:00
}
2021-10-04 16:09:32 +02:00
icon_map . clear ( ) ;
style_map . clear ( ) ;
font_map . clear ( ) ;
shader_map . clear ( ) ;
color_map . clear ( ) ;
constant_map . clear ( ) ;
2014-02-10 02:10:30 +01:00
2021-10-04 16:09:32 +02:00
_emit_theme_changed ( ) ;
2014-02-10 02:10:30 +01:00
}
void Theme : : _bind_methods ( ) {
2020-09-12 18:30:40 +02:00
ClassDB : : bind_method ( D_METHOD ( " set_icon " , " name " , " node_type " , " texture " ) , & Theme : : set_icon ) ;
ClassDB : : bind_method ( D_METHOD ( " get_icon " , " name " , " node_type " ) , & Theme : : get_icon ) ;
ClassDB : : bind_method ( D_METHOD ( " has_icon " , " name " , " node_type " ) , & Theme : : has_icon ) ;
2021-06-10 15:23:00 +02:00
ClassDB : : bind_method ( D_METHOD ( " rename_icon " , " old_name " , " name " , " node_type " ) , & Theme : : rename_icon ) ;
2020-09-12 18:30:40 +02:00
ClassDB : : bind_method ( D_METHOD ( " clear_icon " , " name " , " node_type " ) , & Theme : : clear_icon ) ;
ClassDB : : bind_method ( D_METHOD ( " get_icon_list " , " node_type " ) , & Theme : : _get_icon_list ) ;
2021-06-10 14:28:47 +02:00
ClassDB : : bind_method ( D_METHOD ( " get_icon_types " ) , & Theme : : _get_icon_types ) ;
2020-09-12 18:30:40 +02:00
ClassDB : : bind_method ( D_METHOD ( " set_stylebox " , " name " , " node_type " , " texture " ) , & Theme : : set_stylebox ) ;
ClassDB : : bind_method ( D_METHOD ( " get_stylebox " , " name " , " node_type " ) , & Theme : : get_stylebox ) ;
ClassDB : : bind_method ( D_METHOD ( " has_stylebox " , " name " , " node_type " ) , & Theme : : has_stylebox ) ;
2021-06-10 15:23:00 +02:00
ClassDB : : bind_method ( D_METHOD ( " rename_stylebox " , " old_name " , " name " , " node_type " ) , & Theme : : rename_stylebox ) ;
2020-09-12 18:30:40 +02:00
ClassDB : : bind_method ( D_METHOD ( " clear_stylebox " , " name " , " node_type " ) , & Theme : : clear_stylebox ) ;
ClassDB : : bind_method ( D_METHOD ( " get_stylebox_list " , " node_type " ) , & Theme : : _get_stylebox_list ) ;
2017-03-05 16:44:50 +01:00
ClassDB : : bind_method ( D_METHOD ( " get_stylebox_types " ) , & Theme : : _get_stylebox_types ) ;
2017-02-13 12:47:24 +01:00
2020-09-12 18:30:40 +02:00
ClassDB : : bind_method ( D_METHOD ( " set_font " , " name " , " node_type " , " font " ) , & Theme : : set_font ) ;
ClassDB : : bind_method ( D_METHOD ( " get_font " , " name " , " node_type " ) , & Theme : : get_font ) ;
ClassDB : : bind_method ( D_METHOD ( " has_font " , " name " , " node_type " ) , & Theme : : has_font ) ;
2021-06-10 15:23:00 +02:00
ClassDB : : bind_method ( D_METHOD ( " rename_font " , " old_name " , " name " , " node_type " ) , & Theme : : rename_font ) ;
2020-09-12 18:30:40 +02:00
ClassDB : : bind_method ( D_METHOD ( " clear_font " , " name " , " node_type " ) , & Theme : : clear_font ) ;
ClassDB : : bind_method ( D_METHOD ( " get_font_list " , " node_type " ) , & Theme : : _get_font_list ) ;
2021-06-10 14:28:47 +02:00
ClassDB : : bind_method ( D_METHOD ( " get_font_types " ) , & Theme : : _get_font_types ) ;
2017-02-13 12:47:24 +01:00
2020-09-12 18:30:40 +02:00
ClassDB : : bind_method ( D_METHOD ( " set_color " , " name " , " node_type " , " color " ) , & Theme : : set_color ) ;
ClassDB : : bind_method ( D_METHOD ( " get_color " , " name " , " node_type " ) , & Theme : : get_color ) ;
ClassDB : : bind_method ( D_METHOD ( " has_color " , " name " , " node_type " ) , & Theme : : has_color ) ;
2021-06-10 15:23:00 +02:00
ClassDB : : bind_method ( D_METHOD ( " rename_color " , " old_name " , " name " , " node_type " ) , & Theme : : rename_color ) ;
2020-09-12 18:30:40 +02:00
ClassDB : : bind_method ( D_METHOD ( " clear_color " , " name " , " node_type " ) , & Theme : : clear_color ) ;
ClassDB : : bind_method ( D_METHOD ( " get_color_list " , " node_type " ) , & Theme : : _get_color_list ) ;
2021-06-10 14:28:47 +02:00
ClassDB : : bind_method ( D_METHOD ( " get_color_types " ) , & Theme : : _get_color_types ) ;
2017-02-13 12:47:24 +01:00
2020-09-12 18:30:40 +02:00
ClassDB : : bind_method ( D_METHOD ( " set_constant " , " name " , " node_type " , " constant " ) , & Theme : : set_constant ) ;
ClassDB : : bind_method ( D_METHOD ( " get_constant " , " name " , " node_type " ) , & Theme : : get_constant ) ;
ClassDB : : bind_method ( D_METHOD ( " has_constant " , " name " , " node_type " ) , & Theme : : has_constant ) ;
2021-06-10 15:23:00 +02:00
ClassDB : : bind_method ( D_METHOD ( " rename_constant " , " old_name " , " name " , " node_type " ) , & Theme : : rename_constant ) ;
2020-09-12 18:30:40 +02:00
ClassDB : : bind_method ( D_METHOD ( " clear_constant " , " name " , " node_type " ) , & Theme : : clear_constant ) ;
ClassDB : : bind_method ( D_METHOD ( " get_constant_list " , " node_type " ) , & Theme : : _get_constant_list ) ;
2021-06-10 14:28:47 +02:00
ClassDB : : bind_method ( D_METHOD ( " get_constant_types " ) , & Theme : : _get_constant_types ) ;
2017-02-13 12:47:24 +01:00
2018-11-27 18:33:14 +01:00
ClassDB : : bind_method ( D_METHOD ( " clear " ) , & Theme : : clear ) ;
2017-08-09 13:19:41 +02:00
ClassDB : : bind_method ( D_METHOD ( " set_default_font " , " font " ) , & Theme : : set_default_theme_font ) ;
ClassDB : : bind_method ( D_METHOD ( " get_default_font " ) , & Theme : : get_default_theme_font ) ;
2017-02-13 12:47:24 +01:00
2021-06-10 15:23:00 +02:00
ClassDB : : bind_method ( D_METHOD ( " set_theme_item " , " data_type " , " name " , " node_type " , " value " ) , & Theme : : set_theme_item ) ;
ClassDB : : bind_method ( D_METHOD ( " get_theme_item " , " data_type " , " name " , " node_type " ) , & Theme : : get_theme_item ) ;
ClassDB : : bind_method ( D_METHOD ( " has_theme_item " , " data_type " , " name " , " node_type " ) , & Theme : : has_theme_item ) ;
ClassDB : : bind_method ( D_METHOD ( " rename_theme_item " , " data_type " , " old_name " , " name " , " node_type " ) , & Theme : : rename_theme_item ) ;
ClassDB : : bind_method ( D_METHOD ( " clear_theme_item " , " data_type " , " name " , " node_type " ) , & Theme : : clear_theme_item ) ;
ClassDB : : bind_method ( D_METHOD ( " get_theme_item_list " , " data_type " , " node_type " ) , & Theme : : _get_theme_item_list ) ;
ClassDB : : bind_method ( D_METHOD ( " get_theme_item_types " , " data_type " ) , & Theme : : _get_theme_item_types ) ;
2020-09-12 18:30:40 +02:00
ClassDB : : bind_method ( D_METHOD ( " get_type_list " , " node_type " ) , & Theme : : _get_type_list ) ;
2016-06-17 21:00:27 +02:00
2017-03-05 16:44:50 +01:00
ClassDB : : bind_method ( D_METHOD ( " _emit_theme_changed " ) , & Theme : : _emit_theme_changed ) ;
2016-06-17 21:00:27 +02:00
2017-03-05 16:44:50 +01:00
ClassDB : : bind_method ( " copy_default_theme " , & Theme : : copy_default_theme ) ;
2019-01-26 22:21:53 +01:00
ClassDB : : bind_method ( D_METHOD ( " copy_theme " , " other " ) , & Theme : : copy_theme ) ;
2021-08-14 00:06:21 +02:00
ClassDB : : bind_method ( D_METHOD ( " merge_with " , " other " ) , & Theme : : merge_with ) ;
2016-06-17 21:00:27 +02:00
2017-03-05 16:44:50 +01:00
ADD_PROPERTY ( PropertyInfo ( Variant : : OBJECT , " default_font " , PROPERTY_HINT_RESOURCE_TYPE , " Font " ) , " set_default_font " , " get_default_font " ) ;
2021-06-10 15:23:00 +02:00
BIND_ENUM_CONSTANT ( DATA_TYPE_COLOR ) ;
BIND_ENUM_CONSTANT ( DATA_TYPE_CONSTANT ) ;
BIND_ENUM_CONSTANT ( DATA_TYPE_FONT ) ;
BIND_ENUM_CONSTANT ( DATA_TYPE_ICON ) ;
BIND_ENUM_CONSTANT ( DATA_TYPE_STYLEBOX ) ;
BIND_ENUM_CONSTANT ( DATA_TYPE_MAX ) ;
2014-02-10 02:10:30 +01:00
}
Theme : : Theme ( ) {
}
2017-03-05 16:44:50 +01:00
Theme : : ~ Theme ( ) {
2014-02-10 02:10:30 +01:00
}