Class MapProperty<K,V>
java.lang.Object
javafx.beans.binding.MapExpression<K,V>
javafx.beans.property.ReadOnlyMapProperty<K,V>
javafx.beans.property.MapProperty<K,V>
- Type Parameters:
K
- the type of the key elements of theMap
V
- the type of the value elements of theMap
- All Implemented Interfaces:
Map<K,
,V> Observable
,Property<ObservableMap<K,
,V>> ReadOnlyProperty<ObservableMap<K,
,V>> ObservableMapValue<K,
,V> ObservableObjectValue<ObservableMap<K,
,V>> ObservableValue<ObservableMap<K,
,V>> WritableMapValue<K,
,V> WritableObjectValue<ObservableMap<K,
,V>> WritableValue<ObservableMap<K,
,V>> ObservableMap<K,
V>
- Direct Known Subclasses:
MapPropertyBase
public abstract class MapProperty<K,V>
extends ReadOnlyMapProperty<K,V>
implements Property<ObservableMap<K,V>>, WritableMapValue<K,V>
This class provides a full implementation of a
Property
wrapping an
ObservableMap
.
The value of a MapProperty
can be get and set with ObservableObjectValue.get()
,
MapExpression.getValue()
, WritableObjectValue.set(Object)
, and setValue(javafx.collections.ObservableMap)
.
A property can be bound and unbound unidirectional with
Property.bind(javafx.beans.value.ObservableValue)
and Property.unbind()
. Bidirectional bindings
can be created and removed with bindBidirectional(Property)
and
unbindBidirectional(Property)
.
The context of a MapProperty
can be read with ReadOnlyProperty.getBean()
and ReadOnlyProperty.getName()
.- Since:
- JavaFX 2.1
- See Also:
-
Nested Class Summary
-
Property Summary
Properties declared in class javafx.beans.binding.MapExpression
empty, size
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
bindBidirectional
(Property<ObservableMap<K, V>> other) Create a bidirectional binding between thisProperty
and another one.void
setValue
(ObservableMap<K, V> v) Set the wrapped value.toString()
Returns a string representation of thisMapProperty
object.void
unbindBidirectional
(Property<ObservableMap<K, V>> other) Removes a bidirectional binding between thisProperty
and another one.Methods declared in class javafx.beans.property.ReadOnlyMapProperty
bindContent, bindContentBidirectional, equals, hashCode, unbindContent, unbindContentBidirectional
Methods declared in class javafx.beans.binding.MapExpression
asString, clear, containsKey, containsValue, emptyProperty, entrySet, get, getSize, getValue, isEmpty, isEqualTo, isNotEqualTo, isNotNull, isNull, keySet, mapExpression, put, putAll, remove, size, sizeProperty, valueAt, valueAt, values
Methods declared in class java.lang.Object
clone, equals, finalize, getClass, notify, notifyAll, wait, wait, wait
Methods declared in interface java.util.Map
clear, compute, computeIfAbsent, computeIfPresent, containsKey, containsValue, entrySet, equals, forEach, get, getOrDefault, hashCode, isEmpty, keySet, merge, put, putAll, putIfAbsent, remove, remove, replace, replace, replaceAll, size, values
Methods declared in interface javafx.beans.Observable
addListener, removeListener, subscribe
Methods declared in interface javafx.collections.ObservableMap
addListener, removeListener
Methods declared in interface javafx.beans.value.ObservableObjectValue
get
Methods declared in interface javafx.beans.value.ObservableValue
addListener, flatMap, getValue, map, orElse, removeListener, subscribe, subscribe, when
Methods declared in interface javafx.beans.property.ReadOnlyProperty
getBean, getName
Methods declared in interface javafx.beans.value.WritableObjectValue
get, set
Methods declared in interface javafx.beans.value.WritableValue
getValue
-
Constructor Details
-
MapProperty
public MapProperty()Creates a defaultMapProperty
.
-
-
Method Details
-
setValue
Set the wrapped value.- Specified by:
setValue
in interfaceWritableValue<K>
- Parameters:
v
- The new value
-
bindBidirectional
Create a bidirectional binding between thisProperty
and another one. Bidirectional bindings exists independently of unidirectional bindings. So it is possible to add unidirectional binding to a property with bidirectional binding and vice-versa. However, this practice is discouraged.It is possible to have multiple bidirectional bindings of one Property.
JavaFX bidirectional binding implementation use weak listeners. This means bidirectional binding does not prevent properties from being garbage collected.
- Specified by:
bindBidirectional
in interfaceProperty<K>
- Parameters:
other
- the otherProperty
-
unbindBidirectional
Removes a bidirectional binding between thisProperty
and another one. If no bidirectional binding between the properties exists, calling this method has no effect. It is possible to unbind by a call on the second property. This code will work:property1.bindBidirectional(property2); property2.unbindBidirectional(property1);
- Specified by:
unbindBidirectional
in interfaceProperty<K>
- Parameters:
other
- the otherProperty
-
toString
Returns a string representation of thisMapProperty
object.- Overrides:
toString
in classReadOnlyMapProperty<K,
V> - Returns:
- a string representation of this
MapProperty
object.
-