Class ListBinding<E>
- Type Parameters:
E- the type of theListelement
- All Implemented Interfaces:
Iterable<E>,Collection<E>,List<E>,SequencedCollection<E>,Binding<ObservableList<E>>,Observable,ObservableListValue<E>,ObservableObjectValue<ObservableList<E>>,ObservableValue<ObservableList<E>>,ObservableList<E>
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:
-
Property Summary
PropertiesTypePropertyDescriptionA boolean property that istrue, if the list is empty.An integer property that represents the size of the list. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidaddListener(InvalidationListener listener) Adds anInvalidationListenerwhich will be notified whenever theObservablebecomes invalid.voidaddListener(ChangeListener<? super ObservableList<E>> listener) Adds aChangeListenerwhich will be notified whenever the value of theObservableValuechanges.voidaddListener(ListChangeListener<? super E> listener) Add a listener to this observable list.protected final voidbind(Observable... dependencies) Start observing the dependencies for changes.protected abstract ObservableList<E> Calculates the current value of this binding.voiddispose()A default implementation ofdispose()that is empty.A boolean property that istrue, if the list is empty.final ObservableList<E> get()Returns the result ofcomputeValue().A default implementation ofgetDependencies()that returns an emptyObservableList.final voidMark a binding as invalid.final booleanisValid()Checks if a binding is valid.protected voidThe 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 ObservableList<E>> listener) Removes the given listener from the list of listeners that are notified whenever the value of theObservableValuechanges.voidremoveListener(ListChangeListener<? super E> listener) Tries to remove a listener from this observable list.An integer property that represents the size of the list.toString()Returns a string representation of thisListBindingobject.protected final voidunbind(Observable... dependencies) Stop observing the dependencies for changes.Methods declared in 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, valueAtMethods declared in class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods declared in interface java.util.Collection
parallelStream, removeIf, stream, toArrayMethods declared in interface java.util.List
addFirst, addLast, equals, getFirst, getLast, hashCode, removeFirst, removeLast, replaceAll, reversed, sort, spliteratorMethods declared in interface javafx.beans.Observable
subscribeMethods declared in interface javafx.collections.ObservableList
filtered, sorted, sorted
-
Property Details
-
size
- Specified by:
sizePropertyin classListExpression<E>- Returns:
- the property
- See Also:
-
empty
- Specified by:
emptyPropertyin classListExpression<E>- Returns:
- the
ReadOnlyBooleanProperty - See Also:
-
-
Constructor Details
-
ListBinding
public ListBinding()Creates a defaultListBinding.
-
-
Method Details
-
sizeProperty
Description copied from class:ListExpressionAn integer property that represents the size of the list.- Specified by:
sizePropertyin classListExpression<E>- Returns:
- the
sizeproperty
-
emptyProperty
Description copied from class:ListExpressionA boolean property that istrue, if the list is empty.- Specified by:
emptyPropertyin classListExpression<E>- Returns:
- the
emptyproperty
-
addListener
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:
-
removeListener
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:
-
addListener
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<E>- Parameters:
listener- The listener to register- See Also:
-
removeListener
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<E>- Parameters:
listener- The listener to remove- See Also:
-
addListener
Description copied from interface:ObservableListAdd a listener to this observable list.- Specified by:
addListenerin interfaceObservableList<E>- Parameters:
listener- the listener for listening to the list changes
-
removeListener
Description copied from interface:ObservableListTries to remove a listener from this observable list. If the listener is not attached to this list, nothing happens.- Specified by:
removeListenerin interfaceObservableList<E>- Parameters:
listener- a listener to remove
-
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
-
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. -
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<E>
-
isValid
-
computeValue
Calculates the current value of this binding.Classes extending
ListBindinghave to provide an implementation ofcomputeValue.- Returns:
- the current value
-
toString
-