- java.lang.Object
-
- javafx.beans.binding.SetExpression<E>
-
- javafx.beans.property.ReadOnlySetProperty<E>
-
- javafx.beans.property.SetProperty<E>
-
- Type Parameters:
E
- the type of theSet
elements
- All Implemented Interfaces:
Iterable<E>
,Collection<E>
,Set<E>
,Observable
,Property<ObservableSet<E>>
,ReadOnlyProperty<ObservableSet<E>>
,ObservableObjectValue<ObservableSet<E>>
,ObservableSetValue<E>
,ObservableValue<ObservableSet<E>>
,WritableObjectValue<ObservableSet<E>>
,WritableSetValue<E>
,WritableValue<ObservableSet<E>>
,ObservableSet<E>
- Direct Known Subclasses:
SetPropertyBase
public abstract class SetProperty<E> extends ReadOnlySetProperty<E> implements Property<ObservableSet<E>>, WritableSetValue<E>
This class provides a full implementation of aProperty
wrapping anObservableSet
. The value of aSetProperty
can be get and set withObservableObjectValue.get()
,SetExpression.getValue()
,WritableObjectValue.set(Object)
, andsetValue(ObservableSet)
. A property can be bound and unbound unidirectional withProperty.bind(javafx.beans.value.ObservableValue)
andProperty.unbind()
. Bidirectional bindings can be created and removed withbindBidirectional(Property)
andunbindBidirectional(Property)
. The context of aSetProperty
can be read withReadOnlyProperty.getBean()
andReadOnlyProperty.getName()
.- Since:
- JavaFX 2.1
- See Also:
ObservableSet
,ObservableSetValue
,WritableSetValue
,ReadOnlySetProperty
,Property
-
-
Property Summary
-
Properties inherited from class javafx.beans.binding.SetExpression
empty, size
-
-
Constructor Summary
Constructors Constructor Description SetProperty()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
bindBidirectional(Property<ObservableSet<E>> other)
Create a bidirectional binding between thisProperty
and another one.void
setValue(ObservableSet<E> v)
Set the wrapped value.String
toString()
Returns a string representation of thisSetProperty
object.void
unbindBidirectional(Property<ObservableSet<E>> other)
Remove a bidirectional binding between thisProperty
and another one.-
Methods inherited from class javafx.beans.property.ReadOnlySetProperty
bindContent, bindContentBidirectional, equals, hashCode, unbindContent, unbindContentBidirectional
-
Methods inherited from class javafx.beans.binding.SetExpression
add, addAll, asString, clear, contains, containsAll, emptyProperty, getSize, getValue, isEmpty, isEqualTo, isNotEqualTo, isNotNull, isNull, iterator, remove, removeAll, retainAll, setExpression, size, sizeProperty, toArray, toArray
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface java.util.Collection
parallelStream, removeIf, stream, toArray
-
Methods inherited from interface javafx.beans.Observable
addListener, removeListener
-
Methods inherited from interface javafx.beans.value.ObservableObjectValue
get
-
Methods inherited from interface javafx.collections.ObservableSet
addListener, removeListener
-
Methods inherited from interface javafx.beans.value.ObservableValue
addListener, getValue, removeListener
-
Methods inherited from interface javafx.beans.property.ReadOnlyProperty
getBean, getName
-
Methods inherited from interface java.util.Set
add, addAll, clear, contains, containsAll, equals, hashCode, isEmpty, iterator, remove, removeAll, retainAll, size, spliterator, toArray, toArray
-
Methods inherited from interface javafx.beans.value.WritableObjectValue
get, set
-
Methods inherited from interface javafx.beans.value.WritableValue
getValue
-
-
-
-
Method Detail
-
setValue
public void setValue(ObservableSet<E> v)
Set the wrapped value.- Specified by:
setValue
in interfaceWritableValue<E>
- Parameters:
v
- The new value
-
bindBidirectional
public void bindBidirectional(Property<ObservableSet<E>> other)
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<E>
- Parameters:
other
- the otherProperty
-
unbindBidirectional
public void unbindBidirectional(Property<ObservableSet<E>> other)
Remove 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.bindBirectional(property2); property2.unbindBidirectional(property1);
- Specified by:
unbindBidirectional
in interfaceProperty<E>
- Parameters:
other
- the otherProperty
-
toString
public String toString()
Returns a string representation of thisSetProperty
object.- Overrides:
toString
in classReadOnlySetProperty<E>
- Returns:
- a string representation of this
SetProperty
object.
-
-