- java.lang.Object
-
- javafx.beans.binding.NumberExpressionBase
-
- javafx.beans.binding.FloatExpression
-
- javafx.beans.property.ReadOnlyFloatProperty
-
- javafx.beans.property.FloatProperty
-
- 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
This class defines aProperty
wrapping afloat
value.The value of a
FloatProperty
can be get and set withObservableFloatValue.get()
,FloatExpression.getValue()
,WritableFloatValue.set(float)
, andsetValue(Number)
.A property can be bound and unbound unidirectional with
Property.bind(ObservableValue)
andProperty.unbind()
. Bidirectional bindings can be created and removed withbindBidirectional(Property)
andunbindBidirectional(Property)
.The context of a
FloatProperty
can be read withReadOnlyProperty.getBean()
andReadOnlyProperty.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
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description ObjectProperty<Float>
asObject()
Creates anObjectProperty
that bidirectionally bound to thisFloatProperty
.void
bindBidirectional(Property<Number> other)
Create a bidirectional binding between thisProperty
and another one.static FloatProperty
floatProperty(Property<Float> property)
Returns aFloatProperty
that wraps aProperty
and is bidirectionally bound to it.void
setValue(Number v)
Set the wrapped value.String
toString()
Returns a string representation of thisFloatProperty
object.void
unbindBidirectional(Property<Number> other)
Remove a bidirectional binding between thisProperty
and 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, subtract
-
Methods 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, subtract
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface javafx.beans.Observable
addListener, removeListener
-
Methods inherited from interface javafx.beans.value.ObservableFloatValue
get
-
Methods inherited from interface javafx.beans.value.ObservableValue
addListener, getValue, removeListener
-
Methods inherited from class javafx.beans.property.ReadOnlyFloatProperty
readOnlyFloatProperty
-
Methods inherited from interface javafx.beans.property.ReadOnlyProperty
getBean, getName
-
Methods inherited from interface javafx.beans.value.WritableFloatValue
get, set
-
Methods inherited from interface javafx.beans.value.WritableValue
getValue
-
-
-
-
Method Detail
-
setValue
public void setValue(Number v)
Set the wrapped value.- Specified by:
setValue
in interfaceWritableFloatValue
- Specified by:
setValue
in interfaceWritableValue<Number>
- Parameters:
v
- The new value
-
bindBidirectional
public void bindBidirectional(Property<Number> 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<Number>
- Parameters:
other
- the otherProperty
-
unbindBidirectional
public void unbindBidirectional(Property<Number> 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<Number>
- Parameters:
other
- the otherProperty
-
toString
public String toString()
Returns a string representation of thisFloatProperty
object.- Overrides:
toString
in classReadOnlyFloatProperty
- Returns:
- a string representation of this
FloatProperty
object.
-
floatProperty
public static FloatProperty floatProperty(Property<Float> property)
Returns aFloatProperty
that wraps aProperty
and 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
FloatProperty
that wraps theProperty
- Throws:
NullPointerException
- ifproperty
isnull
- Since:
- JavaFX 8.0
- See Also:
asObject()
-
asObject
public ObjectProperty<Float> asObject()
Creates anObjectProperty
that bidirectionally bound to thisFloatProperty
. If the value of thisFloatProperty
changes, the value of theObjectProperty
will 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:
asObject
in classReadOnlyFloatProperty
- Returns:
- the new
ObjectProperty
- Since:
- JavaFX 8.0
-
-