- All Implemented Interfaces:
NumberExpression,Observable,Property<Number>,ReadOnlyProperty<Number>,ObservableDoubleValue,ObservableNumberValue,ObservableValue<Number>,WritableDoubleValue,WritableNumberValue,WritableValue<Number>
- Direct Known Subclasses:
DoublePropertyBase,JavaBeanDoubleProperty
Property wrapping a double value.
The value of a DoubleProperty can be get and set with ObservableDoubleValue.get(),
DoubleExpression.getValue(), WritableDoubleValue.set(double), and setValue(Number).
A property can be bound and unbound unidirectional with
Property.bind(ObservableValue) and Property.unbind(). Bidirectional bindings
can be created and removed with bindBidirectional(Property) and
unbindBidirectional(Property).
The context of a DoubleProperty can be read with ReadOnlyProperty.getBean()
and ReadOnlyProperty.getName().
Note: setting or binding this property to a null value will set the property to "0.0". See setValue(java.lang.Number).
- Since:
- JavaFX 2.0
- See Also:
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionasObject()Creates anObjectPropertythat bidirectionally bound to thisDoubleProperty.voidbindBidirectional(Property<Number> other) Create a bidirectional binding between thisPropertyand another one.static DoublePropertydoubleProperty(Property<Double> property) Returns aDoublePropertythat wraps aPropertyand is bidirectionally bound to it.voidSet the wrapped value.toString()Returns a string representation of thisDoublePropertyobject.voidunbindBidirectional(Property<Number> other) Removes a bidirectional binding between thisPropertyand another one.Methods declared in class javafx.beans.property.ReadOnlyDoubleProperty
readOnlyDoublePropertyMethods declared in class javafx.beans.binding.DoubleExpression
add, add, add, add, add, divide, divide, divide, divide, divide, doubleExpression, doubleExpression, doubleValue, floatValue, getValue, intValue, longValue, multiply, multiply, multiply, multiply, multiply, negate, subtract, subtract, subtract, subtract, subtractMethods declared in class javafx.beans.binding.NumberExpressionBase
asString, asString, asString, greaterThan, greaterThan, greaterThan, greaterThan, greaterThan, greaterThanOrEqualTo, greaterThanOrEqualTo, greaterThanOrEqualTo, greaterThanOrEqualTo, greaterThanOrEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, isNotEqualTo, lessThan, lessThan, lessThan, lessThan, lessThan, lessThanOrEqualTo, lessThanOrEqualTo, lessThanOrEqualTo, lessThanOrEqualTo, lessThanOrEqualTo, numberExpressionMethods declared in class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods declared in interface javafx.beans.Observable
addListener, removeListener, subscribeMethods declared in interface javafx.beans.value.ObservableDoubleValue
getMethods declared in interface javafx.beans.value.ObservableValue
addListener, flatMap, getValue, map, orElse, removeListener, subscribe, subscribe, whenMethods declared in interface javafx.beans.property.ReadOnlyProperty
getBean, getNameMethods declared in interface javafx.beans.value.WritableDoubleValue
get, setMethods declared in interface javafx.beans.value.WritableValue
getValue
-
Constructor Details
-
DoubleProperty
public DoubleProperty()Creates a defaultDoubleProperty.
-
-
Method Details
-
setValue
Set the wrapped value.- Specified by:
setValuein interfaceWritableDoubleValue- Specified by:
setValuein interfaceWritableValue<Number>- 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<Number>- Parameters:
other- the otherProperty
-
unbindBidirectional
Removes 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.bindBidirectional(property2); property2.unbindBidirectional(property1);- Specified by:
unbindBidirectionalin interfaceProperty<Number>- Parameters:
other- the otherProperty
-
toString
Returns a string representation of thisDoublePropertyobject.- Overrides:
toStringin classReadOnlyDoubleProperty- Returns:
- a string representation of this
DoublePropertyobject.
-
doubleProperty
Returns aDoublePropertythat wraps aPropertyand is bidirectionally bound to it. Changing this property will result in a change of the original property.This is very useful when bidirectionally binding an ObjectProperty<Double> and a DoubleProperty.
Another approach is to convert the DoubleProperty to ObjectProperty usingDoubleProperty doubleProperty = new SimpleDoubleProperty(1.0); ObjectProperty<Double> objectProperty = new SimpleObjectProperty<>(2.0); // Need to keep the reference as bidirectional binding uses weak references DoubleProperty objectAsDouble = DoubleProperty.doubleProperty(objectProperty); doubleProperty.bindBidirectional(objectAsDouble);
asObject()method.Note: null values in the source property will be interpreted as 0.0
- Parameters:
property- The sourceProperty- Returns:
- A
DoublePropertythat wraps theProperty - Throws:
NullPointerException- ifpropertyisnull- Since:
- JavaFX 8.0
- See Also:
-
asObject
Creates anObjectPropertythat bidirectionally bound to thisDoubleProperty. If the value of thisDoublePropertychanges, the value of theObjectPropertywill be updated automatically and vice-versa.Can be used for binding an ObjectProperty to DoubleProperty.
DoubleProperty doubleProperty = new SimpleDoubleProperty(1.0); ObjectProperty<Double> objectProperty = new SimpleObjectProperty<>(2.0); objectProperty.bind(doubleProperty.asObject());
- Overrides:
asObjectin classReadOnlyDoubleProperty- Returns:
- the new
ObjectProperty - Since:
- JavaFX 8.0
-