/* * Copyright (c) 2010, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package javafx.scene.control; import javafx.scene.control.skin.ProgressBarSkin; import javafx.beans.value.WritableValue; import javafx.css.StyleableProperty; import javafx.scene.AccessibleAttribute; import javafx.geometry.Orientation; /** * A specialization of the ProgressIndicator which is represented as a * horizontal bar. *
* ProgressBar sets focusTraversable to false. *
* ** This first example creates a ProgressBar with an indeterminate value: *
ProgressBar p1 = new ProgressBar();
*
*
*
* * This next example creates a ProgressBar which is 25% complete: *
ProgressBar p2 = new ProgressBar();
* p2.setProgress(0.25F);
*
*
*
* @since JavaFX 2.0
*/
public class ProgressBar extends ProgressIndicator {
/***************************************************************************
* *
* Constructors *
* *
**************************************************************************/
/**
* Creates a new indeterminate ProgressBar.
*/
public ProgressBar() {
this(INDETERMINATE_PROGRESS);
}
/**
* Creates a new ProgressBar with the given progress value.
* @param progress the progress, represented as a value between 0 and 1
*/
public ProgressBar(double progress) {
// focusTraversable is styleable through css. Calling setFocusTraversable
// makes it look to css like the user set the value and css will not
// override. Initializing focusTraversable by calling set on the
// CssMetaData ensures that css will be able to override the value.
((StyleableProperty