diff options
author | David Robillard <d@drobilla.net> | 2015-10-26 17:36:03 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2015-10-26 17:36:03 +0000 |
commit | 1b005502bb4f3a271c514e46ce66d3b24b2a5f38 (patch) | |
tree | f76a0ef36c35138cde3a7170fa5b094d6cbd1f05 /src/Canvas.cpp | |
parent | 128bdd836148ad902470d45f4eb36cb0a2045f4f (diff) | |
download | ganv-1b005502bb4f3a271c514e46ce66d3b24b2a5f38.tar.gz ganv-1b005502bb4f3a271c514e46ce66d3b24b2a5f38.tar.bz2 ganv-1b005502bb4f3a271c514e46ce66d3b24b2a5f38.zip |
Add support for edges that do not constrain the layout
git-svn-id: http://svn.drobilla.net/lad/trunk/ganv@5792 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/Canvas.cpp')
-rw-r--r-- | src/Canvas.cpp | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/src/Canvas.cpp b/src/Canvas.cpp index 3c59351..7d79ffe 100644 --- a/src/Canvas.cpp +++ b/src/Canvas.cpp @@ -745,6 +745,9 @@ GanvCanvasImpl::layout_dot(const std::string& filename) ss << edge->impl->head << (flow_right ? ":w" : ":n"); agsafeset(e, (char*)"headport", (char*)ss.str().c_str(), (char*)""); } + if (!ganv_edge_get_constraining(edge)) { + agsafeset(e, (char*)"constraint", "false", (char*)""); + } } else { std::cerr << "Unable to find graphviz node" << std::endl; } @@ -861,8 +864,12 @@ GanvCanvasImpl::layout_calculate(double dur, bool update) // Calculate attractive spring forces for edges FOREACH_EDGE(_edges, i) { const GanvEdge* const edge = *i; - GanvNode* tail = ganv_edge_get_tail(edge); - GanvNode* head = ganv_edge_get_head(edge); + if (!ganv_edge_get_constraining(edge)) { + continue; + } + + GanvNode* tail = ganv_edge_get_tail(edge); + GanvNode* head = ganv_edge_get_head(edge); if (GANV_IS_PORT(tail)) { tail = GANV_NODE(ganv_port_get_module(GANV_PORT(tail))); } |