diff options
Diffstat (limited to 'examples')
-rwxr-xr-x | examples/graph.c | 48 |
1 files changed, 32 insertions, 16 deletions
diff --git a/examples/graph.c b/examples/graph.c index a224a5b..edbb5b3 100755 --- a/examples/graph.c +++ b/examples/graph.c @@ -40,6 +40,8 @@ typedef struct { b8 hover; b8 highlight; f64 distance; + f64 drag_x; + f64 drag_y; } Node; typedef struct { @@ -301,8 +303,11 @@ void highlight_path(i64 src, i64 dst) { world.nodes[min_index].distance = min_distance; - // Repeat until there's no connected nodes left + // Repeat until we got the destination node // + + if (min_index == dst) + break; } // If path not found, stop @@ -446,8 +451,12 @@ void update_and_render_frame(void) { if (world.nodes[i].enabled && world.nodes[i].hover) { drag_on = 1; drag_node = i; - drag_x0 = world.nodes[i].x - platform.cursor_x; - drag_y0 = world.nodes[i].y - platform.cursor_y; + drag_x0 = platform.cursor_x; + drag_y0 = platform.cursor_y; + for (i64 j = 0; j < MAX_NUM_NODES; ++j) { + world.nodes[j].drag_x = world.nodes[j].x; + world.nodes[j].drag_y = world.nodes[j].y; + } break; } @@ -479,25 +488,32 @@ void update_and_render_frame(void) { if (drag_on) { if (check_node_index(drag_node)) { - f64 r = world.nodes[drag_node].radius; - f64 x = drag_x0 + platform.cursor_x; - f64 y = drag_y0 + platform.cursor_y; + f64 dx = platform.cursor_x - drag_x0; + f64 dy = platform.cursor_y - drag_y0; - b8 collision = 0; + world.nodes[drag_node].x = world.nodes[drag_node].drag_x + dx; + world.nodes[drag_node].y = world.nodes[drag_node].drag_y + dy; for (i64 i = 0; i < MAX_NUM_NODES; ++i) { - Node n = world.nodes[i]; - if (i != drag_node && n.enabled && distance_between(n.x, n.y, x, y) < n.radius + r) { - collision = 1; - break; + if (i == drag_node) continue; + + b8 is_neighbor = 0; + + for (i64 k = 0; k < MAX_NUM_EDGES; ++k) { + Edge e = world.edges[k]; + if ((e.src == drag_node && e.dst == i) || (e.src == i && e.dst == drag_node)) { + is_neighbor = 1; + break; + } } - } - if (!collision) { - world.nodes[drag_node].x = x; - world.nodes[drag_node].y = y; - path_changed = 1; + if (is_neighbor) { + world.nodes[i].x = world.nodes[i].drag_x + dx * .3; + world.nodes[i].y = world.nodes[i].drag_y + dy * .3; + } } + + path_changed = 1; } if (!platform.key_down[BUTTON_LEFT]) |