- java.lang.Object
- 
- javafx.scene.control.SelectionModel<T>
- 
- javafx.scene.control.MultipleSelectionModel<T>
- 
- javafx.scene.control.TableSelectionModel<S>
- 
- javafx.scene.control.TableView.TableViewSelectionModel<S>
 
 
 
 
- 
 public abstract static class TableView.TableViewSelectionModel<S> extends TableSelectionModel<S> A simple extension of theSelectionModelabstract class to allow for special support for TableView controls.- Since:
- JavaFX 2.0
 
- 
- 
Property Summary- 
Properties inherited from class javafx.scene.control.TableSelectionModelcellSelectionEnabled
 - 
Properties inherited from class javafx.scene.control.MultipleSelectionModelselectionMode
 - 
Properties inherited from class javafx.scene.control.SelectionModelselectedIndex, selectedItem
 
- 
 - 
Constructor SummaryConstructors Constructor Description TableViewSelectionModel(TableView<S> tableView)Builds a default TableViewSelectionModel instance with the provided TableView.
 - 
Method SummaryModifier and Type Method Description voidclearAndSelect(int row)A method that clears any selection prior to setting the selection to the given index.abstract voidclearAndSelect(int row, TableColumn<S,?> column)Clears all selection, and then selects the cell at the given row/column intersection.voidclearAndSelect(int row, TableColumnBase<S,?> column)Clears all selection, and then selects the cell at the given row/column intersection.voidclearSelection()Clears the selection model of all selected indices.voidclearSelection(int index)This method will clear the selection of the item in the given index.abstract voidclearSelection(int row, TableColumn<S,?> column)Removes selection from the specified row/column position (in view indexes).voidclearSelection(int row, TableColumnBase<S,?> column)Removes selection from the specified row/column position (in view indexes).voidfocus(int row)intgetFocusedIndex()protected intgetItemCount()Returns the number of items in the data model that underpins the control.protected SgetModelItem(int index)Returns the item at the given index.abstract ObservableList<TablePosition>getSelectedCells()A read-only ObservableList representing the currently selected cells in this TableView.ObservableList<Integer>getSelectedIndices()Returns a read-only ObservableList of all selected indices.ObservableList<T>getSelectedItems()Returns a read-only ObservableList of all selected items.protected List<S>getTableModel()Convenience method that returns getTableView().getItems().TableView<S>getTableView()Returns the TableView instance that this selection model is installed in.booleanisEmpty()This method is available to test whether there are any selected indices/items.booleanisSelected(int index)Convenience method to inform if the given index is currently selected in this SelectionModel.abstract booleanisSelected(int row, TableColumn<S,?> column)Convenience function which tests whether the given row and column index is currently selected in this table instance.booleanisSelected(int row, TableColumnBase<S,?> column)Convenience function which tests whether the given row and column index is currently selected in this table instance.voidselect(int row)This will select the given index in the selection model, assuming the index is within the valid range (i.e.abstract voidselect(int row, TableColumn<S,?> column)Selects the cell at the given row/column intersection.voidselect(int row, TableColumnBase<S,?> column)Selects the cell at the given row/column intersection.voidselect(T obj)This method will attempt to select the index that contains the given object.voidselectAll()Convenience method to select all available indices.voidselectFirst()This method will attempt to select the first index in the control.voidselectIndices(int row, int... rows)This method allows for one or more selections to be set at the same time.voidselectLast()This method will attempt to select the last index in the control.voidselectNext()This method will attempt to select the index directly after the current focused index.voidselectPrevious()This method will attempt to select the index directly before the current focused index.voidselectRange(int minRow, TableColumnBase<S,?> minColumn, int maxRow, TableColumnBase<S,?> maxColumn)Selects the cells in the range (minRow, minColumn) to (maxRow, maxColumn), inclusive.- 
Methods inherited from class javafx.scene.control.TableSelectionModelcellSelectionEnabledProperty, isCellSelectionEnabled, selectAboveCell, selectBelowCell, selectLeftCell, selectRightCell, setCellSelectionEnabled
 - 
Methods inherited from class javafx.scene.control.MultipleSelectionModelgetSelectionMode, selectionModeProperty, selectRange, setSelectionMode
 - 
Methods inherited from class javafx.scene.control.SelectionModelgetSelectedIndex, getSelectedItem, selectedIndexProperty, selectedItemProperty, setSelectedIndex, setSelectedItem
 
- 
 
- 
- 
- 
Constructor Detail- 
TableViewSelectionModelpublic TableViewSelectionModel(TableView<S> tableView) Builds a default TableViewSelectionModel instance with the provided TableView.- Parameters:
- tableView- The TableView upon which this selection model should operate.
- Throws:
- NullPointerException- TableView can not be null.
 
 
- 
 - 
Method Detail- 
getSelectedCellspublic abstract ObservableList<TablePosition> getSelectedCells() A read-only ObservableList representing the currently selected cells in this TableView. Rather than directly modify this list, please use the other methods provided in the TableViewSelectionModel.- Returns:
- a read-only ObservableList representing the currently selected cells in this TableView
 
 - 
isSelectedpublic boolean isSelected(int row, TableColumnBase<S,?> column)Convenience function which tests whether the given row and column index is currently selected in this table instance. If the table control is in its 'cell selection' mode (where individual cells can be selected, rather than entire rows), and if the column argument is null, this method should return true only if all cells in the given row are selected.- Specified by:
- isSelectedin class- TableSelectionModel<S>
- Parameters:
- row- the row
- column- the column
- Returns:
- true if the given row and column index is currently selected in this table instance
 
 - 
isSelectedpublic abstract boolean isSelected(int row, TableColumn<S,?> column)Convenience function which tests whether the given row and column index is currently selected in this table instance.- Parameters:
- row- the row
- column- the column
- Returns:
- true if row and column index is currently selected
 
 - 
selectpublic void select(int row, TableColumnBase<S,?> column)Selects the cell at the given row/column intersection. If the table control is in its 'cell selection' mode (where individual cells can be selected, rather than entire rows), and if the column argument is null, this method should select all cells in the given row.- Specified by:
- selectin class- TableSelectionModel<S>
- Parameters:
- row- the row
- column- the column
 
 - 
selectpublic abstract void select(int row, TableColumn<S,?> column)Selects the cell at the given row/column intersection.- Parameters:
- row- the row
- column- the column
 
 - 
clearAndSelectpublic void clearAndSelect(int row, TableColumnBase<S,?> column)Clears all selection, and then selects the cell at the given row/column intersection. If the table control is in its 'cell selection' mode (where individual cells can be selected, rather than entire rows), and if the column argument is null, this method should select all cells in the given row.- Specified by:
- clearAndSelectin class- TableSelectionModel<S>
- Parameters:
- row- the row
- column- the column
 
 - 
clearAndSelectpublic abstract void clearAndSelect(int row, TableColumn<S,?> column)Clears all selection, and then selects the cell at the given row/column intersection.- Parameters:
- row- the row
- column- the column
 
 - 
clearSelectionpublic void clearSelection(int row, TableColumnBase<S,?> column)Removes selection from the specified row/column position (in view indexes). If this particular cell (or row if the column value is -1) is not selected, nothing happens. If the table control is in its 'cell selection' mode (where individual cells can be selected, rather than entire rows), and if the column argument is null, this method should deselect all cells in the given row.- Specified by:
- clearSelectionin class- TableSelectionModel<S>
- Parameters:
- row- the row
- column- the column
 
 - 
clearSelectionpublic abstract void clearSelection(int row, TableColumn<S,?> column)Removes selection from the specified row/column position (in view indexes). If this particular cell (or row if the column value is -1) is not selected, nothing happens.- Parameters:
- row- the row
- column- the column
 
 - 
selectRangepublic void selectRange(int minRow, TableColumnBase<S,?> minColumn, int maxRow, TableColumnBase<S,?> maxColumn)Selects the cells in the range (minRow, minColumn) to (maxRow, maxColumn), inclusive.- Specified by:
- selectRangein class- TableSelectionModel<S>
- Parameters:
- minRow- the minRow
- minColumn- the minColumn
- maxRow- the maxRow
- maxColumn- the maxColumn
 
 - 
getTableViewpublic TableView<S> getTableView() Returns the TableView instance that this selection model is installed in.- Returns:
- the TableView
 
 - 
getTableModelprotected List<S> getTableModel() Convenience method that returns getTableView().getItems().- Returns:
- The items list of the current TableView.
 
 - 
getModelItemprotected S getModelItem(int index) Returns the item at the given index. An example using ListView would belistView.getItems().get(index).- Parameters:
- index- The index of the item that is requested from the underlying data model.
- Returns:
- Returns null if the index is out of bounds, or an element of type T that is related to the given index.
 
 - 
getItemCountprotected int getItemCount() Returns the number of items in the data model that underpins the control. An example would be that a ListView selection model would likely returnlistView.getItems().size(). The valid range of selectable indices is between 0 and whatever is returned by this method.- Returns:
- the number of items in the data model that underpins the control
 
 - 
focuspublic void focus(int row) 
 - 
getFocusedIndexpublic int getFocusedIndex() 
 - 
getSelectedIndicespublic ObservableList<Integer> getSelectedIndices() Description copied from class:MultipleSelectionModelReturns a read-only ObservableList of all selected indices. The ObservableList will be updated by the selection model to always reflect changes in selection. This can be observed by adding a ListChangeListenerto the returned ObservableList.- Specified by:
- getSelectedIndicesin class- MultipleSelectionModel<T>
- Returns:
- the list of selected indices
 
 - 
getSelectedItemspublic ObservableList<T> getSelectedItems() Description copied from class:MultipleSelectionModelReturns a read-only ObservableList of all selected items. The ObservableList will be updated further by the selection model to always reflect changes in selection. This can be observed by adding a ListChangeListenerto the returned ObservableList.- Specified by:
- getSelectedItemsin class- MultipleSelectionModel<T>
- Returns:
- the list of selected items
 
 - 
clearAndSelectpublic void clearAndSelect(int row) Description copied from class:SelectionModelA method that clears any selection prior to setting the selection to the given index. The purpose of this method is to avoid having to callSelectionModel.clearSelection()first, meaning that observers that are listening to theselected indexproperty will not see the selected index being temporarily set to -1.- Specified by:
- clearAndSelectin class- SelectionModel<T>
- Parameters:
- row- The index that should be the only selected index in this selection model.
 
 - 
selectpublic void select(int row) Description copied from class:SelectionModelThis will select the given index in the selection model, assuming the index is within the valid range (i.e. greater than or equal to zero, and less than the total number of items in the underlying data model). If there is already one or more indices selected in this model, calling this method will not clear these selections - to do so it is necessary to first call SelectionModel.clearSelection().If the index is already selected, it will not be selected again, or unselected. However, if multiple selection is implemented, then calling select on an already selected index will have the effect of making the index the new selected index (as returned by SelectionModel.getSelectedIndex().- Specified by:
- selectin class- SelectionModel<T>
- Parameters:
- row- The position of the item to select in the selection model.
 
 - 
selectpublic void select(T obj) Description copied from class:SelectionModelThis method will attempt to select the index that contains the given object. It will iterate through the underlying data model until it finds an item whose value is equal to the given object. At this point it will stop iterating - this means that this method will not select multiple indices. - Specified by:
- selectin class- SelectionModel<T>
- Parameters:
- obj- The object to attempt to select in the underlying data model.
 
 - 
selectIndicespublic void selectIndices(int row, int... rows)Description copied from class:MultipleSelectionModelThis method allows for one or more selections to be set at the same time. It will ignore any value that is not within the valid range (i.e. greater than or equal to zero, and less than the total number of items in the underlying data model). Any duplication of indices will be ignored. If there is already one or more indices selected in this model, calling this method will not clear these selections - to do so it is necessary to first call clearSelection. The last valid value given will become the selected index / selected item. - Specified by:
- selectIndicesin class- MultipleSelectionModel<T>
- Parameters:
- row- the first index to select
- rows- zero or more additional indices to select
 
 - 
selectAllpublic void selectAll() Description copied from class:MultipleSelectionModelConvenience method to select all available indices. - Specified by:
- selectAllin class- MultipleSelectionModel<T>
 
 - 
selectFirstpublic void selectFirst() Description copied from class:MultipleSelectionModelThis method will attempt to select the first index in the control. If clearSelection is not called first, this method will have the result of selecting the first index, whilst retaining the selection of any other currently selected indices. If the first index is already selected, calling this method will have no result, and no selection event will take place. - Specified by:
- selectFirstin class- MultipleSelectionModel<T>
 
 - 
selectLastpublic void selectLast() Description copied from class:MultipleSelectionModelThis method will attempt to select the last index in the control. If clearSelection is not called first, this method will have the result of selecting the last index, whilst retaining the selection of any other currently selected indices. If the last index is already selected, calling this method will have no result, and no selection event will take place. - Specified by:
- selectLastin class- MultipleSelectionModel<T>
 
 - 
clearSelectionpublic void clearSelection(int index) Description copied from class:SelectionModelThis method will clear the selection of the item in the given index. If the given index is not selected, nothing will happen. - Specified by:
- clearSelectionin class- SelectionModel<T>
- Parameters:
- index- The selected item to deselect.
 
 - 
clearSelectionpublic void clearSelection() Description copied from class:SelectionModelClears the selection model of all selected indices. - Specified by:
- clearSelectionin class- SelectionModel<T>
 
 - 
isSelectedpublic boolean isSelected(int index) Description copied from class:SelectionModelConvenience method to inform if the given index is currently selected in this SelectionModel. Is functionally equivalent to calling getSelectedIndices().contains(index).- Specified by:
- isSelectedin class- SelectionModel<T>
- Parameters:
- index- The index to check as to whether it is currently selected or not.
- Returns:
- True if the given index is selected, false otherwise.
 
 - 
isEmptypublic boolean isEmpty() Description copied from class:SelectionModelThis method is available to test whether there are any selected indices/items. It will return true if there are no selected items, and false if there are.- Specified by:
- isEmptyin class- SelectionModel<T>
- Returns:
- Will return true if there are no selected items, and false if there are.
 
 - 
selectPreviouspublic void selectPrevious() Description copied from class:SelectionModelThis method will attempt to select the index directly before the current focused index. If clearSelection is not called first, this method will have the result of selecting the previous index, whilst retaining the selection of any other currently selected indices. Calling this method will only succeed if: - There is currently a lead/focused index.
- The lead/focus index is not the first index in the control.
- The previous index is not already selected.
 If any of these conditions is false, no selection event will take place. - Specified by:
- selectPreviousin class- SelectionModel<T>
 
 - 
selectNextpublic void selectNext() Description copied from class:SelectionModelThis method will attempt to select the index directly after the current focused index. If clearSelection is not called first, this method will have the result of selecting the next index, whilst retaining the selection of any other currently selected indices. Calling this method will only succeed if: - There is currently a lead/focused index.
- The lead/focus index is not the last index in the control.
- The next index is not already selected.
 If any of these conditions is false, no selection event will take place. - Specified by:
- selectNextin class- SelectionModel<T>
 
 
- 
 
-