summaryrefslogtreecommitdiffstats
path: root/src/net/java/joglutils/msg/nodes/Group.java
diff options
context:
space:
mode:
authorKenneth Russel <[email protected]>2007-03-18 11:58:01 +0000
committerKenneth Russel <[email protected]>2007-03-18 11:58:01 +0000
commite1f4a731f55ab29e3f23f87102af1b11c67cb0da (patch)
tree244171ec6562416e3c44341c13f903a29ad44c69 /src/net/java/joglutils/msg/nodes/Group.java
parent208b84ae11288b4edd190364528289240303cb5d (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.java124
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));
+ }
+ }
+}