- All Implemented Interfaces:
NumberExpression,Observable,Property<Number>,ReadOnlyProperty<Number>,ObservableFloatValue,ObservableNumberValue,ObservableValue<Number>,WritableFloatValue,WritableNumberValue,WritableValue<Number>
- Direct Known Subclasses:
FloatPropertyBase,JavaBeanFloatProperty
public abstract class FloatProperty extends ReadOnlyFloatProperty implements Property<Number>, WritableFloatValue
Property wrapping a float value.
The value of a FloatProperty can be get and set with ObservableFloatValue.get(),
FloatExpression.getValue(), WritableFloatValue.set(float), 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 FloatProperty 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:
ObservableFloatValue,WritableFloatValue,ReadOnlyFloatProperty,Property
-
Constructor Summary
Constructors Constructor Description FloatProperty() -
Method Summary
Modifier and Type Method Description ObjectProperty<Float>asObject()Creates anObjectPropertythat bidirectionally bound to thisFloatProperty.voidbindBidirectional(Property<Number> other)Create a bidirectional binding between thisPropertyand another one.static FloatPropertyfloatProperty(Property<Float> property)Returns aFloatPropertythat wraps aPropertyand is bidirectionally bound to it.voidsetValue(Number v)Set the wrapped value.StringtoString()Returns a string representation of thisFloatPropertyobject.voidunbindBidirectional(Property<Number> other)Remove a bidirectional binding between thisPropertyand another one.Methods inherited from class javafx.beans.binding.FloatExpression
add, add, add, add, divide, divide, divide, divide, doubleValue, floatExpression, floatExpression, floatValue, getValue, intValue, longValue, multiply, multiply, multiply, multiply, negate, subtract, subtract, subtract, subtractMethods inherited from class javafx.beans.binding.NumberExpressionBase
add, asString, asString, asString, divide, 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, multiply, numberExpression, subtractMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface javafx.beans.value.ObservableValue
addListener, getValue, removeListener
-
Constructor Details
-
FloatProperty
public FloatProperty()
-
-
Method Details
-
setValue
Set the wrapped value.- Specified by:
setValuein interfaceWritableFloatValue- 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
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<Number>- Parameters:
other- the otherProperty
-
toString
Returns a string representation of thisFloatPropertyobject.- Overrides:
toStringin classReadOnlyFloatProperty- Returns:
- a string representation of this
FloatPropertyobject.
-
floatProperty
Returns aFloatPropertythat 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<Float> and a FloatProperty.
Another approach is to convert the FloatProperty to ObjectProperty usingFloatProperty floatProperty = new SimpleFloatProperty(1.0f); ObjectProperty<Float> objectProperty = new SimpleObjectProperty<>(2.0f); // Need to keep the reference as bidirectional binding uses weak references FloatProperty objectAsFloat = FloatProperty.floatProperty(objectProperty); floatProperty.bindBidirectional(objectAsFloat);
asObject()method.Note: null values in the source property will be interpreted as 0f
- Parameters:
property- The sourceProperty- Returns:
- A
FloatPropertythat wraps theProperty - Throws:
NullPointerException- ifpropertyisnull- Since:
- JavaFX 8.0
- See Also:
asObject()
-
asObject
Creates anObjectPropertythat bidirectionally bound to thisFloatProperty. If the value of thisFloatPropertychanges, the value of theObjectPropertywill be updated automatically and vice-versa.Can be used for binding an ObjectProperty to FloatProperty.
FloatProperty floatProperty = new SimpleFloatProperty(1.0f); ObjectProperty<Float> objectProperty = new SimpleObjectProperty<>(2.0f); objectProperty.bind(floatProperty.asObject());
- Overrides:
asObjectin classReadOnlyFloatProperty- Returns:
- the new
ObjectProperty - Since:
- JavaFX 8.0
-