- java.lang.Object
-
- javafx.beans.binding.NumberExpressionBase
-
- javafx.beans.binding.DoubleExpression
-
- javafx.beans.binding.DoubleBinding
-
- All Implemented Interfaces:
Binding<Number>,NumberBinding,NumberExpression,Observable,ObservableDoubleValue,ObservableNumberValue,ObservableValue<Number>
public abstract class DoubleBinding extends DoubleExpression implements NumberBinding
Base class that provides most of the functionality needed to implement aBindingof adoublevalue.DoubleBindingprovides a simple invalidation-scheme. An extending class can register dependencies by callingbind(Observable...). If One of the registered dependencies becomes invalid, thisDoubleBindingis marked as invalid. Withunbind(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 whenget()is called for an invalid binding.Below is a simple example of a
DoubleBindingcalculating the square- root of aObservableNumberValuemoo.
Following is the same example with implementations for the optional methodsfinal ObservableDoubleValue moo = ...; DoubleBinding foo = new DoubleBinding() { { super.bind(moo); } @Override protected double computeValue() { return Math.sqrt(moo.getValue()); } };Binding.getDependencies()andBinding.dispose().final ObservableDoubleValue moo = ...; DoubleBinding foo = new DoubleBinding() { { super.bind(moo); } @Override protected double computeValue() { return Math.sqrt(moo.getValue()); } @Override public ObservableList<?> getDependencies() { return FXCollections.singletonObservableList(moo); } @Override public void dispose() { super.unbind(moo); } };- Since:
- JavaFX 2.0
- See Also:
Binding,NumberBinding,DoubleExpression
-
-
Constructor Summary
Constructors Constructor Description DoubleBinding()
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidaddListener(InvalidationListener listener)Adds anInvalidationListenerwhich will be notified whenever theObservablebecomes invalid.voidaddListener(ChangeListener<? super Number> listener)Adds aChangeListenerwhich will be notified whenever the value of theObservableValuechanges.protected voidbind(Observable... dependencies)Start observing the dependencies for changes.protected abstract doublecomputeValue()Calculates the current value of this binding.voiddispose()A default implementation ofdispose()that is empty.doubleget()Returns the result ofcomputeValue().ObservableList<?>getDependencies()A default implementation ofgetDependencies()that returns an emptyObservableList.voidinvalidate()Mark a binding as invalid.booleanisValid()Checks if a binding is valid.protected voidonInvalidating()The method onInvalidating() can be overridden by extending classes to react, if 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 Number> listener)Removes the given listener from the list of listeners that are notified whenever the value of theObservableValuechanges.StringtoString()Returns a string representation of thisDoubleBindingobject.protected voidunbind(Observable... dependencies)Stop observing the dependencies for changes.-
Methods inherited from class javafx.beans.binding.DoubleExpression
add, add, add, add, add, asObject, divide, divide, divide, divide, divide, doubleExpression, doubleExpression, doubleValue, floatValue, getValue, intValue, longValue, multiply, multiply, multiply, multiply, multiply, negate, subtract, subtract, subtract, subtract, subtract
-
Methods inherited from class javafx.beans.binding.NumberExpressionBase
asString, asString, asString, greaterThan, greaterThan, greaterThan, greaterThan, greaterThan, greaterThanOrEqualTo, greaterThanOrEqualTo, greaterThanOrEqualTo, greaterThanOrEqualTo, greaterThanOrEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, lessThan, lessThan, lessThan, lessThan, lessThan, lessThanOrEqualTo, lessThanOrEqualTo, lessThanOrEqualTo, lessThanOrEqualTo, lessThanOrEqualTo, numberExpression
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface javafx.beans.binding.NumberExpression
add, add, add, add, add, asString, asString, asString, divide, divide, divide, divide, divide, greaterThan, greaterThan, greaterThan, greaterThan, greaterThan, greaterThanOrEqualTo, greaterThanOrEqualTo, greaterThanOrEqualTo, greaterThanOrEqualTo, greaterThanOrEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, lessThan, lessThan, lessThan, lessThan, lessThan, lessThanOrEqualTo, lessThanOrEqualTo, lessThanOrEqualTo, lessThanOrEqualTo, lessThanOrEqualTo, multiply, multiply, multiply, multiply, multiply, negate, subtract, subtract, subtract, subtract, subtract
-
Methods inherited from interface javafx.beans.value.ObservableNumberValue
doubleValue, floatValue, intValue, longValue
-
Methods inherited from interface javafx.beans.value.ObservableValue
getValue
-
-
-
-
Method Detail
-
addListener
public void addListener(InvalidationListener listener)
Description 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 interfaceObservable- Parameters:
listener- The listener to register- See Also:
Observable.removeListener(InvalidationListener)
-
removeListener
public void removeListener(InvalidationListener listener)
Description 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 interfaceObservable- Parameters:
listener- The listener to remove- See Also:
Observable.addListener(InvalidationListener)
-
addListener
public void addListener(ChangeListener<? super Number> listener)
Description 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 interfaceObservableValue<Number>- Parameters:
listener- The listener to register- See Also:
ObservableValue.removeListener(ChangeListener)
-
removeListener
public void removeListener(ChangeListener<? super Number> listener)
Description 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 interfaceObservableValue<Number>- Parameters:
listener- The listener to remove- See Also:
ObservableValue.addListener(ChangeListener)
-
bind
protected final void bind(Observable... dependencies)
Start 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
-
unbind
protected final void unbind(Observable... dependencies)
Stop observing the dependencies for changes.- Parameters:
dependencies- the dependencies to stop observing
-
dispose
public void dispose()
A default implementation ofdispose()that is empty.
-
getDependencies
public ObservableList<?> getDependencies()
A default implementation ofgetDependencies()that returns an emptyObservableList.- Specified by:
getDependenciesin interfaceBinding<Number>- Returns:
- an empty
ObservableList
-
get
public final double get()
Returns 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 interfaceObservableDoubleValue- Returns:
- the current value
-
onInvalidating
protected void onInvalidating()
The method onInvalidating() can be overridden by extending classes to react, if this binding becomes invalid. The default implementation is empty.
-
invalidate
public 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 interfaceBinding<Number>
-
isValid
public final boolean isValid()
Description copied from interface:BindingChecks if a binding is valid.
-
computeValue
protected abstract double computeValue()
Calculates the current value of this binding.Classes extending
DoubleBindinghave to provide an implementation ofcomputeValue.- Returns:
- the current value
-
-