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

org.controlsfx.control.CheckTreeView Maven / Gradle / Ivy

Go to download

High quality UI controls and other tools to complement the core JavaFX distribution

There is a newer version: 11.2.1
Show newest version
/**
 * Copyright (c) 2013, ControlsFX
 * 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 ControlsFX, any associated website, 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 CONTROLSFX 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 org.controlsfx.control;

import javafx.beans.property.BooleanProperty;
import javafx.beans.property.ObjectProperty;
import javafx.beans.property.SimpleObjectProperty;
import javafx.collections.ListChangeListener;
import javafx.event.EventHandler;
import javafx.scene.control.CheckBox;
import javafx.scene.control.CheckBoxTreeItem;
import javafx.scene.control.CheckBoxTreeItem.TreeModificationEvent;
import javafx.scene.control.MultipleSelectionModel;
import javafx.scene.control.TreeItem;
import javafx.scene.control.TreeView;
import javafx.scene.control.cell.CheckBoxTreeCell;

/**
 * A simple UI control that makes it possible to select zero or more items within
 * a TreeView without the need to set a custom cell factory or manually create
 * boolean properties for each row - simply use the 
 * {@link #checkModelProperty() check model} to request the current selection 
 * state.
 * 
 * 

Screenshot

*

The following screenshot shows the CheckTreeView with some sample data: * *
* * *

Code Example:

*

To create the CheckTreeView shown in the screenshot, simply do the * following: * *

 * {@code
 * // create the data to show in the CheckTreeView 
 * CheckBoxTreeItem root = new CheckBoxTreeItem("Root");
 * root.setExpanded(true);
 * root.getChildren().addAll(
 *               new CheckBoxTreeItem("Jonathan"),
 *               new CheckBoxTreeItem("Eugene"),
 *               new CheckBoxTreeItem("Henri"),
 *               new CheckBoxTreeItem("Samir"));
 * 
 * // Create the CheckTreeView with the data 
 * final CheckTreeView checkTreeView = new CheckTreeView<>(root);
 *       
 * // and listen to the relevant events (e.g. when the selected indices or 
 * // selected items change).
 * checkTreeView.getCheckModel().getSelectedItems().addListener(new ListChangeListener>() {
 *     public void onChanged(ListChangeListener.Change> c) {
 *         System.out.println(checkListView.getCheckModel().getSelectedIndices());
 *     }
 * });
 * }
* * @param The type of the data in the TreeView. */ public class CheckTreeView extends TreeView { /************************************************************************** * * Private fields * **************************************************************************/ /************************************************************************** * * Constructors * **************************************************************************/ /** * Creates a new CheckTreeView instance with an empty tree of choices. */ public CheckTreeView() { this(null); } /** * Creates a new CheckTreeView instance with the given CheckBoxTreeItem set * as the tree root. * * @param root The root tree item to display in the CheckTreeView. */ public CheckTreeView(final CheckBoxTreeItem root) { super(root); setCheckModel(new CheckTreeViewBitSetCheckModel(this)); setCellFactory(CheckBoxTreeCell.forTreeView()); } /************************************************************************** * * Public API * **************************************************************************/ /** * Returns the {@link BooleanProperty} for a given item index in the * CheckTreeView. This is useful if you want to bind to the property. */ public BooleanProperty getItemBooleanProperty(int index) { CheckBoxTreeItem treeItem = (CheckBoxTreeItem) getTreeItem(index); return treeItem.selectedProperty(); } /************************************************************************** * * Properties * **************************************************************************/ // --- Check Model private ObjectProperty>> checkModel = new SimpleObjectProperty<>(this, "checkModel"); /** * Sets the 'check model' to be used in the CheckTreeView - this is the * code that is responsible for representing the selected state of each * {@link CheckBox} - that is, whether each {@link CheckBox} is checked or * not (and not to be confused with the * selection model concept, which is used in the TreeView control to * represent the selection state of each row).. */ public final void setCheckModel(MultipleSelectionModel> value) { checkModelProperty().set(value); } /** * Returns the currently installed check model. */ public final MultipleSelectionModel> getCheckModel() { return checkModel == null ? null : checkModel.get(); } /** * The check model provides the API through which it is possible * to check single or multiple items within a CheckTreeView, as well as inspect * which items have been checked by the user. Note that it has a generic * type that must match the type of the CheckTreeView itself. */ public final ObjectProperty>> checkModelProperty() { return checkModel; } /************************************************************************** * * Implementation * **************************************************************************/ /************************************************************************** * * Support classes * **************************************************************************/ private static class CheckTreeViewBitSetCheckModel extends CheckBitSetModelBase> { /*********************************************************************** * * * Internal properties * * * **********************************************************************/ private final CheckTreeView treeView; private final TreeItem root; /*********************************************************************** * * * Constructors * * * **********************************************************************/ CheckTreeViewBitSetCheckModel(final CheckTreeView treeView) { super(null); this.treeView = treeView; this.root = treeView.getRoot(); this.root.addEventHandler(CheckBoxTreeItem.checkBoxSelectionChangedEvent(), new EventHandler>() { public void handle(TreeModificationEvent e) { CheckBoxTreeItem treeItem = e.getTreeItem(); final int index = getItemIndex(treeItem); if (treeItem.isSelected() && ! treeItem.isIndeterminate()) { select(index); } else { clearSelection(index); } } }); } /*********************************************************************** * * * Implementing abstract API * * * **********************************************************************/ @Override public TreeItem getItem(int index) { return treeView.getTreeItem(index); } @Override public int getItemCount() { return treeView.getExpandedItemCount(); } @Override public int getItemIndex(TreeItem item) { return treeView.getRow(item); } /*********************************************************************** * * * Overriding public API * * * **********************************************************************/ @Override protected void updateMap() { // no-op } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy