From 696ac88330e267a82b66f1a6d0e6f2807402bc9f Mon Sep 17 00:00:00 2001 From: Claudio Barril Date: Mon, 25 Aug 2014 23:32:17 -0300 Subject: [PATCH] fix side as first level nodes are drawn --- .../importer/freemind/FreemindImporter.java | 71 ++++--------------- 1 file changed, 15 insertions(+), 56 deletions(-) diff --git a/wise-webapp/src/main/java/com/wisemapping/importer/freemind/FreemindImporter.java b/wise-webapp/src/main/java/com/wisemapping/importer/freemind/FreemindImporter.java index bf35454b..e419e6fd 100755 --- a/wise-webapp/src/main/java/com/wisemapping/importer/freemind/FreemindImporter.java +++ b/wise-webapp/src/main/java/com/wisemapping/importer/freemind/FreemindImporter.java @@ -230,6 +230,8 @@ public class FreemindImporter TopicType currentWiseTopic = wiseParent; int order = 0; + int firstLevelRightOrder = 0; + int firstLevelLeftOrder = 1; for (Object element : freeChilden) { if (element instanceof Node) { @@ -247,7 +249,13 @@ public class FreemindImporter if (depth != 1) { norder = order++; } else { - norder = calcFirstLevelOrder(freeChilden, freeChild); + if (freeChild.getPOSITION().equals(POSITION_LEFT)) { + norder = firstLevelLeftOrder; + firstLevelLeftOrder = firstLevelLeftOrder + 2; + } else { + norder = firstLevelRightOrder; + firstLevelRightOrder = firstLevelRightOrder + 2; + } } wiseChild.setOrder(norder); @@ -343,53 +351,6 @@ public class FreemindImporter } } - /** - * Sort the freemind node following this pattern: - *

- * 0 -> 3 - * 1 -> 1 - * 2 -> 0 - * 3 -> 2 - * 4 -> 4 - */ - private int calcFirstLevelOrder(@NotNull List freeChilden, @Nullable Node freeChild) { - final List nodes = new ArrayList(); - int result; - - // Collect all the nodes of the same side ... - for (Object child : freeChilden) { - if (child instanceof Node) { - Node node = (Node) child; - - final String side = node.getPOSITION(); - if (side == freeChild.getPOSITION() || freeChild.getPOSITION().equals(side)) { - nodes.add(node); - } - } - } - - // What is the index of the current node ? - int nodeIndex = 0; - for (Node node : nodes) { - if (node == freeChild) { - break; - } - nodeIndex++; - } - - int size = nodes.size(); - int center = (size - 1) / 2; - result = nodeIndex - center; - - if (result < 0) { - result = (result * ORDER_SEPARATION_FACTOR * -2) - 1; - - } else { - result = result * ORDER_SEPARATION_FACTOR * 2; - } - return result; - } - /** * Position is (x,y). * x values greater than 0 are right axis @@ -420,16 +381,14 @@ public class FreemindImporter int y; if (depth == 1) { - // Follow the following algorithm ... - // Order: 3 = -100 1 - // Order: 1 = -50 2 - // Order: 0 = 0 3 - // Order: 2 = 50 4 - // Order: 4 = 100 5 + // pair order numbers represent nodes at the right + // odd order numbers represent nodes at the left if (order % 2 == 0) { - y = ROOT_LEVEL_TOPIC_HEIGHT * order; + int multiplier = (int) ((order - Math.floor((childrenCount - 1) / 2)) * 2); + y = multiplier * ROOT_LEVEL_TOPIC_HEIGHT; } else { - y = -ROOT_LEVEL_TOPIC_HEIGHT * (order + 1); + int multiplier = (int) ((order - Math.floor(childrenCount / 2)) * 2); + y = multiplier * ROOT_LEVEL_TOPIC_HEIGHT; } } else {