View Javadoc

1   /* -------------------------------------------------------------------
2    * Java source file for the class TextureAttributesBeanInfo
3    * 
4    * Copyright (c), 2003, Masahiro Takatsuka.
5    * All Rights Researved.
6    * 
7    * Original Author: Masahiro Takatsuka (masa@jbeans.net)
8    * $Author: takatsukam $
9    * 
10   * $Date: 2004/03/03 11:53:06 $
11   * 
12   * $Id: TextureAttributesBeanInfo.java,v 1.3 2004/03/03 11:53:06 takatsukam Exp $
13   * 
14   * Reference:		Document no:
15   * ___				___
16   * 
17   * To Do:
18   * ___
19   * 
20  ------------------------------------------------------------------- */
21  
22  /* --------------------------- Package ---------------------------- */
23  package net.jbeans.j3d.scenegraph;
24  
25  /* ------------------ Import classes (packages) ------------------- *//package-summary/html">class="comment"> ------------------ Import classes (packages) ------------------- *//package-summary.html">class="comment">/* ------------------ Import classes (packages) ------------------- *//package-summary.html">class="comment"> ------------------ Import classes (packages) ------------------- */
26  import java.awt.*;
27  import java.awt.event.*;
28  import java.beans.*;
29  import javax.swing.event.*;
30  
31  import net.jbeans.bean.*;
32  
33  /*====================================================================
34            Implementation of class TextureAttributesBeanInfo           
35  ====================================================================*/
36  /***
37   * generally describe TextureAttributesBeanInfo in here
38   * 
39   * @version $Revision: 1.3 $
40   * @author Masahiro Takatsuka (masa@jbeans.net)
41   * @see JBeansBeanInfo
42   */
43  
44  public final class TextureAttributesBeanInfo extends JBeansBeanInfo {
45      private final static Class beanClass = TextureAttributes.class;
46  	
47  	private static String iconColor16x16Filename = "resources/TextureAttributes/IconColor16.gif";
48  	private static String iconColor32x32Filename = "resources/TextureAttributes/IconColor32.gif";
49  	private static String iconMono16x16Filename;
50  	private static String iconMono32x32Filename;
51  	
52  	/***
53  	* Returns a icons of the specified size.
54  	* <PRE>
55  	* </PRE>
56  	* 
57  	* @param iconKind an ID (ICON_COLOR_16x16 or ICON_COLOR_32x32)
58  	* indicating the size of the icon.
59  	* @return Image
60  	*/
61  	public Image getIcon(int iconKind) {
62  		switch (iconKind) {
63  			case BeanInfo.ICON_COLOR_16x16:
64  			  return iconColor16x16Filename != null ? loadImage(iconColor16x16Filename) : null;
65  			case BeanInfo.ICON_COLOR_32x32:
66  			  return iconColor32x32Filename != null ? loadImage(iconColor32x32Filename) : null;
67  			case BeanInfo.ICON_MONO_16x16:
68  			  return iconMono16x16Filename != null ? loadImage(iconMono16x16Filename) : null;
69  			case BeanInfo.ICON_MONO_32x32:
70  			  return iconMono32x32Filename != null ? loadImage(iconMono32x32Filename) : null;
71  		}
72  		return null;
73  	}
74  
75      protected PropertyDescriptor createPropertyDescriptor(String s, Object aobj[]) {
76          return super.createPropertyDescriptor(beanClass, s, aobj);
77      }
78  
79  	/***
80  	* Returns a BeanDescriptor for AmbientLight bean.
81  	* <PRE>
82  	* </PRE>
83  	* 
84  	* @return BeanDescriptor
85  	*/
86      public BeanDescriptor getBeanDescriptor() {
87          BeanDescriptor bd = createBeanDescriptor(beanClass, new Object[] {
88              "preferred", Boolean.TRUE, "isContainer", Boolean.FALSE, "shortDescription", "An ambient light component."
89          });
90  		//bd.setValue("hidden-state", Boolean.TRUE);
91          bd.setValue("helpSetName", "net/jbeans/j3d/scenegraph/resources/TextureAttributes/jhelpset.hs");
92  		return bd;
93      }
94  	
95  	/***
96  	 * Returns PropertyDescriptors associated with a AmbientLight bean.
97  	 * <PRE>
98  	 * </PRE>
99  	 * 
100 	 * @return PropertyDescriptor[]
101 	 */
102    	public PropertyDescriptor[] getPropertyDescriptors() {
103   		Object perspectivemode[] = {
104 			"NICEST", new Integer(TextureAttributes.NICEST), "TextureAttributes.NICEST",
105 			"FASTEST", new Integer(TextureAttributes.FASTEST), "TextureAttributes.FASTEST"
106   		};
107   		Object mode[] = {
108 			"MODULATE", new Integer(TextureAttributes.MODULATE), "TextureAttributes.MODULATE",
109 			"DECAL", new Integer(TextureAttributes.DECAL), "TextureAttributes.DECAL",
110 			"BLEND", new Integer(TextureAttributes.BLEND), "TextureAttributes.BLEND",
111 			"REPLACE", new Integer(TextureAttributes.REPLACE), "TextureAttributes.REPLACE"
112   		};
113 		
114   		return (new PropertyDescriptor[] {
115   			createPropertyDescriptor("perspectiveCorrectionMode", new Object[] {
116   				BOUND, Boolean.TRUE, "enumerationValues", perspectivemode, PREFERRED, Boolean.TRUE, "visualUpdate", Boolean.TRUE, "shortDescription", "Set the perspective correction mode."}),
117   			createPropertyDescriptor("textureMode", new Object[] {
118   				BOUND, Boolean.TRUE, "enumerationValues", mode, PREFERRED, Boolean.TRUE, "visualUpdate", Boolean.TRUE, "shortDescription", "Set the texture mode."}),
119   			createPropertyDescriptor("textureBlendColor", new Object[] {
120   				BOUND, Boolean.TRUE, PREFERRED, Boolean.TRUE, "visualUpdate", Boolean.TRUE, "shortDescription", "Set the texture blend color."}),
121   			createPropertyDescriptor("textureTransform", new Object[] {
122   				BOUND, Boolean.TRUE, PREFERRED, Boolean.TRUE, "visualUpdate", Boolean.TRUE, "shortDescription", "Set the transform object."})
123   		});
124   	}
125 
126 	/***
127 	 * Returns EventSetDescriptors associated with a AmbientLight bean.
128 	 * <PRE>
129 	 * </PRE>
130 	 * 
131 	 * @return EventSetDescriptor[]
132 	 */
133   	public EventSetDescriptor[] getEventSetDescriptors() {
134 		EventSetDescriptor[] rv = {};
135 		return rv;
136   	}	
137 }