diff options
author | Kenneth Russel <[email protected]> | 2007-03-18 11:58:01 +0000 |
---|---|---|
committer | Kenneth Russel <[email protected]> | 2007-03-18 11:58:01 +0000 |
commit | e1f4a731f55ab29e3f23f87102af1b11c67cb0da (patch) | |
tree | 244171ec6562416e3c44341c13f903a29ad44c69 /src/net/java/joglutils/msg/nodes/Group.java | |
parent | 208b84ae11288b4edd190364528289240303cb5d (diff) |
Initial checkin of the Minimal Scene Graph (MSG) library, intentended
for experimentation with both 3D and 2D/3D interaction.
git-svn-id: file:///usr/local/projects/SUN/JOGL/git-svn/svn-server-sync/joglutils/trunk@44 83d24430-9974-4f80-8418-2cc3294053b9
Diffstat (limited to 'src/net/java/joglutils/msg/nodes/Group.java')
-rw-r--r-- | src/net/java/joglutils/msg/nodes/Group.java | 124 |
1 files changed, 124 insertions, 0 deletions
diff --git a/src/net/java/joglutils/msg/nodes/Group.java b/src/net/java/joglutils/msg/nodes/Group.java new file mode 100644 index 0000000..f9a961b --- /dev/null +++ b/src/net/java/joglutils/msg/nodes/Group.java @@ -0,0 +1,124 @@ +/* + * Copyright (c) 2007 Sun Microsystems, Inc. All Rights Reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are + * met: + * + * - Redistribution of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * - Redistribution 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. + * + * Neither the name of Sun Microsystems, Inc. or the names of + * contributors may be used to endorse or promote products derived from + * this software without specific prior written permission. + * + * This software is provided "AS IS," without a warranty of any kind. ALL + * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, + * INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A + * PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN + * MICROSYSTEMS, INC. ("SUN") AND ITS LICENSORS SHALL NOT BE LIABLE FOR + * ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR + * DISTRIBUTING THIS SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN OR + * ITS LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR FOR + * DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE + * DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, + * ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE, EVEN IF + * SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. + * + * You acknowledge that this software is not designed or intended for use + * in the design, construction, operation or maintenance of any nuclear + * facility. + * + */ + +package net.java.joglutils.msg.nodes; + +import java.util.*; + +import net.java.joglutils.msg.actions.*; + +/** A node which manages other Node instances. */ + +public class Group extends Node { + private List<Node> children = new ArrayList<Node>(); + + /** Append a child node to the list of children nodes this group node is managing. */ + public void addChild(Node child) { + children.add(child); + } + + /** Adds a child so that it becomes the one with the given index. */ + public void insertChild(Node child, int index) { + children.add(index, child); + } + + /** Returns the child node with the given index. */ + public Node getChild(int index) { + return children.get(index); + } + + /** Finds the index of given child within the group. Returns -1 if not found. */ + public int findChild(Node node) { + return children.indexOf(node); + } + + /** Returns number of children. */ + public int getNumChildren() { + return children.size(); + } + + /** Removes the child with given index from the group. + + @throws IndexOutOfBoundsException if the index is less than 0 or + greater than the number of children + */ + public void removeChild(int index) throws IndexOutOfBoundsException { + children.remove(index); + } + + /** Removes the given child from the group. This is a convenience + method equivalent to calling {@link #findChild findChild} and, + if the node is found, passing the index to {@link #removeChild + removeChild}. + */ + public void removeChild(Node node) { + int idx = findChild(node); + if (idx >= 0) + removeChild(idx); + } + + /** Removes all children from this Group node. */ + public void removeAllChildren() { + children.clear(); + } + + /** Replaces the child at the given index with the new child. + + @throws IndexOutOfBoundsException if the index is less than 0 or + greater than the number of children + */ + public void replaceChild(int index, Node newChild) throws IndexOutOfBoundsException { + removeChild(index); + insertChild(newChild, index); + } + + /** Replaces the old child with the new child. This is a convenience + method. It will simply call {@link #findChild findChild} with + oldChild as argument, and call replaceChild(int, SoNode*) if the + child is found. */ + public void replaceChild(Node oldChild, Node newChild) { + int idx = findChild(oldChild); + if (idx >= 0) + replaceChild(idx, newChild); + } + + public void doAction(Action action) { + for (int i = 0; i < getNumChildren(); i++) { + action.apply(getChild(i)); + } + } +} |