diff options
author | Caio Marcelo de Oliveira Filho <caio.oliveira@openbossa.org> | 2009-08-12 20:53:54 (GMT) |
---|---|---|
committer | Caio Marcelo de Oliveira Filho <caio.oliveira@openbossa.org> | 2009-08-12 21:14:12 (GMT) |
commit | 114e4b6ca9a1871f75dc5b9d443ab1e344eb99af (patch) | |
tree | fc6bb942ae80800aa1e5d611fba373c5bf2ba211 /src/gui/graphicsview | |
parent | 9fe513c2809cfc0446fdde6870b23e0094ac955f (diff) | |
download | Qt-114e4b6ca9a1871f75dc5b9d443ab1e344eb99af.zip Qt-114e4b6ca9a1871f75dc5b9d443ab1e344eb99af.tar.gz Qt-114e4b6ca9a1871f75dc5b9d443ab1e344eb99af.tar.bz2 |
QGraphicsAnchorLayout: fix restore simplification logic
Patch from Jan-Arve.
Diffstat (limited to 'src/gui/graphicsview')
-rw-r--r-- | src/gui/graphicsview/qgraphicsanchorlayout_p.cpp | 44 |
1 files changed, 13 insertions, 31 deletions
diff --git a/src/gui/graphicsview/qgraphicsanchorlayout_p.cpp b/src/gui/graphicsview/qgraphicsanchorlayout_p.cpp index f0e0660..7e0541e 100644 --- a/src/gui/graphicsview/qgraphicsanchorlayout_p.cpp +++ b/src/gui/graphicsview/qgraphicsanchorlayout_p.cpp @@ -461,19 +461,16 @@ static void restoreSimplifiedAnchor(Graph<AnchorVertex, AnchorData> &g, } prev = v1; } - g.removeEdge(before, after); } else if (edge->type == AnchorData::Parallel) { ParallelAnchorData* parallelEdge = static_cast<ParallelAnchorData*>(edge); AnchorData *parallelEdges[2] = {parallelEdge->firstEdge, - parallelEdge->secondEdge}; - // must remove the old anchor first - g.removeEdge(before, after); + parallelEdge->secondEdge}; for (int i = 0; i < 2; ++i) { AnchorData *data = parallelEdges[i]; - if (data->type != AnchorData::Normal) { - restoreSimplifiedAnchor(g, data, before, after); - } else { + if (data->type == AnchorData::Normal) { g.createEdge(before, after, data); + } else { + restoreSimplifiedAnchor(g, data, before, after); } } } @@ -483,32 +480,17 @@ void QGraphicsAnchorLayoutPrivate::restoreSimplifiedGraph(Orientation orientatio { Q_Q(QGraphicsAnchorLayout); Graph<AnchorVertex, AnchorData> &g = graph[orientation]; - AnchorVertex *v = g.rootVertex(); - - if (!v) - return; - QSet<AnchorVertex*> visited; - QStack<AnchorVertex *> stack; - stack.push(v); - QGraphicsAnchorLayout::Edge layoutCenterEdge = pickEdge(QGraphicsAnchorLayout::HCenter, orientation); - // walk depth-first. - while (!stack.isEmpty()) { - v = stack.pop(); - QList<AnchorVertex *> vertices = g.adjacentVertices(v); - const int count = vertices.count(); - for (int i = 0; i < count; ++i) { - AnchorVertex *next = vertices.at(i); - if (next->m_item == q && next->m_edge == layoutCenterEdge) - continue; - if (visited.contains(next)) - continue; - - AnchorData *edge = g.edgeData(v, next); - if (edge->type != AnchorData::Normal) - restoreSimplifiedAnchor(g, edge, v, next); + QList<QPair<AnchorVertex*, AnchorVertex*> > connections = g.connections(); + for (int i = 0; i < connections.count(); ++i) { + AnchorVertex *v1 = connections.at(i).first; + AnchorVertex *v2 = connections.at(i).second; + AnchorData *edge = g.edgeData(v1, v2); + if (edge->type != AnchorData::Normal) { + AnchorData *oldEdge = g.takeEdge(v1, v2); + restoreSimplifiedAnchor(g, edge, v1, v2); + delete oldEdge; } - visited.insert(v); } } |