- java.lang.Object
-
- javafx.beans.binding.ListExpression<E>
-
- javafx.beans.binding.ListBinding<E>
-
- Type Parameters:
E
- the type of theList
element
- All Implemented Interfaces:
Iterable<E>
,Collection<E>
,List<E>
,Binding<ObservableList<E>>
,Observable
,ObservableListValue<E>
,ObservableObjectValue<E>
,ObservableValue<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 aBinding
of anObservableList
.ListBinding
provides a simple invalidation-scheme. An extending class can register dependencies by callingbind(Observable...)
. If one of the registered dependencies becomes invalid, thisListBinding
is 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.See
DoubleBinding
for an example how this base class can be extended.- Since:
- JavaFX 2.1
- See Also:
Binding
,ListExpression
-
-
Property Summary
Properties Type Property Description ReadOnlyBooleanProperty
empty
A boolean property that istrue
, if the list is empty.ReadOnlyIntegerProperty
size
An integer property that represents the size of the list.
-
Constructor Summary
Constructors Constructor Description ListBinding()
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description void
addListener(InvalidationListener listener)
Adds anInvalidationListener
which will be notified whenever theObservable
becomes invalid.void
addListener(ChangeListener<? super ObservableList<E>> listener)
Adds aChangeListener
which will be notified whenever the value of theObservableValue
changes.void
addListener(ListChangeListener<? super E> listener)
Add a listener to this observable list.protected void
bind(Observable... dependencies)
Start observing the dependencies for changes.protected abstract ObservableList<E>
computeValue()
Calculates the current value of this binding.void
dispose()
A default implementation ofdispose()
that is empty.ReadOnlyBooleanProperty
emptyProperty()
A boolean property that istrue
, if the list is empty.ObservableList<E>
get()
Returns the result ofcomputeValue()
.ObservableList<?>
getDependencies()
A default implementation ofgetDependencies()
that returns an emptyObservableList
.void
invalidate()
Mark a binding as invalid.boolean
isValid()
Checks if a binding is valid.protected void
onInvalidating()
The method onInvalidating() can be overridden by extending classes to react, if this binding becomes invalid.void
removeListener(InvalidationListener listener)
Removes the given listener from the list of listeners, that are notified whenever the value of theObservable
becomes invalid.void
removeListener(ChangeListener<? super ObservableList<E>> listener)
Removes the given listener from the list of listeners, that are notified whenever the value of theObservableValue
changes.void
removeListener(ListChangeListener<? super E> listener)
Tries to remove a listener from this observable list.ReadOnlyIntegerProperty
sizeProperty()
An integer property that represents the size of the list.String
toString()
Returns a string representation of thisListBinding
object.protected void
unbind(Observable... dependencies)
Stop observing the dependencies for changes.-
Methods inherited from interface java.util.Collection
parallelStream, removeIf, stream
-
Methods inherited from interface java.util.List
equals, hashCode, of, of, of, of, of, of, of, of, of, of, of, of, replaceAll, sort, spliterator
-
Methods inherited from class javafx.beans.binding.ListExpression
add, add, addAll, addAll, addAll, asString, clear, contains, containsAll, get, getSize, getValue, indexOf, isEmpty, isEqualTo, isNotEqualTo, isNotNull, isNull, iterator, lastIndexOf, listExpression, listIterator, listIterator, remove, remove, remove, removeAll, removeAll, retainAll, retainAll, set, setAll, setAll, size, subList, toArray, toArray, valueAt, valueAt
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface javafx.collections.ObservableList
filtered, sorted, sorted
-
Methods inherited from interface javafx.beans.value.ObservableValue
getValue
-
-
-
-
Property Detail
-
size
public ReadOnlyIntegerProperty sizeProperty
- Specified by:
sizeProperty
in classListExpression<E>
- See Also:
ListExpression.getSize()
-
empty
public ReadOnlyBooleanProperty emptyProperty
- Specified by:
emptyProperty
in classListExpression<E>
- See Also:
ListExpression.isEmpty()
-
-
Method Detail
-
sizeProperty
public ReadOnlyIntegerProperty sizeProperty()
Description copied from class:ListExpression
An integer property that represents the size of the list.- Specified by:
sizeProperty
in classListExpression<E>
- See Also:
ListExpression.getSize()
-
emptyProperty
public ReadOnlyBooleanProperty emptyProperty()
Description copied from class:ListExpression
A boolean property that istrue
, if the list is empty.- Specified by:
emptyProperty
in classListExpression<E>
- See Also:
ListExpression.isEmpty()
-
addListener
public void addListener(InvalidationListener listener)
Description copied from interface:Observable
Adds anInvalidationListener
which will be notified whenever theObservable
becomes 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
InvalidationListener
instance may be safely registered for differentObservables
.The
Observable
stores 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 callingremoveListener
after use or to use an instance ofWeakInvalidationListener
avoid this situation.- Specified by:
addListener
in interfaceObservable
- Parameters:
listener
- The listener to register- See Also:
Observable.removeListener(InvalidationListener)
-
removeListener
public void removeListener(InvalidationListener listener)
Description copied from interface:Observable
Removes the given listener from the list of listeners, that are notified whenever the value of theObservable
becomes 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:
removeListener
in interfaceObservable
- Parameters:
listener
- The listener to remove- See Also:
Observable.addListener(InvalidationListener)
-
addListener
public void addListener(ChangeListener<? super ObservableList<E>> listener)
Description copied from interface:ObservableValue
Adds aChangeListener
which will be notified whenever the value of theObservableValue
changes. 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
ChangeListener
instance may be safely registered for differentObservableValues
.The
ObservableValue
stores 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 callingremoveListener
after use or to use an instance ofWeakChangeListener
avoid this situation.- Specified by:
addListener
in interfaceObservableValue<E>
- Parameters:
listener
- The listener to register- See Also:
ObservableValue.removeListener(ChangeListener)
-
removeListener
public void removeListener(ChangeListener<? super ObservableList<E>> listener)
Description copied from interface:ObservableValue
Removes the given listener from the list of listeners, that are notified whenever the value of theObservableValue
changes.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:
removeListener
in interfaceObservableValue<E>
- Parameters:
listener
- The listener to remove- See Also:
ObservableValue.addListener(ChangeListener)
-
addListener
public void addListener(ListChangeListener<? super E> listener)
Description copied from interface:ObservableList
Add a listener to this observable list.- Specified by:
addListener
in interfaceObservableList<E>
- Parameters:
listener
- the listener for listening to the list changes
-
removeListener
public void removeListener(ListChangeListener<? super E> listener)
Description copied from interface:ObservableList
Tries to remove a listener from this observable list. If the listener is not attached to this list, nothing happens.- Specified by:
removeListener
in interfaceObservableList<E>
- Parameters:
listener
- a listener to remove
-
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:
getDependencies
in interfaceBinding<E>
- Returns:
- an empty
ObservableList
-
get
public final ObservableList<E> 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:
get
in 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.
-
invalidate
public final void invalidate()
Description copied from interface:Binding
Mark a binding as invalid. This forces the recalculation of the value of theBinding
next time it is request.- Specified by:
invalidate
in interfaceBinding<E>
-
isValid
public final boolean isValid()
Description copied from interface:Binding
Checks if a binding is valid.
-
computeValue
protected abstract ObservableList<E> computeValue()
Calculates the current value of this binding.Classes extending
ListBinding
have to provide an implementation ofcomputeValue
.- Returns:
- the current value
-
-