Added step support when exporting integers.
Added step support when exporting integers. This wasn't possible before and was kinda unclear see #21441
This commit is contained in:
parent
c432ce4ee1
commit
0e37829031
3 changed files with 12 additions and 7 deletions
|
@ -817,10 +817,10 @@ void EditorPropertyInteger::_bind_methods() {
|
|||
ClassDB::bind_method(D_METHOD("_value_changed"), &EditorPropertyInteger::_value_changed);
|
||||
}
|
||||
|
||||
void EditorPropertyInteger::setup(int p_min, int p_max, bool p_allow_greater, bool p_allow_lesser) {
|
||||
void EditorPropertyInteger::setup(int p_min, int p_max, int p_step, bool p_allow_greater, bool p_allow_lesser) {
|
||||
spin->set_min(p_min);
|
||||
spin->set_max(p_max);
|
||||
spin->set_step(1);
|
||||
spin->set_step(p_step);
|
||||
spin->set_allow_greater(p_allow_greater);
|
||||
spin->set_allow_lesser(p_allow_lesser);
|
||||
}
|
||||
|
@ -2663,7 +2663,7 @@ bool EditorInspectorDefaultPlugin::parse_property(Object *p_object, Variant::Typ
|
|||
|
||||
} else {
|
||||
EditorPropertyInteger *editor = memnew(EditorPropertyInteger);
|
||||
int min = 0, max = 65535;
|
||||
int min = 0, max = 65535, step = 1;
|
||||
bool greater = true, lesser = true;
|
||||
|
||||
if (p_hint == PROPERTY_HINT_RANGE && p_hint_text.get_slice_count(",") >= 2) {
|
||||
|
@ -2671,6 +2671,11 @@ bool EditorInspectorDefaultPlugin::parse_property(Object *p_object, Variant::Typ
|
|||
lesser = false;
|
||||
min = p_hint_text.get_slice(",", 0).to_int();
|
||||
max = p_hint_text.get_slice(",", 1).to_int();
|
||||
|
||||
if (p_hint_text.get_slice_count(",") >= 3) {
|
||||
step = p_hint_text.get_slice(",", 2).to_int();
|
||||
}
|
||||
|
||||
for (int i = 2; i < p_hint_text.get_slice_count(","); i++) {
|
||||
String slice = p_hint_text.get_slice(",", i).strip_edges();
|
||||
if (slice == "or_greater") {
|
||||
|
@ -2682,7 +2687,7 @@ bool EditorInspectorDefaultPlugin::parse_property(Object *p_object, Variant::Typ
|
|||
}
|
||||
}
|
||||
|
||||
editor->setup(min, max, greater, lesser);
|
||||
editor->setup(min, max, step, greater, lesser);
|
||||
|
||||
add_property_editor(p_path, editor);
|
||||
}
|
||||
|
|
|
@ -265,7 +265,7 @@ protected:
|
|||
|
||||
public:
|
||||
virtual void update_property();
|
||||
void setup(int p_min, int p_max, bool p_allow_greater, bool p_allow_lesser);
|
||||
void setup(int p_min, int p_max, int p_step, bool p_allow_greater, bool p_allow_lesser);
|
||||
EditorPropertyInteger();
|
||||
};
|
||||
|
||||
|
|
|
@ -337,7 +337,7 @@ void EditorPropertyArray::update_property() {
|
|||
} break;
|
||||
case Variant::INT: {
|
||||
EditorPropertyInteger *editor = memnew(EditorPropertyInteger);
|
||||
editor->setup(-100000, 100000, true, true);
|
||||
editor->setup(-100000, 100000, 1, true, true);
|
||||
prop = editor;
|
||||
|
||||
} break;
|
||||
|
@ -800,7 +800,7 @@ void EditorPropertyDictionary::update_property() {
|
|||
} break;
|
||||
case Variant::INT: {
|
||||
EditorPropertyInteger *editor = memnew(EditorPropertyInteger);
|
||||
editor->setup(-100000, 100000, true, true);
|
||||
editor->setup(-100000, 100000, 1, true, true);
|
||||
prop = editor;
|
||||
|
||||
} break;
|
||||
|
|
Loading…
Reference in a new issue