- All Implemented Interfaces:
NumberExpression
,Observable
,Property<Number>
,ReadOnlyProperty<Number>
,ObservableLongValue
,ObservableNumberValue
,ObservableValue<Number>
,WritableLongValue
,WritableNumberValue
,WritableValue<Number>
- Direct Known Subclasses:
JavaBeanLongProperty
,LongPropertyBase
public abstract class LongProperty extends ReadOnlyLongProperty implements Property<Number>, WritableLongValue
Property
wrapping a long
value.
The value of a LongProperty
can be get and set with ObservableLongValue.get()
,
LongExpression.getValue()
, WritableLongValue.set(long)
, 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 LongProperty
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:
ObservableLongValue
,WritableLongValue
,ReadOnlyLongProperty
,Property
-
Constructor Summary
Constructors Constructor Description LongProperty()
Creates a defaultLongProperty
. -
Method Summary
Modifier and Type Method Description ObjectProperty<Long>
asObject()
Creates anObjectProperty
that bidirectionally bound to thisLongProperty
.void
bindBidirectional(Property<Number> other)
Create a bidirectional binding between thisProperty
and another one.static LongProperty
longProperty(Property<Long> property)
Returns aLongProperty
that wraps aProperty
and is bidirectionally bound to it.void
setValue(Number v)
Set the wrapped value.String
toString()
Returns a string representation of thisLongProperty
object.void
unbindBidirectional(Property<Number> other)
Remove a bidirectional binding between thisProperty
and another one.Methods inherited from class javafx.beans.property.ReadOnlyLongProperty
readOnlyLongProperty
Methods inherited from class javafx.beans.binding.LongExpression
add, add, add, add, divide, divide, divide, divide, doubleValue, floatValue, getValue, intValue, longExpression, longExpression, 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.ObservableLongValue
get
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 javafx.beans.value.WritableLongValue
get, set
Methods inherited from interface javafx.beans.value.WritableValue
getValue
-
Constructor Details
-
LongProperty
public LongProperty()Creates a defaultLongProperty
.
-
-
Method Details
-
setValue
Set the wrapped value.- Specified by:
setValue
in interfaceWritableLongValue
- Specified by:
setValue
in interfaceWritableValue<Number>
- Parameters:
v
- The new value
-
bindBidirectional
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
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
Returns a string representation of thisLongProperty
object.- Overrides:
toString
in classReadOnlyLongProperty
- Returns:
- a string representation of this
LongProperty
object.
-
longProperty
Returns aLongProperty
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<Long> and a LongProperty.
Another approach is to convert the LongProperty to ObjectProperty usingLongProperty longProperty = new SimpleLongProperty(1L); ObjectProperty<Long> objectProperty = new SimpleObjectProperty<>(2L); // Need to keep the reference as bidirectional binding uses weak references LongProperty objectAsLong = LongProperty.longProperty(objectProperty); longProperty.bindBidirectional(objectAsLong);
asObject()
method.Note: null values in the source property will be interpreted as 0L
- Parameters:
property
- The sourceProperty
- Returns:
- A
LongProperty
that wraps theProperty
- Throws:
NullPointerException
- ifproperty
isnull
- Since:
- JavaFX 8.0
- See Also:
asObject()
-
asObject
Creates anObjectProperty
that bidirectionally bound to thisLongProperty
. If the value of thisLongProperty
changes, the value of theObjectProperty
will be updated automatically and vice-versa.Can be used for binding an ObjectProperty to LongProperty.
LongProperty longProperty = new SimpleLongProperty(1L); ObjectProperty<Long> objectProperty = new SimpleObjectProperty<>(2L); objectProperty.bind(longProperty.asObject());
- Overrides:
asObject
in classReadOnlyLongProperty
- Returns:
- the new
ObjectProperty
- Since:
- JavaFX 8.0
-