Merge pull request #98401 from vaner-org/green-arrow-priority-for-transition-selection

Prioritize proximity to green arrow when selecting overlapping transitions in AnimationNodeStateMachine
This commit is contained in:
Rémi Verschelde 2024-12-02 15:50:17 +01:00
commit 463c479ac8
No known key found for this signature in database
GPG key ID: C3336907360768E1

View file

@ -228,9 +228,12 @@ void AnimationNodeStateMachineEditor::_state_machine_gui_input(const Ref<InputEv
} }
} }
//test the lines now // Test the transition lines.
int closest = -1; int closest = -1;
float closest_d = 1e20; float closest_d = 1e20;
Vector<int> close_candidates;
// First find closest lines using point-to-segment distance.
for (int i = 0; i < transition_lines.size(); i++) { for (int i = 0; i < transition_lines.size(); i++) {
Vector2 s[2] = { Vector2 s[2] = {
transition_lines[i].from, transition_lines[i].from,
@ -238,13 +241,34 @@ void AnimationNodeStateMachineEditor::_state_machine_gui_input(const Ref<InputEv
}; };
Vector2 cpoint = Geometry2D::get_closest_point_to_segment(mb->get_position(), s); Vector2 cpoint = Geometry2D::get_closest_point_to_segment(mb->get_position(), s);
float d = cpoint.distance_to(mb->get_position()); float d = cpoint.distance_to(mb->get_position());
if (d > transition_lines[i].width) { if (d > transition_lines[i].width) {
continue; continue;
} }
if (d < closest_d) { // If this is very close to our current closest distance, add it to candidates.
closest = i; if (Math::abs(d - closest_d) < 2.0) { // Within 2 pixels.
close_candidates.push_back(i);
} else if (d < closest_d) {
closest_d = d; closest_d = d;
closest = i;
close_candidates.clear();
close_candidates.push_back(i);
}
}
// Use midpoint distance as bias.
if (close_candidates.size() > 1) {
float best_midpoint_dist = 1e20;
for (int idx : close_candidates) {
Vector2 midpoint = (transition_lines[idx].from + transition_lines[idx].to) / 2.0;
float midpoint_dist = midpoint.distance_to(mb->get_position());
if (midpoint_dist < best_midpoint_dist) {
best_midpoint_dist = midpoint_dist;
closest = idx;
}
} }
} }