java.lang.Object
javafx.beans.binding.ListExpression<E>
javafx.beans.binding.ListBinding<E>
- Type Parameters:
E- the type of theListelement
- All Implemented Interfaces:
Iterable<E>,Collection<E>,List<E>,Binding<ObservableList<E>>,Observable,ObservableListValue<E>,ObservableObjectValue<ObservableList<E>>,ObservableValue<ObservableList<E>>,ObservableList<E>
public abstract class ListBinding<E> extends ListExpression<E> implements Binding<ObservableList<E>>
Base class that provides most of the functionality needed to implement a
Binding of an ObservableList.
ListBinding provides a simple invalidation-scheme. An extending
class can register dependencies by calling bind(Observable...).
If one of the registered dependencies becomes invalid, this
ListBinding 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.1
- See Also:
Binding,ListExpression
-
Property Summary
Properties declared in class javafx.beans.binding.ListExpression
empty, size -
Constructor Summary
Constructors Constructor Description ListBinding()Creates a defaultListBinding. -
Method Summary
Modifier and Type Method Description protected voidbind(Observable... dependencies)Start observing the dependencies for changes.protected abstract ObservableList<E>computeValue()Calculates the current value of this binding.voiddispose()A default implementation ofdispose()that is empty.ObservableList<E>get()Returns the result ofcomputeValue().ObservableList<?>getDependencies()A default implementation ofgetDependencies()that returns an emptyObservableList.protected voidonInvalidating()The method onInvalidating() can be overridden by extending classes to react, if this binding becomes invalid.StringtoString()Returns a string representation of thisListBindingobject.protected voidunbind(Observable... dependencies)Stop observing the dependencies for changes.Methods declared in class javafx.beans.binding.ListExpression
asString, emptyProperty, getSize, isEqualTo, isNotEqualTo, isNotNull, isNull, listExpression, sizeProperty, valueAt, valueAtMethods declared in class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods declared in interface javafx.beans.binding.Binding
invalidate, isValidMethods declared in interface java.util.Collection
parallelStream, removeIf, stream, toArrayMethods declared in interface java.util.List
add, add, addAll, addAll, clear, contains, containsAll, equals, get, hashCode, indexOf, isEmpty, iterator, lastIndexOf, listIterator, listIterator, remove, remove, removeAll, replaceAll, retainAll, set, size, sort, spliterator, subList, toArray, toArrayMethods declared in interface javafx.beans.Observable
addListener, removeListenerMethods declared in interface javafx.collections.ObservableList
addAll, addListener, filtered, remove, removeAll, removeListener, retainAll, setAll, setAll, sorted, sortedMethods declared in interface javafx.beans.value.ObservableValue
addListener, getValue, removeListener
-
Constructor Details
-
ListBinding
public ListBinding()Creates a defaultListBinding.
-
-
Method Details
-
bind
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
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
A default implementation ofgetDependencies()that returns an emptyObservableList.- Specified by:
getDependenciesin interfaceBinding<E>- Returns:
- an empty
ObservableList
-
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 interfaceObservableObjectValue<E>- 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. -
computeValue
Calculates the current value of this binding.Classes extending
ListBindinghave to provide an implementation ofcomputeValue.- Returns:
- the current value
-
toString
Returns a string representation of thisListBindingobject.
-