Class ObjectBinding<T>
- Type Parameters:
- T- the type of the wrapped- Object
- All Implemented Interfaces:
- Binding<T>,- Observable,- ObservableObjectValue<T>,- ObservableValue<T>
Binding of an Object.
 
 ObjectBinding provides a simple invalidation-scheme. An extending
 class can register dependencies by calling bind(Observable...).
 If One of the registered dependencies becomes invalid, this
 ObjectBinding is marked as invalid. With
 unbind(Observable...) listening to dependencies can be stopped.
 
 To provide a concrete implementation of this class, the method
 computeValue() has to be implemented to calculate the value of this
 binding based on the current state of the dependencies. It is called when
 get() is called for an invalid binding.
 
 See DoubleBinding for an example how this base class can be extended.
- Since:
- JavaFX 2.0
- See Also:
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddListener(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.protected booleanChecks if the binding is allowed to become valid.protected final voidbind(Observable... dependencies) Start observing the dependencies for changes.protected abstract TCalculates the current value of this binding.voiddispose()A default implementation ofdispose()that is empty.final Tget()Returns the result ofcomputeValue().A default implementation ofgetDependencies()that returns an emptyObservableList.final voidMark a binding as invalid.protected final booleanChecks if the binding has at least one listener registered on it.final booleanisValid()Checks if a binding is valid.protected voidCalled when this binding becomes invalid.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.toString()Returns a string representation of thisObjectBindingobject.protected final voidunbind(Observable... dependencies) Stop observing the dependencies for changes.Methods declared in class javafx.beans.binding.ObjectExpressionasString, asString, asString, getValue, isEqualTo, isEqualTo, isNotEqualTo, isNotEqualTo, isNotNull, isNull, objectExpressionMethods declared in class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods declared in interface javafx.beans.Observablesubscribe
- 
Constructor Details- 
ObjectBindingpublic ObjectBinding()Creates a defaultObjectBinding.
 
- 
- 
Method Details- 
addListenerDescription copied from interface:ObservableAdds 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:
 
- 
removeListenerDescription copied from interface:ObservableRemoves 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:
 
- 
addListenerDescription copied from interface:ObservableValueAdds 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:
 
- 
removeListenerDescription copied from interface:ObservableValueRemoves 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:
 
- 
bindStart observing the dependencies for changes. If the value of one of the dependencies changes, the binding is marked as invalid.- Parameters:
- dependencies- the dependencies to observe
 
- 
unbindStop observing the dependencies for changes.- Parameters:
- dependencies- the dependencies to stop observing
 
- 
dispose
- 
getDependenciesA default implementation ofgetDependencies()that returns an emptyObservableList.- Specified by:
- getDependenciesin interface- Binding<T>
- Returns:
- an empty ObservableList
 
- 
getReturns the result ofcomputeValue(). The methodcomputeValue()is only called if the binding is invalid. The result is cached and returned if the binding did not become invalid since the last call ofget().- Specified by:
- getin interface- ObservableObjectValue<T>
- Returns:
- the current value
 
- 
onInvalidatingprotected void onInvalidating()Called when this binding becomes invalid. Can be overridden by extending classes to react to the invalidation. The default implementation is empty.
- 
invalidatepublic final void invalidate()Description copied from interface:BindingMark a binding as invalid. This forces the recalculation of the value of theBindingnext time it is request.- Specified by:
- invalidatein interface- Binding<T>
 
- 
isValid
- 
isObservedprotected final boolean isObserved()Checks if the binding has at least one listener registered on it. This is useful for subclasses which want to conserve resources when not observed.- Returns:
- trueif this binding currently has one or more listeners registered on it, otherwise- false
- Since:
- 19
 
- 
allowValidationprotected boolean allowValidation()Checks if the binding is allowed to become valid. Overriding classes can prevent a binding from becoming valid. This is useful in subclasses which do not always listen for invalidations of their dependencies and prefer to recompute the current value instead. This can also be useful if caching of the current computed value is not desirable.The default implementation always allows bindings to become valid. - Returns:
- trueif this binding is allowed to become valid, otherwise- false
- Since:
- 19
 
- 
computeValueCalculates the current value of this binding.Classes extending ObjectBindinghave to provide an implementation ofcomputeValue.- Returns:
- the current value
 
- 
toString
 
-