/* * Copyright (c) 1997, 2014, 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 javax.swing.table; import java.util.Enumeration; import javax.swing.event.ChangeEvent; import javax.swing.event.*; import javax.swing.*; /** * Defines the requirements for a table column model object suitable for * use with <code>JTable</code>. * * @author Alan Chung * @author Philip Milne * @see DefaultTableColumnModel */ public interface TableColumnModel { // // Modifying the model // /** * Appends <code>aColumn</code> to the end of the * <code>tableColumns</code> array. * This method posts a <code>columnAdded</code> * event to its listeners. * * @param aColumn the <code>TableColumn</code> to be added * @see #removeColumn */ public void addColumn(TableColumn aColumn); /** * Deletes the <code>TableColumn</code> <code>column</code> from the * <code>tableColumns</code> array. This method will do nothing if * <code>column</code> is not in the table's column list. * This method posts a <code>columnRemoved</code> * event to its listeners. * * @param column the <code>TableColumn</code> to be removed * @see #addColumn */ public void removeColumn(TableColumn column); /** * Moves the column and its header at <code>columnIndex</code> to * <code>newIndex</code>. The old column at <code>columnIndex</code> * will now be found at <code>newIndex</code>. The column that used * to be at <code>newIndex</code> is shifted left or right * to make room. This will not move any columns if * <code>columnIndex</code> equals <code>newIndex</code>. This method * posts a <code>columnMoved</code> event to its listeners. * * @param columnIndex the index of column to be moved * @param newIndex index of the column's new location * @exception IllegalArgumentException if <code>columnIndex</code> or * <code>newIndex</code> * are not in the valid range */ public void moveColumn(int columnIndex, int newIndex); /** * Sets the <code>TableColumn</code>'s column margin to * <code>newMargin</code>. This method posts * a <code>columnMarginChanged</code> event to its listeners. * * @param newMargin the width, in pixels, of the new column margins * @see #getColumnMargin */ public void setColumnMargin(int newMargin); // // Querying the model // /** * Returns the number of columns in the model. * @return the number of columns in the model */ public int getColumnCount(); /** * Returns an <code>Enumeration</code> of all the columns in the model. * @return an <code>Enumeration</code> of all the columns in the model */ public Enumeration<TableColumn> getColumns(); /** * Returns the index of the first column in the table * whose identifier is equal to <code>identifier</code>, * when compared using <code>equals</code>. * * @param columnIdentifier the identifier object * @return the index of the first table column * whose identifier is equal to <code>identifier</code> * @exception IllegalArgumentException if <code>identifier</code> * is <code>null</code>, or no * <code>TableColumn</code> has this * <code>identifier</code> * @see #getColumn */ public int getColumnIndex(Object columnIdentifier); /** * Returns the <code>TableColumn</code> object for the column at * <code>columnIndex</code>. * * @param columnIndex the index of the desired column * @return the <code>TableColumn</code> object for * the column at <code>columnIndex</code> */ public TableColumn getColumn(int columnIndex); /** * Returns the width between the cells in each column. * @return the margin, in pixels, between the cells */ public int getColumnMargin(); /** * Returns the index of the column that lies on the * horizontal point, <code>xPosition</code>; * or -1 if it lies outside the any of the column's bounds. * * In keeping with Swing's separable model architecture, a * TableColumnModel does not know how the table columns actually appear on * screen. The visual presentation of the columns is the responsibility * of the view/controller object using this model (typically JTable). The * view/controller need not display the columns sequentially from left to * right. For example, columns could be displayed from right to left to * accommodate a locale preference or some columns might be hidden at the * request of the user. Because the model does not know how the columns * are laid out on screen, the given <code>xPosition</code> should not be * considered to be a coordinate in 2D graphics space. Instead, it should * be considered to be a width from the start of the first column in the * model. If the column index for a given X coordinate in 2D space is * required, <code>JTable.columnAtPoint</code> can be used instead. * * @param xPosition width from the start of the first column in * the model. * * @return the index of the column; or -1 if no column is found * @see javax.swing.JTable#columnAtPoint */ public int getColumnIndexAtX(int xPosition); /** * Returns the total width of all the columns. * @return the total computed width of all columns */ public int getTotalColumnWidth(); // // Selection // /** * Sets whether the columns in this model may be selected. * @param flag true if columns may be selected; otherwise false * @see #getColumnSelectionAllowed */ public void setColumnSelectionAllowed(boolean flag); /** * Returns true if columns may be selected. * @return true if columns may be selected * @see #setColumnSelectionAllowed */ public boolean getColumnSelectionAllowed(); /** * Returns an array of indicies of all selected columns. * @return an array of integers containing the indicies of all * selected columns; or an empty array if nothing is selected */ public int[] getSelectedColumns(); /** * Returns the number of selected columns. * * @return the number of selected columns; or 0 if no columns are selected */ public int getSelectedColumnCount(); /** * Sets the selection model. * * @param newModel a <code>ListSelectionModel</code> object * @see #getSelectionModel */ public void setSelectionModel(ListSelectionModel newModel); /** * Returns the current selection model. * * @return a <code>ListSelectionModel</code> object * @see #setSelectionModel */ public ListSelectionModel getSelectionModel(); // // Listener // /** * Adds a listener for table column model events. * * @param x a <code>TableColumnModelListener</code> object */ public void addColumnModelListener(TableColumnModelListener x); /** * Removes a listener for table column model events. * * @param x a <code>TableColumnModelListener</code> object */ public void removeColumnModelListener(TableColumnModelListener x); }