All Downloads are FREE. Search and download functionalities are using the official Maven repository.

scalafx.scene.control.SpinnerValueFactory.scala Maven / Gradle / Ivy

/*
 * Copyright (c) 2011-2014, ScalaFX Project
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *     * Redistributions of source code must retain the above copyright
 *       notice, this list of conditions and the following disclaimer.
 *     * Redistributions in binary form must reproduce the above copyright
 *       notice, this list of conditions and the following disclaimer in the
 *       documentation and/or other materials provided with the distribution.
 *     * Neither the name of the ScalaFX Project nor the
 *       names of its contributors may be used to endorse or promote products
 *       derived from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL THE SCALAFX PROJECT OR ITS CONTRIBUTORS BE LIABLE
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

package scalafx.scene.control


import javafx.scene.{control => jfxsc}
import javafx.{collections => jfxc, util => jfxu}

import scala.language.implicitConversions
import scalafx.Includes._
import scalafx.beans.property.{BooleanProperty, DoubleProperty, IntegerProperty, ObjectProperty}
import scalafx.collections.ObservableBuffer
import scalafx.delegate.SFXDelegate
import scalafx.util.StringConverter


object SpinnerValueFactory {

  implicit def sfxSpinnerValueFactory2jfx[T](v: SpinnerValueFactory[T]): jfxsc.SpinnerValueFactory[T] =
    if (v != null) v.delegate else null

  object ListSpinnerValueFactory {
    implicit def sfxListSpinnerValueFactory2jfx[T](v: ListSpinnerValueFactory[T]): jfxsc.SpinnerValueFactory.ListSpinnerValueFactory[T] =
      if (v != null) v.delegate else null
  }


  /**
   * A SpinnerValueFactory implementation designed to iterate through
   * a list of values.
   *
   *
   * @tparam T The type of the elements in the List.
   */
  class ListSpinnerValueFactory[T](override val delegate: jfxsc.SpinnerValueFactory.ListSpinnerValueFactory[T])
    extends SpinnerValueFactory(delegate)
    with SFXDelegate[jfxsc.SpinnerValueFactory.ListSpinnerValueFactory[T]] {

    /**
     * Creates a new instance of the ListSpinnerValueFactory with the given
     * list used as the list to step through.
     *
     * @param items The list of items to step through with the Spinner.
     */
    def this(items: ObservableBuffer[T]) {
      this(new jfxsc.SpinnerValueFactory.ListSpinnerValueFactory(items.delegate))
    }

    /**
     * The underlying data model for the ListView. Note that it has a generic
     * type that must match the type of the ListView itself.
     */
    def items: ObjectProperty[jfxc.ObservableList[T]] = delegate.itemsProperty
    def items_=(v: ObservableBuffer[T]) {
      items() = v
    }
  }

  object IntegerSpinnerValueFactory {
    implicit def sfxIntegerSpinnerValueFactory2jfx(v: IntegerSpinnerValueFactory): jfxsc.SpinnerValueFactory.IntegerSpinnerValueFactory =
      if (v != null) v.delegate else null
  }

  class IntegerSpinnerValueFactory(override val delegate: jfxsc.SpinnerValueFactory.IntegerSpinnerValueFactory)
    extends SpinnerValueFactory[Integer](delegate)
    with SFXDelegate[jfxsc.SpinnerValueFactory.IntegerSpinnerValueFactory] {

    /**
     * Constructs a new IntegerSpinnerValueFactory that sets the initial value
     * to be equal to the min value, and a default `amountToStepBy` of one.
     *
     * @param min The minimum allowed integer value for the Spinner.
     * @param max The maximum allowed integer value for the Spinner.
     */
    def this(min: Int, max: Int) {
      this(new jfxsc.SpinnerValueFactory.IntegerSpinnerValueFactory(min, max))
    }

    /**
     * Constructs a new IntegerSpinnerValueFactory with a default
     * `amountToStepBy` of one.
     *
     * @param min The minimum allowed integer value for the Spinner.
     * @param max The maximum allowed integer value for the Spinner.
     * @param initialValue The value of the Spinner when first instantiated, must
     *                     be within the bounds of the min and max arguments, or
     *                     else the min value will be used.
     */
    def this(min: Int, max: Int, initialValue: Int) {
      this(new jfxsc.SpinnerValueFactory.IntegerSpinnerValueFactory(min, max, initialValue))
    }

    /**
     * Constructs a new IntegerSpinnerValueFactory.
     *
     * @param min The minimum allowed integer value for the Spinner.
     * @param max The maximum allowed integer value for the Spinner.
     * @param initialValue The value of the Spinner when first instantiated, must
     *                     be within the bounds of the min and max arguments, or
     *                     else the min value will be used.
     * @param amountToStepBy The amount to increment or decrement by, per step.
     */
    def this(min: Int, max: Int, initialValue: Int, amountToStepBy: Int) {
      this(new jfxsc.SpinnerValueFactory.IntegerSpinnerValueFactory(min, max, initialValue, amountToStepBy))
    }

    /**
     * Sets the minimum allowable value for this value factory
     */
    def min: IntegerProperty = delegate.minProperty
    def min_=(value: Int) {
      min() = value
    }

    /**
     * Sets the maximum allowable value for this value factory
     */
    def max: IntegerProperty = delegate.maxProperty
    def max_=(value: Int) {
      max() = value
    }

    /**
     * Sets the amount to increment or decrement by, per step.
     */
    def amountToStepBy: IntegerProperty = delegate.amountToStepByProperty
    def amountToStepBy_=(value: Int) {
      amountToStepBy() = value
    }
  }

  object DoubleSpinnerValueFactory {
    implicit def sfxDoubleSpinnerValueFactory2jfx(v: DoubleSpinnerValueFactory): jfxsc.SpinnerValueFactory.DoubleSpinnerValueFactory =
      if (v != null) v.delegate else null
  }


  /**
   * A `SpinnerValueFactory` implementation designed to iterate through
   * double values.
   *
   */
  class DoubleSpinnerValueFactory(override val delegate: jfxsc.SpinnerValueFactory.DoubleSpinnerValueFactory)
    extends SpinnerValueFactory(delegate)
    with SFXDelegate[jfxsc.SpinnerValueFactory.DoubleSpinnerValueFactory] {

    /**
     * Constructs a new DoubleSpinnerValueFactory that sets the initial value
     * to be equal to the min value, and a default `amountToStepBy` of
     * one.
     *
     * @param min The minimum allowed double value for the Spinner.
     * @param max The maximum allowed double value for the Spinner.
     */
    def this(min: Double, max: Double) {
      this(new jfxsc.SpinnerValueFactory.DoubleSpinnerValueFactory(min, max))
    }

    /**
     * Constructs a new DoubleSpinnerValueFactory with a default
     * `amountToStepBy` of one.
     *
     * @param min The minimum allowed double value for the Spinner.
     * @param max The maximum allowed double value for the Spinner.
     * @param initialValue The value of the Spinner when first instantiated, must
     *                     be within the bounds of the min and max arguments, or
     *                     else the min value will be used.
     */
    def this(min: Double, max: Double, initialValue: Double) {
      this(new jfxsc.SpinnerValueFactory.DoubleSpinnerValueFactory(min, max, initialValue))
    }

    /**
     * Constructs a new DoubleSpinnerValueFactory.
     *
     * @param min The minimum allowed double value for the Spinner.
     * @param max The maximum allowed double value for the Spinner.
     * @param initialValue The value of the Spinner when first instantiated, must
     *                     be within the bounds of the min and max arguments, or
     *                     else the min value will be used.
     * @param amountToStepBy The amount to increment or decrement by, per step.
     */
    def this(min: Double, max: Double, initialValue: Double, amountToStepBy: Double) {
      this(new jfxsc.SpinnerValueFactory.DoubleSpinnerValueFactory(min, max, initialValue, amountToStepBy))
    }

    /**
     * Sets the minimum allowable value for this value factory
     */
    def min: DoubleProperty = delegate.minProperty
    def min_=(value: Double) {
      min() = value
    }

    /**
     * Sets the maximum allowable value for this value factory
     */
    def max: DoubleProperty = delegate.maxProperty
    def max_=(value: Double) {
      max() = value
    }

    /**
     * Sets the amount to increment or decrement by, per step.
     */
    def amountToStepBy: DoubleProperty = delegate.amountToStepByProperty
    def amountToStepBy_=(value: Double) {
      amountToStepBy() = value
    }
  }

}

/**
 * The SpinnerValueFactory is the model behind the `Spinner` control - without a value factory installed a
 * `Spinner` is unusable.
 *
 * Wraps a JavaFX [[http://docs.oracle.com/javase/8/javafx/api/javafx/scene/control/SpinnerValueFactory.html]].
 *
 * @param delegate A JavaFX SpinnerValueFactory to be wrapped. Its default value is a new JavaFX SpinnerValueFactory.
 * @tparam T The type of the data this value factory deals with, which must
 *           coincide with the type of the Spinner that the value factory is set on.
 */
abstract class SpinnerValueFactory[T](override val delegate: jfxsc.SpinnerValueFactory[T])
  extends SFXDelegate[jfxsc.SpinnerValueFactory[T]] {

  /**
   * Represents the current value of the SpinnerValueFactory, or null if no
   * value has been set.
   */
  def value: ObjectProperty[T] = delegate.valueProperty()
  def value_=(newValue: T): Unit = {
    value() = newValue
  }

  /**
   * Converts the user-typed input (when the Spinner is `editable`) to an object of type T,
   * such that the input may be retrieved via the  `value`
   * property.
   */
  def converter: ObjectProperty[jfxu.StringConverter[T]] = delegate.converterProperty()
  def converter_=(newValue: StringConverter[T]): Unit = {
    converter() = newValue
  }

  /**
   * The wrapAround property is used to specify whether the value factory should
   * be circular. For example, should an integer-based value model increment
   * from the maximum value back to the minimum value (and vice versa).
   */
  def wrapAround: BooleanProperty = delegate.wrapAroundProperty()
  def wrapAround_=(value: Boolean): Unit = {
    wrapAround() = value
  }

}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy