001: /*
002: * $RCSfile: MFNode.java,v $
003: *
004: * @(#)MFNode.java 1.9 98/11/05 20:40:32
005: *
006: * Copyright (c) 1996-1998 Sun Microsystems, Inc. All Rights Reserved.
007: *
008: * Sun grants you ("Licensee") a non-exclusive, royalty free, license to use,
009: * modify and redistribute this software in source and binary code form,
010: * provided that i) this copyright notice and license appear on all copies of
011: * the software; and ii) Licensee does not utilize the software in a manner
012: * which is disparaging to Sun.
013: *
014: * This software is provided "AS IS," without a warranty of any kind. ALL
015: * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING ANY
016: * IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR
017: * NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN AND ITS LICENSORS SHALL NOT BE
018: * LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING
019: * OR DISTRIBUTING THE SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN OR ITS
020: * LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR FOR DIRECT,
021: * INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER
022: * CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF THE USE OF
023: * OR INABILITY TO USE SOFTWARE, EVEN IF SUN HAS BEEN ADVISED OF THE
024: * POSSIBILITY OF SUCH DAMAGES.
025: *
026: * This software is not designed or intended for use in on-line control of
027: * aircraft, air traffic, aircraft navigation or aircraft communications; or in
028: * the design, construction, operation or maintenance of any nuclear
029: * facility. Licensee represents and warrants that it will not use or
030: * redistribute the Software for such purposes.
031: *
032: * $Revision: 1.2 $
033: * $Date: 2005/02/03 23:07:14 $
034: * $State: Exp $
035: */
036: /*
037: * @Author: Rick Goldberg
038: * @Author: Doug Gehringer
039: */
040: package vrml.field;
041:
042: import vrml.BaseNode;
043: import vrml.Field;
044:
045: /** Description of the Class */
046: public class MFNode extends vrml.MField {
047: org.jdesktop.j3d.loaders.vrml97.impl.MFNode impl;
048:
049: /**
050: *Constructor for the MFNode object
051: *
052: *@param init Description of the Parameter
053: */
054: public MFNode(org.jdesktop.j3d.loaders.vrml97.impl.MFNode init) {
055: super (init);
056: impl = init;
057: }
058:
059: /**
060: * Description of the Method
061: *
062: *@return Description of the Return Value
063: */
064: public synchronized Object clone() {
065: return new MFNode(
066: (org.jdesktop.j3d.loaders.vrml97.impl.MFNode) impl
067: .clone());
068: }
069:
070: /**
071: *Constructor for the MFNode object
072: *
073: *@param nodes Description of the Parameter
074: */
075: MFNode(BaseNode nodes[]) {
076: super (null);
077: org.jdesktop.j3d.loaders.vrml97.impl.BaseNode[] implNodes = new org.jdesktop.j3d.loaders.vrml97.impl.BaseNode[nodes.length];
078: for (int i = 0; i < nodes.length; i++) {
079: implNodes[i] = Field.getImpl(nodes[i]);
080: }
081: impl = new org.jdesktop.j3d.loaders.vrml97.impl.MFNode(
082: implNodes);
083: implField = impl;
084: }
085:
086: /**
087: * Gets the value attribute of the MFNode object
088: *
089: *@param values Description of the Parameter
090: */
091: public void getValue(BaseNode values[]) {
092: org.jdesktop.j3d.loaders.vrml97.impl.BaseNode[] implNodes = impl
093: .getValue();
094: for (int i = 0; i < implNodes.length; i++) {
095: values[i] = implNodes[i].wrap();
096: }
097: }
098:
099: /**
100: * Gets the value attribute of the MFNode object
101: *
102: *@return The value value
103: */
104: public BaseNode[] getValue() {
105: org.jdesktop.j3d.loaders.vrml97.impl.BaseNode[] implNodes = impl
106: .getValue();
107: BaseNode[] nodes = new BaseNode[implNodes.length];
108: for (int i = 0; i < implNodes.length; i++) {
109: nodes[i] = implNodes[i].wrap();
110: }
111: return nodes;
112: }
113:
114: /**
115: * Sets the value attribute of the MFNode object
116: *
117: *@param values The new value value
118: */
119: public void setValue(BaseNode[] values) {
120: org.jdesktop.j3d.loaders.vrml97.impl.BaseNode[] implNodes = new org.jdesktop.j3d.loaders.vrml97.impl.BaseNode[values.length];
121: for (int i = 0; i < values.length; i++) {
122: implNodes[i] = Field.getImpl(values[i]);
123: }
124: impl.setValue(implNodes);
125: }
126:
127: /**
128: * Sets the value attribute of the MFNode object
129: *
130: *@param size The new value value
131: *@param values The new value value
132: */
133: public void setValue(int size, BaseNode[] values) {
134: org.jdesktop.j3d.loaders.vrml97.impl.BaseNode[] implNodes = new org.jdesktop.j3d.loaders.vrml97.impl.BaseNode[size];
135: for (int i = 0; i < size; i++) {
136: implNodes[i] = Field.getImpl(values[i]);
137: }
138: impl.setValue(size, implNodes);
139: }
140:
141: /**
142: * Sets the value attribute of the MFNode object
143: *
144: *@param n The new value value
145: */
146: public void setValue(ConstMFNode n) {
147: impl.setValue(n.impl);
148: }
149:
150: /**
151: * Description of the Method
152: *
153: *@param index Description of the Parameter
154: *@return Description of the Return Value
155: */
156: public BaseNode get1Value(int index) {
157: return impl.get1Value(index).wrap();
158: }
159:
160: /**
161: * Description of the Method
162: *
163: *@param index Description of the Parameter
164: *@param n Description of the Parameter
165: */
166: public void set1Value(int index, BaseNode n) {
167: impl.set1Value(index, vrml.Field.getImpl(n));
168: }
169:
170: /**
171: * Description of the Method
172: *
173: *@param index Description of the Parameter
174: *@param n Description of the Parameter
175: */
176: public void set1Value(int index, ConstSFNode n) {
177: impl.set1Value(index, n.impl);
178: }
179:
180: /**
181: * Description of the Method
182: *
183: *@param index Description of the Parameter
184: *@param n Description of the Parameter
185: */
186: public void set1Value(int index, SFNode n) {
187: impl.set1Value(index, n.impl);
188: }
189:
190: /**
191: * Adds a feature to the Value attribute of the MFNode object
192: *
193: *@param n The feature to be added to the Value attribute
194: */
195: public void addValue(BaseNode n) {
196: impl.addValue(vrml.Field.getImpl(n));
197: }
198:
199: /**
200: * Adds a feature to the Value attribute of the MFNode object
201: *
202: *@param n The feature to be added to the Value attribute
203: */
204: public void addValue(ConstSFNode n) {
205: impl.addValue(n.impl);
206: }
207:
208: /**
209: * Adds a feature to the Value attribute of the MFNode object
210: *
211: *@param n The feature to be added to the Value attribute
212: */
213: public void addValue(SFNode n) {
214: impl.addValue(n.impl);
215: }
216:
217: /**
218: * Description of the Method
219: *
220: *@param index Description of the Parameter
221: *@param n Description of the Parameter
222: */
223: public void insertValue(int index, BaseNode n) {
224: impl.insertValue(index, vrml.Field.getImpl(n));
225: }
226:
227: /**
228: * Description of the Method
229: *
230: *@param index Description of the Parameter
231: *@param n Description of the Parameter
232: */
233: public void insertValue(int index, ConstSFNode n) {
234: impl.insertValue(index, n.impl);
235: }
236:
237: /**
238: * Description of the Method
239: *
240: *@param index Description of the Parameter
241: *@param n Description of the Parameter
242: */
243: public void insertValue(int index, SFNode n) {
244: impl.insertValue(index, n.impl);
245: }
246:
247: /**
248: * Gets the size attribute of the MFNode object
249: *
250: *@return The size value
251: */
252: public int getSize() {
253: return impl.getSize();
254: }
255:
256: /** Description of the Method */
257: public void clear() {
258: impl.clear();
259: }
260:
261: /**
262: * Description of the Method
263: *
264: *@param n Description of the Parameter
265: */
266: public void delete(int n) {
267: impl.delete(n);
268: }
269: }
|