javafx.scene.control.ColorPicker Maven / Gradle / Ivy
Show all versions of openjfx-78-backport Show documentation
/*
* Copyright (c) 2012, 2013, 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.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.scene.paint.Color;
import com.sun.javafx.scene.control.skin.ColorPickerSkin;
/**
* ColorPicker control allows the user to select a color from either a standard
* palette of colors with a simple one click selection OR define their own custom color.
*
*
The {@link #valueProperty() value} is the currently selected {@link javafx.scene.paint.Color}.
* An initial color can be set by calling setColor or via the constructor. If nothing
* is specified, a default initial color is used.
*
*
The ColorPicker control provides a color palette with a predefined set of colors. If
* the user does not want to choose from the predefined set, they can create a custom
* color by interacting with a custom color dialog. This dialog provides RGB,
* HSB and Web modes of interaction, to create new colors. It also lets the opacity
* of the color to be modified.
*
*
Once a new color is defined, users can choose whether they want to save it
* or just use it. If the new color is saved, this color will then appear in the
* custom colors area on the color palette. Also {@link #getCustomColors() getCustomColors}
* returns the list of saved custom colors.
*
*
The {@link #promptTextProperty() promptText} is not supported and hence is a no-op.
* But it may be supported in the future.
*
*
* final ColorPicker colorPicker = new ColorPicker();
* colorPicker.setOnAction(new EventHandler() {
* public void handle(Event t) {
* Color c = colorPicker.getValue();
* System.out.println("New Color's RGB = "+c.getRed()+" "+c.getGreen()+" "+c.getBlue());
* }
* });
*
*
* The ColorPicker control's appearance can be styled in three ways: a simple Button mode,
* MenuButton mode or SplitMenuButton mode. The default is MenuButton mode.
* For a Button like appearance the style class to use is {@link #STYLE_CLASS_BUTTON STYLE_CLASS_BUTTON}
* and for SplitMenuButton appearance and behavior, the style class to use is
* {@link #STYLE_CLASS_SPLIT_BUTTON STYLE_CLASS_SPLIT_BUTTON}.
*
*
* colorPicker.getStyleClass().add("button");
*
* or
*
* colorPicker.getStyleClass().add("split-button");
*
* @since JavaFX 2.2
*/
public class ColorPicker extends ComboBoxBase {
/**
* The style class to specify a Button like appearance of ColorPicker control.
*/
public static final String STYLE_CLASS_BUTTON = "button";
/**
* The style class to specify a SplitMenuButton like appearance of ColorPicker control.
*/
public static final String STYLE_CLASS_SPLIT_BUTTON = "split-button";
/**
* The custom colors added to the Color Palette by the user.
*/
private ObservableList customColors = FXCollections.observableArrayList();
/**
* Gets the list of custom colors added to the Color Palette by the user.
*/
public final ObservableList getCustomColors() {
return customColors;
}
/**
* Creates a default ColorPicker instance with a selected color set to white.
*/
public ColorPicker() {
this(Color.WHITE);
}
/**
* Creates a ColorPicker instance and sets the selected color to the given color.
* @param color to be set as the currently selected color of the ColorPicker.
*/
public ColorPicker(Color color) {
setValue(color);
getStyleClass().add(DEFAULT_STYLE_CLASS);
}
@Override void valueInvalidated() {
// do nothing - we dont want to fire action event when value changes.
}
/***************************************************************************
* *
* Methods *
* *
**************************************************************************/
/** {@inheritDoc} */
@Override protected Skin createDefaultSkin() {
return new ColorPickerSkin(this);
}
/***************************************************************************
* *
* Stylesheet Handling *
* *
**************************************************************************/
private static final String DEFAULT_STYLE_CLASS = "color-picker";
}