- java.lang.Object
-
- javafx.beans.binding.NumberExpressionBase
-
- javafx.beans.binding.IntegerExpression
-
- javafx.beans.property.ReadOnlyIntegerProperty
-
- javafx.beans.property.IntegerProperty
-
- All Implemented Interfaces:
NumberExpression,Observable,Property<Number>,ReadOnlyProperty<Number>,ObservableIntegerValue,ObservableNumberValue,ObservableValue<Number>,WritableIntegerValue,WritableNumberValue,WritableValue<Number>
- Direct Known Subclasses:
IntegerPropertyBase,JavaBeanIntegerProperty
public abstract class IntegerProperty extends ReadOnlyIntegerProperty implements Property<Number>, WritableIntegerValue
This class defines aPropertywrapping anintvalue.The value of an
IntegerPropertycan be get and set withObservableIntegerValue.get(),IntegerExpression.getValue(),WritableIntegerValue.set(int), 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
IntegerPropertycan 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:
ObservableIntegerValue,WritableIntegerValue,ReadOnlyIntegerProperty,Property
-
-
Constructor Summary
Constructors Constructor Description IntegerProperty()
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description ObjectProperty<Integer>asObject()Creates anObjectPropertythat bidirectionally bound to thisIntegerProperty.voidbindBidirectional(Property<Number> other)Create a bidirectional binding between thisPropertyand another one.static IntegerPropertyintegerProperty(Property<Integer> property)Returns aIntegerPropertythat wraps aPropertyand is bidirectionally bound to it.voidsetValue(Number v)Set the wrapped value.StringtoString()Returns a string representation of thisIntegerPropertyobject.voidunbindBidirectional(Property<Number> other)Remove a bidirectional binding between thisPropertyand another one.-
Methods inherited from class javafx.beans.property.ReadOnlyIntegerProperty
readOnlyIntegerProperty
-
Methods inherited from class javafx.beans.binding.IntegerExpression
add, add, add, add, divide, divide, divide, divide, doubleValue, floatValue, getValue, integerExpression, integerExpression, 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.ObservableIntegerValue
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.WritableIntegerValue
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:
setValuein interfaceWritableIntegerValue- Specified by:
setValuein interfaceWritableValue<Number>- Parameters:
v- The new value
-
bindBidirectional
public void bindBidirectional(Property<Number> other)
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
public void unbindBidirectional(Property<Number> other)
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
public String toString()
Returns a string representation of thisIntegerPropertyobject.- Overrides:
toStringin classReadOnlyIntegerProperty- Returns:
- a string representation of this
IntegerPropertyobject.
-
integerProperty
public static IntegerProperty integerProperty(Property<Integer> property)
Returns aIntegerPropertythat 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<Integer> and a IntegerProperty.
Another approach is to convert the IntegerProperty to ObjectProperty usingIntegerProperty integerProperty = new SimpleIntegerProperty(1); ObjectProperty<Integer> objectProperty = new SimpleObjectProperty<>(2); // Need to keep the reference as bidirectional binding uses weak references IntegerProperty objectAsInteger = IntegerProperty.integerProperty(objectProperty); integerProperty.bindBidirectional(objectAsInteger);
asObject()method.Note: null values in the source property will be interpreted as 0
- Parameters:
property- The sourceProperty- Returns:
- A
IntegerPropertythat wraps theProperty - Throws:
NullPointerException- ifpropertyisnull- Since:
- JavaFX 8.0
- See Also:
asObject()
-
asObject
public ObjectProperty<Integer> asObject()
Creates anObjectPropertythat bidirectionally bound to thisIntegerProperty. If the value of thisIntegerPropertychanges, the value of theObjectPropertywill be updated automatically and vice-versa.Can be used for binding an ObjectProperty to IntegerProperty.
IntegerProperty integerProperty = new SimpleIntegerProperty(1); ObjectProperty<Integer> objectProperty = new SimpleObjectProperty<>(2); objectProperty.bind(integerProperty.asObject());
- Overrides:
asObjectin classReadOnlyIntegerProperty- Returns:
- the new
ObjectProperty - Since:
- JavaFX 8.0
-
-