K - the type of the key elementsV - the type of the value elementspublic abstract class MapBinding<K,V> extends MapExpression<K,V> implements Binding<ObservableMap<K,V>>
Binding of an ObservableMap.
MapBinding provides a simple invalidation-scheme. An extending
class can register dependencies by calling bind(Observable...).
If one of the registered dependencies becomes invalid, this
MapBinding 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.
Binding,
MapExpression| Type | Property and Description |
|---|---|
ReadOnlyBooleanProperty |
empty
A boolean property that is
true, if the map is empty. |
ReadOnlyIntegerProperty |
size |
| Constructor and Description |
|---|
MapBinding() |
| Modifier and Type | Method and Description |
|---|---|
void |
addListener(ChangeListener<? super ObservableMap<K,V>> listener)
Adds a
ChangeListener which will be notified whenever the value
of the ObservableValue changes. |
void |
addListener(InvalidationListener listener)
Adds an
InvalidationListener which will be notified whenever the
Observable becomes invalid. |
void |
addListener(MapChangeListener<? super K,? super V> listener)
Add a listener to this observable map.
|
protected void |
bind(Observable... dependencies)
Start observing the dependencies for changes.
|
protected abstract ObservableMap<K,V> |
computeValue()
Calculates the current value of this binding.
|
void |
dispose()
A default implementation of
dispose() that is empty. |
ReadOnlyBooleanProperty |
emptyProperty()
A boolean property that is
true, if the map is empty. |
ObservableMap<K,V> |
get()
Returns the result of
computeValue(). |
ObservableList<?> |
getDependencies()
A default implementation of
getDependencies() that returns an
empty ObservableList. |
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(ChangeListener<? super ObservableMap<K,V>> listener)
Removes the given listener from the list of listeners, that are notified
whenever the value of the
ObservableValue changes. |
void |
removeListener(InvalidationListener listener)
Removes the given listener from the list of listeners, that are notified
whenever the value of the
Observable becomes invalid. |
void |
removeListener(MapChangeListener<? super K,? super V> listener)
Tries to removed a listener from this observable list.
|
ReadOnlyIntegerProperty |
sizeProperty() |
java.lang.String |
toString()
Returns a string representation of this
MapBinding object. |
protected void |
unbind(Observable... dependencies)
Stop observing the dependencies for changes.
|
asString, clear, containsKey, containsValue, entrySet, get, getSize, getValue, isEmpty, isEqualTo, isNotEqualTo, isNotNull, isNull, keySet, mapExpression, put, putAll, remove, size, valueAt, valueAt, valuesclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitgetValuepublic ReadOnlyIntegerProperty sizeProperty
sizeProperty in class MapExpression<K,V>MapExpression.getSize()public ReadOnlyBooleanProperty emptyProperty
emptyProperty in class MapExpression<K,V>MapExpression.isEmpty()public ReadOnlyIntegerProperty sizeProperty()
sizeProperty in class MapExpression<K,V>MapExpression.getSize()public ReadOnlyBooleanProperty emptyProperty()
MapExpressiontrue, if the map is empty.emptyProperty in class MapExpression<K,V>MapExpression.isEmpty()public void addListener(InvalidationListener listener)
ObservableInvalidationListener which will be notified whenever the
Observable 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 different Observables.
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 calling removeListener after use or to use an instance of
WeakInvalidationListener avoid this situation.
addListener in interface Observablelistener - The listener to registerObservable.removeListener(InvalidationListener)public void removeListener(InvalidationListener listener)
ObservableObservable 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.
removeListener in interface Observablelistener - The listener to removeObservable.addListener(InvalidationListener)public void addListener(ChangeListener<? super ObservableMap<K,V>> listener)
ObservableValueChangeListener which will be notified whenever the value
of the ObservableValue 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 different ObservableValues.
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 calling removeListener after use or to use an instance of
WeakChangeListener avoid this situation.
addListener in interface ObservableValue<ObservableMap<K,V>>listener - The listener to registerObservableValue.removeListener(ChangeListener)public void removeListener(ChangeListener<? super ObservableMap<K,V>> listener)
ObservableValueObservableValue 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.
removeListener in interface ObservableValue<ObservableMap<K,V>>listener - The listener to removeObservableValue.addListener(ChangeListener)public void addListener(MapChangeListener<? super K,? super V> listener)
ObservableMapaddListener in interface ObservableMap<K,V>listener - the listener for listening to the list changespublic void removeListener(MapChangeListener<? super K,? super V> listener)
ObservableMapremoveListener in interface ObservableMap<K,V>listener - a listener to removeprotected final void bind(Observable... dependencies)
dependencies - the dependencies to observeprotected final void unbind(Observable... dependencies)
dependencies - the dependencies to stop observingpublic void dispose()
dispose() that is empty.dispose in interface Binding<ObservableMap<K,V>>public ObservableList<?> getDependencies()
getDependencies() that returns an
empty ObservableList.getDependencies in interface Binding<ObservableMap<K,V>>ObservableListpublic final ObservableMap<K,V> get()
computeValue(). The method
computeValue() 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 of get().get in interface ObservableObjectValue<ObservableMap<K,V>>protected void onInvalidating()
public final void invalidate()
BindingBinding next time it is request.invalidate in interface Binding<ObservableMap<K,V>>public final boolean isValid()
BindingisValid in interface Binding<ObservableMap<K,V>>true if the Binding is valid, false
otherwiseprotected abstract ObservableMap<K,V> computeValue()
Classes extending MapBinding have to provide an implementation
of computeValue.
public java.lang.String toString()
MapBinding object.toString in class java.lang.ObjectMapBinding object.Copyright (c) 2008, 2014, Oracle and/or its affiliates. All rights reserved.