K
- the type of the key elements of the Map
V
- the type of the value elements of the Map
public abstract class MapProperty<K,V> extends ReadOnlyMapProperty<K,V> implements Property<ObservableMap<K,V>>, WritableMapValue<K,V>
Property
wrapping a
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()
.ObservableMap
,
ObservableMapValue
,
WritableMapValue
,
ReadOnlyMapProperty
,
Property
empty, size
Constructor and Description |
---|
MapProperty() |
Modifier and Type | Method and Description |
---|---|
void |
bindBidirectional(Property<ObservableMap<K,V>> other)
Create a bidirectional binding between this
Property and another
one. |
void |
setValue(ObservableMap<K,V> v)
Set the wrapped value.
|
String |
toString()
Returns a string representation of this
MapProperty object. |
void |
unbindBidirectional(Property<ObservableMap<K,V>> other)
Remove a bidirectional binding between this
Property and another
one. |
bindContent, bindContentBidirectional, equals, hashCode, unbindContent, unbindContentBidirectional
asString, clear, containsKey, containsValue, emptyProperty, entrySet, get, getSize, getValue, isEmpty, isEqualTo, isNotEqualTo, isNotNull, isNull, keySet, mapExpression, put, putAll, remove, size, sizeProperty, valueAt, valueAt, values
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
getBean, getName
addListener, getValue, removeListener
addListener, removeListener
get, set
getValue
addListener, removeListener
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
get
public void setValue(ObservableMap<K,V> v)
setValue
in interface WritableValue<ObservableMap<K,V>>
v
- The new valuepublic void bindBidirectional(Property<ObservableMap<K,V>> other)
Property
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.
bindBidirectional
in interface Property<ObservableMap<K,V>>
other
- the other Property
public void unbindBidirectional(Property<ObservableMap<K,V>> other)
Property
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.bindBirectional(property2); property2.unbindBidirectional(property1);
unbindBidirectional
in interface Property<ObservableMap<K,V>>
other
- the other Property
public String toString()
MapProperty
object.toString
in class ReadOnlyMapProperty<K,V>
MapProperty
object.Submit a bug or feature
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
Copyright © 2008, 2020, Oracle and/or its affiliates. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.