public class PropertyDescriptor extends FeatureDescriptor
A PropertyDescriptor describes one property that a Java Bean exports via a pair of accessor methods.
public PropertyDescriptor(String propertyName, Class<?> beanClass) throws IntrospectionException
Constructs a PropertyDescriptor for a property that follows the standard Java convention by having getFoo and setFoo accessor methods. Thus if the argument name is "fred", it will assume that the writer method is "setFred" and the reader method is "getFred" (or "isFred" for a boolean property). Note that the property name should start with a lower case character, which will be capitalized in the method names.
propertyName
- The programmatic name of the property.beanClass
- The Class object for the target bean. For example sun.beans.OurButton.class.IntrospectionException
- if an exception occurs during introspection.public PropertyDescriptor(String propertyName, Class<?> beanClass, String readMethodName, String writeMethodName) throws IntrospectionException
This constructor takes the name of a simple property, and method names for reading and writing the property.
propertyName
- The programmatic name of the property.beanClass
- The Class object for the target bean. For example sun.beans.OurButton.class.readMethodName
- The name of the method used for reading the property value. May be null if the property is write-only.writeMethodName
- The name of the method used for writing the property value. May be null if the property is read-only.IntrospectionException
- if an exception occurs during introspection.public PropertyDescriptor(String propertyName, Method readMethod, Method writeMethod) throws IntrospectionException
This constructor takes the name of a simple property, and Method objects for reading and writing the property.
propertyName
- The programmatic name of the property.readMethod
- The method used for reading the property value. May be null if the property is write-only.writeMethod
- The method used for writing the property value. May be null if the property is read-only.IntrospectionException
- if an exception occurs during introspection.public Class<?> getPropertyType()
Returns the Java type info for the property. Note that the Class
object may describe primitive Java types such as int
. This type is returned by the read method or is used as the parameter type of the write method. Returns null
if the type is an indexed property that does not support non-indexed access.
Class
object that represents the Java type info, or null
if the type cannot be determinedpublic Method getReadMethod()
Gets the method that should be used to read the property value.
public void setReadMethod(Method readMethod) throws IntrospectionException
Sets the method that should be used to read the property value.
readMethod
- The new read method.IntrospectionException
- if the read method is invalidpublic Method getWriteMethod()
Gets the method that should be used to write the property value.
public void setWriteMethod(Method writeMethod) throws IntrospectionException
Sets the method that should be used to write the property value.
writeMethod
- The new write method.IntrospectionException
- if the write method is invalidpublic boolean isBound()
Updates to "bound" properties will cause a "PropertyChange" event to get fired when the property is changed.
public void setBound(boolean bound)
Updates to "bound" properties will cause a "PropertyChange" event to get fired when the property is changed.
bound
- True if this is a bound property.public boolean isConstrained()
Attempted updates to "Constrained" properties will cause a "VetoableChange" event to get fired when the property is changed.
public void setConstrained(boolean constrained)
Attempted updates to "Constrained" properties will cause a "VetoableChange" event to get fired when the property is changed.
constrained
- True if this is a constrained property.public void setPropertyEditorClass(Class<?> propertyEditorClass)
Normally PropertyEditors will be found using the PropertyEditorManager. However if for some reason you want to associate a particular PropertyEditor with a given property, then you can do it with this method.
propertyEditorClass
- The Class for the desired PropertyEditor.public Class<?> getPropertyEditorClass()
Gets any explicit PropertyEditor Class that has been registered for this property.
public PropertyEditor createPropertyEditor(Object bean)
Constructs an instance of a property editor using the current property editor class.
If the property editor class has a public constructor that takes an Object argument then it will be invoked using the bean parameter as the argument. Otherwise, the default constructor will be invoked.
bean
- the source objectpublic boolean equals(Object obj)
Compares this PropertyDescriptor
against the specified object. Returns true if the objects are the same. Two PropertyDescriptor
s are the same if the read, write, property types, property editor and flags are equivalent.
equals
in class Object
obj
- the reference object with which to compare.true
if this object is the same as the obj argument; false
otherwise.Object.hashCode()
, HashMap
public int hashCode()
Returns a hash code value for the object. See Object.hashCode()
for a complete description.
hashCode
in class Object
Object.equals(java.lang.Object)
, System.identityHashCode(java.lang.Object)
© 1993–2017, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.