001: /*
002: * $RCSfile: ShaderAttributeArray.java,v $
003: *
004: * Copyright 2005-2008 Sun Microsystems, Inc. All Rights Reserved.
005: * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
006: *
007: * This code is free software; you can redistribute it and/or modify it
008: * under the terms of the GNU General Public License version 2 only, as
009: * published by the Free Software Foundation. Sun designates this
010: * particular file as subject to the "Classpath" exception as provided
011: * by Sun in the LICENSE file that accompanied this code.
012: *
013: * This code is distributed in the hope that it will be useful, but WITHOUT
014: * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
015: * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
016: * version 2 for more details (a copy is included in the LICENSE file that
017: * accompanied this code).
018: *
019: * You should have received a copy of the GNU General Public License version
020: * 2 along with this work; if not, write to the Free Software Foundation,
021: * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
022: *
023: * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
024: * CA 95054 USA or visit www.sun.com if you need additional information or
025: * have any questions.
026: *
027: * $Revision: 1.5 $
028: * $Date: 2008/02/28 20:17:29 $
029: * $State: Exp $
030: */
031:
032: package javax.media.j3d;
033:
034: import javax.vecmath.*;
035:
036: /**
037: * The ShaderAttributeArray object encapsulates a uniform shader
038: * attribute whose value is specified explicitly. The shader variable
039: * <code>attrName</code> is explicitly set to the specified
040: * <code>value</code> during rendering. <code>attrName</code> must be
041: * the name of a valid uniform attribute in the shader in which it is
042: * used. Otherwise, the attribute name will be ignored and a runtime
043: * error may be generated. The <code>value</code> must be an array
044: * of one of the allowed classes. The allowed classes are:
045: * <code>Integer[]</code>, <code>Float[]</code>,
046: * <code>Tuple{2,3,4}{i,f}[]</code>, <code>Matrix{3,4}f[]</code>. A
047: * ClassCastException will be thrown if a specified <code>value</code>
048: * object is not one of the allowed types. Further, the type and length of the
049: * value is immutable once a ShaderAttributeArray is constructed.
050: * Subsequent setValue operations must be called with an array of the
051: * same type and length as the one that was used to construct the
052: * ShaderAttributeArray. Finally, the type of the <code>value</code>
053: * object must match the type of the corresponding
054: * <code>attrName</code> variable in the shader in which it is
055: * used. Otherwise, the shader will not be able to use the attribute
056: * and a runtime error may be generated.
057: *
058: * @see ShaderAttributeSet
059: * @see ShaderProgram
060: *
061: * @since Java 3D 1.4
062: */
063:
064: public class ShaderAttributeArray extends ShaderAttributeObject {
065: /**
066: * Constructs a new ShaderAttributeArray object with the specified
067: * <code>(attrName, value)</code> pair. The specified value
068: * must be an array of one of the allowed class types.
069: * A deep copy of the array is stored.
070: *
071: * @param attrName the name of the shader attribute
072: * @param value the value of the shader attribute
073: *
074: * @exception NullPointerException if attrName or value is null
075: *
076: * @exception ClassCastException if value is not an array of
077: * one of the allowed classes
078: */
079: public ShaderAttributeArray(String attrName, Object value) {
080: super (attrName, value);
081: }
082:
083: // Implement abstract getValue method
084: public Object getValue() {
085: if (isLiveOrCompiled())
086: if (!this .getCapability(ALLOW_VALUE_READ))
087: throw new CapabilityNotSetException(J3dI18N
088: .getString("ShaderAttributeObject0"));
089:
090: return ((ShaderAttributeArrayRetained) this .retained)
091: .getValue();
092: }
093:
094: // Implement abstract setValue method
095: public void setValue(Object value) {
096: if (value == null) {
097: throw new NullPointerException();
098: }
099:
100: if (isLiveOrCompiled())
101: if (!this .getCapability(ALLOW_VALUE_WRITE))
102: throw new CapabilityNotSetException(J3dI18N
103: .getString("ShaderAttributeObject1"));
104:
105: if (isLive())
106: ((ShaderAttributeArrayRetained) this .retained)
107: .setValue(value);
108: else
109: ((ShaderAttributeArrayRetained) this .retained)
110: .initValue(value);
111:
112: }
113:
114: /**
115: * Sets the specified array element of the value of this shader
116: * attribute to the specified value.
117: * A copy of the object is stored.
118: *
119: * @param value the new value of the shader attribute
120: *
121: * @exception NullPointerException if value is null
122: *
123: * @exception ClassCastException if value is not an instance of
124: * the same base class as the individual elements of the array object
125: * used to construct this shader attribute object.
126: *
127: * @exception CapabilityNotSetException if appropriate capability is
128: * not set and this object is part of live or compiled scene graph
129: */
130: public void setValue(int index, Object value) {
131: if (value == null) {
132: throw new NullPointerException();
133: }
134:
135: if (isLiveOrCompiled())
136: if (!this .getCapability(ALLOW_VALUE_WRITE))
137: throw new CapabilityNotSetException(J3dI18N
138: .getString("ShaderAttributeObject1"));
139:
140: if (isLive())
141: ((ShaderAttributeArrayRetained) this .retained).setValue(
142: index, value);
143: else {
144: ((ShaderAttributeArrayRetained) this .retained).initValue(
145: index, value);
146: }
147: }
148:
149: /**
150: * Returns the number of elements in the value array.
151: *
152: * @return the number of elements in the value array
153: *
154: * @exception CapabilityNotSetException if appropriate capability is
155: * not set and this object is part of live or compiled scene graph
156: */
157: public int length() {
158: if (isLiveOrCompiled())
159: if (!this .getCapability(ALLOW_VALUE_READ))
160: throw new CapabilityNotSetException(J3dI18N
161: .getString("ShaderAttributeObject0"));
162:
163: return ((ShaderAttributeArrayRetained) this .retained).length();
164: }
165:
166: /**
167: * Creates a retained mode ShaderAttributeArrayRetained object that this
168: * ShaderAttributeArray component object will point to.
169: */
170: void createRetained() {
171: this .retained = new ShaderAttributeArrayRetained();
172: this.retained.setSource(this);
173: }
174: }
|