/* * TouchGraph LLC. Apache-Style Software License * * * Copyright (c) 2002 Alexander Shapiro. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * 3. The end-user documentation included with the redistribution, * if any, must include the following acknowledgment: * "This product includes software developed by * TouchGraph LLC (http://www.touchgraph.com/)." * Alternately, this acknowledgment may appear in the software itself, * if and wherever such third-party acknowledgments normally appear. * * 4. The names "TouchGraph" or "TouchGraph LLC" must not be used to endorse * or promote products derived from this software without prior written * permission. For written permission, please contact * alex@touchgraph.com * * 5. Products derived from this software may not be called "TouchGraph", * nor may "TouchGraph" appear in their name, without prior written * permission of alex@touchgraph.com. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL TOUCHGRAPH OR ITS CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * ==================================================================== * */ package com.touchgraph.graphlayout.graphelements; import com.touchgraph.graphlayout.Node; import com.touchgraph.graphlayout.Edge; import com.touchgraph.graphlayout.TGException; import java.util.Vector; /** Locality: A way of representing a subset of a larger set of nodes. * Allows for both manipulation of the subset, and manipulation of the * larger set. For instance, one can call removeNode to delete it from * the subset, or deleteNode to remove it from the larger set. * * Locality is used in conjunction with LocalityUtils, which handle * locality shift animations. * * More synchronization will almost definitely be required. * * @author Alexander Shapiro * @version 1.20 */ public class Locality extends GraphEltSet { protected GraphEltSet completeEltSet; // ............ /** Constructor with GraphEltSet ges. */ public Locality(GraphEltSet ges) { super(); completeEltSet = ges; } public GraphEltSet getCompleteEltSet() { return completeEltSet; } public void addNode( Node n ) throws TGException { super.addNode(n); //If a new node is added to locality, add it to the complete elt set as well if (!completeEltSet.contains(n)) completeEltSet.addNode(n); } public void addEdge( Edge e ) { if(!contains(e)) { edges.addElement(e); e.from.localEdgeCount++; e.to.localEdgeCount++; } //If a new node edge is added to locality, add it to the complete elt set as well if (!completeEltSet.contains(e)) completeEltSet.addEdge(e); } public void addNodeWithEdges( Node n ) throws TGException { addNode(n); for (int i = 0 ; i < n.edgeNum(); i++) { Edge e=n.edgeAt(i); if(contains(e.getOtherEndpt(n))) addEdge(e); } } public Edge findEdge( Node from, Node to ) { Edge foundEdge=super.findEdge(from,to); if (foundEdge!=null && edges.contains(foundEdge)) return foundEdge; else return null; } public boolean deleteEdge( Edge e ) { if (e == null) return false; else { removeEdge(e); return completeEltSet.deleteEdge(e); } } public synchronized void deleteEdges( Vector edgesToDelete ) { removeEdges(edgesToDelete); completeEltSet.deleteEdges(edgesToDelete); } public boolean removeEdge( Edge e ) { if (e == null) return false; else { if(edges.removeElement(e)) { e.from.localEdgeCount--; e.to.localEdgeCount--; return true; } return false; } } public synchronized void removeEdges( Vector edgesToRemove ) { for (int i=0;i