001 /* =========================================================== 002 * JFreeChart : a free chart library for the Java(tm) platform 003 * =========================================================== 004 * 005 * (C) Copyright 2000-2008, by Object Refinery Limited and Contributors. 006 * 007 * Project Info: http://www.jfree.org/jfreechart/index.html 008 * 009 * This library is free software; you can redistribute it and/or modify it 010 * under the terms of the GNU Lesser General Public License as published by 011 * the Free Software Foundation; either version 2.1 of the License, or 012 * (at your option) any later version. 013 * 014 * This library is distributed in the hope that it will be useful, but 015 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 016 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public 017 * License for more details. 018 * 019 * You should have received a copy of the GNU Lesser General Public 020 * License along with this library; if not, write to the Free Software 021 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, 022 * USA. 023 * 024 * [Java is a trademark or registered trademark of Sun Microsystems, Inc. 025 * in the United States and other countries.] 026 * 027 * ------------------------ 028 * XYDatasetTableModel.java 029 * ------------------------ 030 * (C)opyright 2003-2008, by Bryan Scott and Contributors. 031 * 032 * Original Author: Bryan Scott ; 033 * Contributor(s): David Gilbert (for Object Refinery Limited); 034 * 035 * Changes 036 * ------- 037 * 01-Jul-2003 : Version 1 contributed by Bryan Scott (DG); 038 * 27-Apr-2005 : Change XYDataset --> TableXYDataset because the table model 039 * assumes all series share the same x-values, and this is not 040 * enforced by XYDataset. Also fixed bug 1191046, a problem 041 * in the getValueAt() method (DG); 042 * 043 */ 044 045 package org.jfree.data.xy; 046 047 import javax.swing.table.AbstractTableModel; 048 import javax.swing.table.TableModel; 049 050 import org.jfree.data.general.DatasetChangeEvent; 051 import org.jfree.data.general.DatasetChangeListener; 052 053 /** 054 * A READ-ONLY wrapper around a {@link TableXYDataset} to convert it to a 055 * table model for use in a JTable. The first column of the table shows the 056 * x-values, the remaining columns show the y-values for each series (series 0 057 * appears in column 1, series 1 appears in column 2, etc). 058 * <P> 059 * TO DO: 060 * <ul> 061 * <li>implement proper naming for x axis (getColumnName)</li> 062 * <li>implement setValueAt to remove READ-ONLY constraint (not sure how)</li> 063 * </ul> 064 */ 065 public class XYDatasetTableModel extends AbstractTableModel 066 implements TableModel, DatasetChangeListener { 067 068 /** The dataset. */ 069 TableXYDataset model = null; 070 071 /** 072 * Default constructor. 073 */ 074 public XYDatasetTableModel() { 075 super(); 076 } 077 078 /** 079 * Creates a new table model based on the specified dataset. 080 * 081 * @param dataset the dataset. 082 */ 083 public XYDatasetTableModel(TableXYDataset dataset) { 084 this(); 085 this.model = dataset; 086 this.model.addChangeListener(this); 087 } 088 089 /** 090 * Sets the model (dataset). 091 * 092 * @param dataset the dataset. 093 */ 094 public void setModel(TableXYDataset dataset) { 095 this.model = dataset; 096 this.model.addChangeListener(this); 097 fireTableDataChanged(); 098 } 099 100 /** 101 * Returns the number of rows. 102 * 103 * @return The row count. 104 */ 105 public int getRowCount() { 106 if (this.model == null) { 107 return 0; 108 } 109 return this.model.getItemCount(); 110 } 111 112 /** 113 * Gets the number of columns in the model. 114 * 115 * @return The number of columns in the model. 116 */ 117 public int getColumnCount() { 118 if (this.model == null) { 119 return 0; 120 } 121 return this.model.getSeriesCount() + 1; 122 } 123 124 /** 125 * Returns the column name. 126 * 127 * @param column the column index. 128 * 129 * @return The column name. 130 */ 131 public String getColumnName(int column) { 132 if (this.model == null) { 133 return super.getColumnName(column); 134 } 135 if (column < 1) { 136 return "X Value"; 137 } 138 else { 139 return this.model.getSeriesKey(column - 1).toString(); 140 } 141 } 142 143 /** 144 * Returns a value of the specified cell. 145 * Column 0 is the X axis, Columns 1 and over are the Y axis 146 * 147 * @param row the row number. 148 * @param column the column number. 149 * 150 * @return The value of the specified cell. 151 */ 152 public Object getValueAt(int row, int column) { 153 if (this.model == null) { 154 return null; 155 } 156 if (column < 1) { 157 return this.model.getX(0, row); 158 } 159 else { 160 return this.model.getY(column - 1, row); 161 } 162 } 163 164 /** 165 * Receives notification that the underlying dataset has changed. 166 * 167 * @param event the event 168 * 169 * @see DatasetChangeListener 170 */ 171 public void datasetChanged(DatasetChangeEvent event) { 172 fireTableDataChanged(); 173 } 174 175 /** 176 * Returns a flag indicating whether or not the specified cell is editable. 177 * 178 * @param row the row number. 179 * @param column the column number. 180 * 181 * @return <code>true</code> if the specified cell is editable. 182 */ 183 public boolean isCellEditable(int row, int column) { 184 return false; 185 } 186 187 /** 188 * Updates the {@link XYDataset} if allowed. 189 * 190 * @param value the new value. 191 * @param row the row. 192 * @param column the column. 193 */ 194 public void setValueAt(Object value, int row, int column) { 195 if (isCellEditable(row, column)) { 196 // XYDataset only provides methods for reading a dataset... 197 } 198 } 199 200 // /** 201 // * Run a demonstration of the table model interface. 202 // * 203 // * @param args ignored. 204 // * 205 // * @throws Exception when an error occurs. 206 // */ 207 // public static void main(String args[]) throws Exception { 208 // JFrame frame = new JFrame(); 209 // JPanel panel = new JPanel(); 210 // panel.setLayout(new BorderLayout()); 211 // 212 // XYSeries s1 = new XYSeries("Series 1", true, false); 213 // for (int i = 0; i < 10; i++) { 214 // s1.add(i, Math.random()); 215 // } 216 // XYSeries s2 = new XYSeries("Series 2", true, false); 217 // for (int i = 0; i < 15; i++) { 218 // s2.add(i, Math.random()); 219 // } 220 // DefaultTableXYDataset dataset = new DefaultTableXYDataset(); 221 // dataset.addSeries(s1); 222 // dataset.addSeries(s2); 223 // XYDatasetTableModel tablemodel = new XYDatasetTableModel(); 224 // 225 // tablemodel.setModel(dataset); 226 // 227 // JTable dataTable = new JTable(tablemodel); 228 // JScrollPane scroll = new JScrollPane(dataTable); 229 // scroll.setPreferredSize(new Dimension(600, 150)); 230 // 231 // JFreeChart chart = ChartFactory.createXYLineChart( 232 // "XY Series Demo", 233 // "X", "Y", dataset, PlotOrientation.VERTICAL, 234 // true, 235 // true, 236 // false 237 // ); 238 // 239 // ChartPanel chartPanel = new ChartPanel(chart); 240 // 241 // panel.add(chartPanel, BorderLayout.CENTER); 242 // panel.add(scroll, BorderLayout.SOUTH); 243 // 244 // frame.setContentPane(panel); 245 // frame.setSize(600, 500); 246 // frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 247 // frame.show(); 248 // RefineryUtilities.centerFrameOnScreen(frame); 249 // } 250 251 }