|
@@ -3042,7 +3042,7 @@ void Control::set_layout_direction(Control::LayoutDirection p_direction) {
|
|
|
if (data.layout_dir == p_direction) {
|
|
|
return;
|
|
|
}
|
|
|
- ERR_FAIL_INDEX((int)p_direction, 4);
|
|
|
+ ERR_FAIL_INDEX(p_direction, LAYOUT_DIRECTION_MAX);
|
|
|
|
|
|
data.layout_dir = p_direction;
|
|
|
|
|
@@ -3115,13 +3115,20 @@ bool Control::is_layout_rtl() const {
|
|
|
String locale = TranslationServer::get_singleton()->get_tool_locale();
|
|
|
const_cast<Control *>(this)->data.is_rtl = TS->is_locale_right_to_left(locale);
|
|
|
}
|
|
|
- } else if (data.layout_dir == LAYOUT_DIRECTION_LOCALE) {
|
|
|
+ } else if (data.layout_dir == LAYOUT_DIRECTION_APPLICATION_LOCALE) {
|
|
|
if (GLOBAL_GET(SNAME("internationalization/rendering/force_right_to_left_layout_direction"))) {
|
|
|
const_cast<Control *>(this)->data.is_rtl = true;
|
|
|
} else {
|
|
|
String locale = TranslationServer::get_singleton()->get_tool_locale();
|
|
|
const_cast<Control *>(this)->data.is_rtl = TS->is_locale_right_to_left(locale);
|
|
|
}
|
|
|
+ } else if (data.layout_dir == LAYOUT_DIRECTION_SYSTEM_LOCALE) {
|
|
|
+ if (GLOBAL_GET(SNAME("internationalization/rendering/force_right_to_left_layout_direction"))) {
|
|
|
+ const_cast<Control *>(this)->data.is_rtl = true;
|
|
|
+ } else {
|
|
|
+ String locale = OS::get_singleton()->get_locale();
|
|
|
+ const_cast<Control *>(this)->data.is_rtl = TS->is_locale_right_to_left(locale);
|
|
|
+ }
|
|
|
} else {
|
|
|
const_cast<Control *>(this)->data.is_rtl = (data.layout_dir == LAYOUT_DIRECTION_RTL);
|
|
|
}
|
|
@@ -3574,7 +3581,7 @@ void Control::_bind_methods() {
|
|
|
ADD_GROUP("Layout", "");
|
|
|
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "clip_contents"), "set_clip_contents", "is_clipping_contents");
|
|
|
ADD_PROPERTY(PropertyInfo(Variant::VECTOR2, "custom_minimum_size", PROPERTY_HINT_NONE, "suffix:px"), "set_custom_minimum_size", "get_custom_minimum_size");
|
|
|
- ADD_PROPERTY(PropertyInfo(Variant::INT, "layout_direction", PROPERTY_HINT_ENUM, "Inherited,Based on Locale,Left-to-Right,Right-to-Left"), "set_layout_direction", "get_layout_direction");
|
|
|
+ ADD_PROPERTY(PropertyInfo(Variant::INT, "layout_direction", PROPERTY_HINT_ENUM, "Inherited,Based on Application Locale,Left-to-Right,Right-to-Left,Based on System Locale"), "set_layout_direction", "get_layout_direction");
|
|
|
ADD_PROPERTY(PropertyInfo(Variant::INT, "layout_mode", PROPERTY_HINT_ENUM, "Position,Anchors,Container,Uncontrolled", PROPERTY_USAGE_DEFAULT | PROPERTY_USAGE_INTERNAL), "_set_layout_mode", "_get_layout_mode");
|
|
|
ADD_PROPERTY_DEFAULT("layout_mode", LayoutMode::LAYOUT_MODE_POSITION);
|
|
|
|
|
@@ -3723,9 +3730,14 @@ void Control::_bind_methods() {
|
|
|
BIND_ENUM_CONSTANT(ANCHOR_END);
|
|
|
|
|
|
BIND_ENUM_CONSTANT(LAYOUT_DIRECTION_INHERITED);
|
|
|
- BIND_ENUM_CONSTANT(LAYOUT_DIRECTION_LOCALE);
|
|
|
+ BIND_ENUM_CONSTANT(LAYOUT_DIRECTION_APPLICATION_LOCALE);
|
|
|
BIND_ENUM_CONSTANT(LAYOUT_DIRECTION_LTR);
|
|
|
BIND_ENUM_CONSTANT(LAYOUT_DIRECTION_RTL);
|
|
|
+ BIND_ENUM_CONSTANT(LAYOUT_DIRECTION_SYSTEM_LOCALE);
|
|
|
+ BIND_ENUM_CONSTANT(LAYOUT_DIRECTION_MAX);
|
|
|
+#ifndef DISABLE_DEPRECATED
|
|
|
+ BIND_ENUM_CONSTANT(LAYOUT_DIRECTION_LOCALE);
|
|
|
+#endif // DISABLE_DEPRECATED
|
|
|
|
|
|
BIND_ENUM_CONSTANT(TEXT_DIRECTION_INHERITED);
|
|
|
BIND_ENUM_CONSTANT(TEXT_DIRECTION_AUTO);
|