The given consumer will be called once the JavaFX worker is finished. - Java JavaFX

Java examples for JavaFX:Bindable Properties

Description

The given consumer will be called once the JavaFX worker is finished.

Demo Code


/**/*from  ww w. j ava 2  s  .c om*/
     * Copyright (c) 2011, 2014, Jonathan Giles, Johan Vos, Hendrik Ebbers
     * 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 DataFX, the website javafxdata.org, 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 DataFX 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 com.java2s;

import java.util.function.Consumer;

import javafx.beans.property.BooleanProperty;
import javafx.beans.property.ReadOnlyBooleanProperty;
import javafx.beans.property.SimpleBooleanProperty;
import javafx.beans.value.ChangeListener;
import javafx.concurrent.Worker;

public class Main {
  /**
   * The given consumer will be called once the worker is finished. The result of
   * the worker will be passed to the consumer.
   * 
   * @param worker
   *          the worker
   * @param consumer
   *          the consumer
   * @param <T>
   *          the resukt type of the worker
   */
  public static <T> void then(Worker<T> worker, Consumer<T> consumer) {
    ReadOnlyBooleanProperty doneProperty = createIsDoneProperty(worker);
    ChangeListener<Boolean> listener = (o, oldValue, newValue) -> {
      if (newValue) {
        consumer.accept(worker.getValue());
      }
    };
    doneProperty.addListener(listener);
  }

  /**
   * Returns a property that defines the state of the given worker. Once the
   * worker is done the value of the property will be set to true
   * 
   * @param worker
   *          the worker
   * @return the property
   */
  public static ReadOnlyBooleanProperty createIsDoneProperty(Worker<?> worker) {
    final BooleanProperty property = new SimpleBooleanProperty();
    Consumer<Worker.State> stateChecker = (s) -> {
      if (s.equals(Worker.State.CANCELLED) || s.equals(Worker.State.FAILED) || s.equals(Worker.State.SUCCEEDED)) {
        property.setValue(true);
      } else {
        property.setValue(false);
      }
    };
    worker.stateProperty().addListener((o, oldValue, newValue) -> stateChecker.accept(newValue));
    stateChecker.accept(worker.getState());
    return property;

  }
}

Related Tutorials