public void coarsen(HierarchicalGraph g) { HierarchicalGraph graph = g; int retract = 0; int count = 0; for (Edge e : graph.getEdgesAndMetaEdges().toArray()) { Node a = e.getSource(); Node b = e.getTarget(); count++; if (graph.getParent(a) == graph.getParent(b) && graph.getLevel(a) == 0) { float x = (a.getNodeData().x() + b.getNodeData().x()) / 2; float y = (a.getNodeData().y() + b.getNodeData().y()) / 2; Node parent = graph.groupNodes(new Node[] {a, b}); parent.getNodeData().setX(x); parent.getNodeData().setY(y); graph.retract(parent); retract++; } } }
public void groupCluster(Cluster cluster) { GraphModel gm = Lookup.getDefault().lookup(GraphController.class).getModel(); if (gm != null) { HierarchicalGraph graph = gm.getHierarchicalGraphVisible(); Node[] newGroup = cluster.getNodes(); float centroidX = 0; float centroidY = 0; int len = 0; Node group = graph.groupNodes(newGroup); cluster.setMetaNode(group); group.getNodeData().setLabel("Group"); group.getNodeData().setSize(10f); for (Node child : newGroup) { centroidX += child.getNodeData().x(); centroidY += child.getNodeData().y(); len++; } centroidX /= len; centroidY /= len; group.getNodeData().setX(centroidX); group.getNodeData().setY(centroidY); } }