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 theMapV- 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:
ObservableMap,ObservableMapValue,WritableMapValue,ReadOnlyMapProperty,Property
-
Property Summary
-
Nested Class Summary
-
Constructor Summary
Constructors Constructor Description MapProperty() -
Method Summary
Modifier and Type Method Description voidbindBidirectional(Property<ObservableMap<K,V>> other)Create a bidirectional binding between thisPropertyand another one.voidsetValue(ObservableMap<K,V> v)Set the wrapped value.StringtoString()Returns a string representation of thisMapPropertyobject.voidunbindBidirectional(Property<ObservableMap<K,V>> other)Remove a bidirectional binding between thisPropertyand another one.Methods inherited from class javafx.beans.property.ReadOnlyMapProperty
bindContent, bindContentBidirectional, equals, hashCode, unbindContent, unbindContentBidirectionalMethods inherited from 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, valuesMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from 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, valuesMethods inherited from interface javafx.beans.value.ObservableValue
addListener, getValue, removeListener
-
Constructor Details
-
MapProperty
public MapProperty()
-
-
Method Details
-
setValue
Set the wrapped value.- Specified by:
setValuein interfaceWritableValue<K>- Parameters:
v- The new value
-
bindBidirectional
Create a bidirectional binding between thisPropertyand 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:
bindBidirectionalin interfaceProperty<K>- Parameters:
other- the otherProperty
-
unbindBidirectional
Remove a bidirectional binding between thisPropertyand 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.bindBirectional(property2); property2.unbindBidirectional(property1);- Specified by:
unbindBidirectionalin interfaceProperty<K>- Parameters:
other- the otherProperty
-
toString
Returns a string representation of thisMapPropertyobject.- Overrides:
toStringin classReadOnlyMapProperty<K,V>- Returns:
- a string representation of this
MapPropertyobject.
-