- Type Parameters:
- T- type of the wrapped- Object
- All Implemented Interfaces:
- Observable,- JavaBeanProperty<T>,- ReadOnlyJavaBeanProperty<T>,- Property<T>,- ReadOnlyProperty<T>,- ObservableObjectValue<T>,- ObservableValue<T>,- WritableObjectValue<T>,- WritableValue<T>
public final class JavaBeanObjectProperty<T> extends ObjectProperty<T> implements JavaBeanProperty<T>
JavaBeanObjectProperty provides an adapter between a regular
 Java Bean property of type T and a JavaFX
 ObjectProperty<T>. It cannot be created directly, but a
 JavaBeanObjectPropertyBuilder has to be used.
 
 As a minimum, the Java Bean class must implement a getter and a setter for the
 property.
 The class, as well as the getter and a setter methods, must be declared public.
 If the getter of an instance of this class is called, the property of
 the Java Bean is returned. If the setter is called, the value will be passed
 to the Java Bean property. If the Java Bean property is bound (i.e. it supports
 PropertyChangeListeners), this JavaBeanObjectProperty will be
 aware of changes in the Java Bean. Otherwise it can be notified about
 changes by calling fireValueChangedEvent(). If the Java Bean property
 is also constrained (i.e. it supports VetoableChangeListeners), this
 JavaBeanObjectProperty will reject changes, if it is bound to an
 ObservableValue<Object>.
 
Deploying an Application as a Module
 If the Java Bean class is in a named module, then it must be reflectively
 accessible to the javafx.base module.
 A class is reflectively accessible if the module
 opens the containing package to at
 least the javafx.base module.
 
 For example, if com.foo.MyBeanClass is in the foo.app module,
 the module-info.java might
 look like this:
 
module foo.app {
    opens com.foo to javafx.base;
}
 Alternatively, a class is reflectively accessible if the module
 exports the containing package
 unconditionally.
 
- Since:
- JavaFX 2.1
- See Also:
- ObjectProperty,- JavaBeanObjectPropertyBuilder
- 
Method SummaryModifier and Type Method Description voidaddListener(InvalidationListener listener)Adds anInvalidationListenerwhich will be notified whenever theObservablebecomes invalid.voidaddListener(ChangeListener<? super T> listener)Adds aChangeListenerwhich will be notified whenever the value of theObservableValuechanges.voidbind(ObservableValue<? extends T> observable)Create a unidirection binding for thisProperty.voiddispose()Signals to the JavaFX property that it will not be used anymore and any references can be removed.voidfireValueChangedEvent()This method can be called to notify the adapter of a change of the Java Bean value, if the Java Bean property is not bound (i.e.Tget()Get the wrapped value.ObjectgetBean()Returns theObjectthat contains this property.StringgetName()Returns the name of this property.booleanisBound()Can be used to check, if aPropertyis bound.voidremoveListener(InvalidationListener listener)Removes the given listener from the list of listeners, that are notified whenever the value of theObservablebecomes invalid.voidremoveListener(ChangeListener<? super T> listener)Removes the given listener from the list of listeners that are notified whenever the value of theObservableValuechanges.voidset(T value)Set the wrapped value.StringtoString()Returns a string representation of thisJavaBeanObjectPropertyobject.voidunbind()Remove the unidirectional binding for thisProperty.Methods inherited from class javafx.beans.property.ObjectPropertybindBidirectional, setValue, unbindBidirectionalMethods inherited from class javafx.beans.binding.ObjectExpressionasString, asString, asString, getValue, isEqualTo, isEqualTo, isNotEqualTo, isNotEqualTo, isNotNull, isNull, objectExpressionMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface javafx.beans.property.PropertybindBidirectional, unbindBidirectional
- 
Method Details- 
getGet the wrapped value. This must be identical to the value returned fromWritableValue.getValue().This method exists only to align WritableObjectValue API with WritableBooleanValueand subclasses ofWritableNumberValue- Specified by:
- getin interface- ObservableObjectValue<T>
- Specified by:
- getin interface- WritableObjectValue<T>
- Returns:
- The current value
- Throws:
- UndeclaredThrowableException- if calling the getter of the Java Bean property throws an- IllegalAccessExceptionor an- InvocationTargetException.
 
- 
setSet the wrapped value. Should be equivalent toWritableValue.setValue(java.lang.Object)- Specified by:
- setin interface- WritableObjectValue<T>
- Parameters:
- value- The new value
- Throws:
- UndeclaredThrowableException- if calling the getter of the Java Bean property throws an- IllegalAccessExceptionor an- InvocationTargetException.
- See Also:
- WritableObjectValue.get()
 
- 
bindCreate a unidirection binding for thisProperty.Note that JavaFX has all the bind calls implemented through weak listeners. This means the bound property can be garbage collected and stopped from being updated. 
- 
unbindpublic void unbind()Remove the unidirectional binding for thisProperty. If thePropertyis not bound, calling this method has no effect.- Specified by:
- unbindin interface- Property<T>
- See Also:
- Property.bind(javafx.beans.value.ObservableValue)
 
- 
isBoundpublic boolean isBound()Can be used to check, if aPropertyis bound.- Specified by:
- isBoundin interface- Property<T>
- Returns:
- trueif the- Propertyis bound,- falseotherwise
- See Also:
- Property.bind(javafx.beans.value.ObservableValue)
 
- 
getBeanReturns theObjectthat contains this property. If this property is not contained in anObject,nullis returned.- Specified by:
- getBeanin interface- ReadOnlyProperty<T>
- Returns:
- the containing Objectornull
 
- 
getNameReturns the name of this property. If the property does not have a name, this method returns an emptyString.- Specified by:
- getNamein interface- ReadOnlyProperty<T>
- Returns:
- the name or an empty String
 
- 
addListenerAdds aChangeListenerwhich will be notified whenever the value of theObservableValuechanges. If the same listener is added more than once, then it will be notified more than once. That is, no check is made to ensure uniqueness.Note that the same actual ChangeListenerinstance may be safely registered for differentObservableValues.The ObservableValuestores a strong reference to the listener which will prevent the listener from being garbage collected and may result in a memory leak. It is recommended to either unregister a listener by callingremoveListenerafter use or to use an instance ofWeakChangeListeneravoid this situation.- Specified by:
- addListenerin interface- ObservableValue<T>
- Parameters:
- listener- The listener to register
- See Also:
- ObservableValue.removeListener(ChangeListener)
 
- 
removeListenerRemoves the given listener from the list of listeners that are notified whenever the value of theObservableValuechanges.If the given listener has not been previously registered (i.e. it was never added) then this method call is a no-op. If it had been previously added then it will be removed. If it had been added more than once, then only the first occurrence will be removed. - Specified by:
- removeListenerin interface- ObservableValue<T>
- Parameters:
- listener- The listener to remove
- See Also:
- ObservableValue.addListener(ChangeListener)
 
- 
addListenerAdds anInvalidationListenerwhich will be notified whenever theObservablebecomes invalid. If the same listener is added more than once, then it will be notified more than once. That is, no check is made to ensure uniqueness.Note that the same actual InvalidationListenerinstance may be safely registered for differentObservables.The Observablestores a strong reference to the listener which will prevent the listener from being garbage collected and may result in a memory leak. It is recommended to either unregister a listener by callingremoveListenerafter use or to use an instance ofWeakInvalidationListeneravoid this situation.- Specified by:
- addListenerin interface- Observable
- Parameters:
- listener- The listener to register
- See Also:
- Observable.removeListener(InvalidationListener)
 
- 
removeListenerRemoves the given listener from the list of listeners, that are notified whenever the value of theObservablebecomes invalid.If the given listener has not been previously registered (i.e. it was never added) then this method call is a no-op. If it had been previously added then it will be removed. If it had been added more than once, then only the first occurrence will be removed. - Specified by:
- removeListenerin interface- Observable
- Parameters:
- listener- The listener to remove
- See Also:
- Observable.addListener(InvalidationListener)
 
- 
fireValueChangedEventpublic void fireValueChangedEvent()This method can be called to notify the adapter of a change of the Java Bean value, if the Java Bean property is not bound (i.e. it does not support PropertyChangeListeners).- Specified by:
- fireValueChangedEventin interface- ReadOnlyJavaBeanProperty<T>
 
- 
disposepublic void dispose()Signals to the JavaFX property that it will not be used anymore and any references can be removed. A call of this method usually results in the property stopping to observe the Java Bean property by unregistering its listener(s).- Specified by:
- disposein interface- ReadOnlyJavaBeanProperty<T>
 
- 
toStringReturns a string representation of thisJavaBeanObjectPropertyobject.- Overrides:
- toStringin class- ObjectProperty<T>
- Returns:
- a string representation of this JavaBeanObjectPropertyobject.
 
 
-