导航:首页 > 编程语言 > javajtabel竖

javajtabel竖

发布时间:2024-02-02 19:42:38

java SWING 表头不显示问题

说明:jscrollPane 也是组件, 你需要把滚动面板也添加到你的布局里.

由于你的布局是绝对布局setLayout(null); 那么你还需要为JScrollPane 设置大小和位置

效果图

importjavax.swing.*;

{

publicFrameDemo(){
JTabletable=newJTable(newString[][]{{"值A1","值A2"}},newString[]{"列1","列2"});
//table.setBounds(10,10,200,200);//不要为JTabel指定位置和大小
//add(table);//不要把JTabel加入到窗口上
JScrollPanejsp=newJScrollPane(table);//把Jtable加入到滚动面板上
jsp.setBounds(10,10,200,200);//指定滚动面板的位置和大小
add(jsp);//窗口添加上滚动面板

setLayout(null);//绝对布局
setResizable(false);//窗口不许缩放
setSize(320,320);//窗口大小
setLocationRelativeTo(null);//窗口居中
setDefaultCloseOperation(EXIT_ON_CLOSE);//退出程序就关闭
}

publicstaticvoidmain(String[]args){
newFrameDemo().setVisible(true);
}
}

② java中选择框的使用方法

java.awt
类 List
java.lang.Object
java.awt.Component
java.awt.List
所有已实现的接口:
ImageObserver, ItemSelectable, MenuContainer, Serializable, Accessible

--------------------------------------------------------------------------------

public class Listextends Componentimplements ItemSelectable, AccessibleList 组件为用户提供了一个可滚动的文本项列表。可设置此 list,使其允许用户进行单项或多项选择。

例如以下代码

--------------------------------------------------------------------------------

List lst = new List(4, false);
lst.add("Mercury");
lst.add("Venus");
lst.add("Earth");
lst.add("JavaSoft");
lst.add("Mars");
lst.add("Jupiter");
lst.add("Saturn");
lst.add("Uranus");
lst.add("Neptune");
lst.add("Pluto");
cnt.add(lst);

--------------------------------------------------------------------------------

当 cnt 为容器时,将生成以下滚动列表:

如果 List 允许进行多项选择,则单击已选中的项时,将取消选中该项。在上面的示例中,一次只能从滚动列表中选择一项,因为创建新的滚动列表时,第二个参数为 false。如果 List 不允许进行多项选择,则选择某一项会导致其他选中的项取消选中。

注意,本示例中显示的列表是用四个可视行创建的。创建该列表之后,不可更改可视行的数量。默认的 List 是用四行创建的,所以 lst = new List() 与 list = new List(4, false) 等效。

从 Java 1.1 开始,AWT(Abstract Window Toolkit,抽象窗口工具包)会把列表上发生的所有鼠标、键盘和焦点事件发送给 List 对象。(维护旧的 AWT 事件模型的目的是为了向后兼容,不推荐使用它。)

当用户选中或取消选中某项时,AWT 将向列表发送一个 ItemEvent 实例。当用户双击滚动列表中的某一项时,AWT 会在紧随项事件后向列表发送一个 ActionEvent 实例。当用户选中列表中的某项,按下 return 键时,AWT 也会生成一个动作事件。

如果应用程序需要基于此列表中用户选中或激活的项执行某个动作,则应该相应地实现 ItemListener 或 ActionListener,并注册新的侦听器,以便在此列表中接收事件。

对于多项选择滚动列表,使用外部动作(如单击按钮)来触发动作被认为是一种更好的用户界面。

从以下版本开始:
JDK1.0
另请参见:
ItemEvent, ItemListener, ActionEvent, ActionListener, 序列化表格

--------------------------------------------------------------------------------

嵌套类摘要
protected class List.AccessibleAWTList
此类实现 List 类的可访问性支持。
从类 java.awt.Component 继承的嵌套类/接口
Component.AccessibleAWTComponent, Component.BaselineResizeBehavior, Component.BltBufferStrategy, Component.FlipBufferStrategy
字段摘要
从类 java.awt.Component 继承的字段
BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT
从接口 java.awt.image.ImageObserver 继承的字段
ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH
构造方法摘要
List()
创建新的滚动列表。
List(int rows)
创建一个用指定可视行数初始化的新滚动列表。
List(int rows, boolean multipleMode)
创建一个初始化为显示指定行数的新滚动列表。
方法摘要
void add(String item)
向滚动列表的末尾添加指定的项。
void add(String item, int index)
向滚动列表中索引指示的位置添加指定的项。
void addActionListener(ActionListener l)
添加指定的动作侦听器以从此列表接收动作事件。
void addItem(String item)
已过时。 由 add(String) 取代。
void addItem(String item, int index)
已过时。 由 add(String, int) 取代。
void addItemListener(ItemListener l)
添加指定的项侦听器以接收此列表的项事件。
void addNotify()
创建列表的同位体。
boolean allowsMultipleSelections()
已过时。 从 JDK version 1.1 开始,由 isMultipleMode() 取代。
void clear()
已过时。 从 JDK version 1.1 开始,由 removeAll() 取代。
int countItems()
已过时。 从 JDK version 1.1 开始,由 getItemCount() 取代。
void delItem(int position)
已过时。 由 remove(String) 和 remove(int) 取代。
void delItems(int start, int end)
已过时。 从 JDK version 1.1 开始,后来不再公开使用。只希望作为包私有方法时保留此方法。
void deselect(int index)
取消选择指定索引处的项。
AccessibleContext getAccessibleContext()
获取与此 List 关联的 AccessibleContext。
ActionListener[] getActionListeners()
返回已在此列表上注册的所有动作侦听器的数组。
String getItem(int index)
获取与指定索引关联的项。
int getItemCount()
获取列表中的项数。
ItemListener[] getItemListeners()
返回已在此列表上注册的所有项侦听器的数组。
String[] getItems()
获取列表中的项。
<T extends EventListener>
T[]
getListeners(Class<T> listenerType)
返回目前已在此 List 上注册为 FooListener 的所有对象的数组。
Dimension getMinimumSize()
确定此滚动列表的最小大小。
Dimension getMinimumSize(int rows)
获取具有指定行数的列表的最少维数。
Dimension getPreferredSize()
获取此滚动列表的首选大小。
Dimension getPreferredSize(int rows)
获取具有指定行数的列表的首选维数。
int getRows()
获取此列表中的可视行数。
int getSelectedIndex()
获取列表中选中项的索引。
int[] getSelectedIndexes()
获取列表中选中的索引。
String getSelectedItem()
获取此滚动列表中选中的项。
String[] getSelectedItems()
获取此滚动列表中选中的项。
Object[] getSelectedObjects()
获取对象数组中此滚动列表的选中项。
int getVisibleIndex()
获取上次由 makeVisible 方法使其可视的项的索引。
boolean isIndexSelected(int index)
确定是否已选中此滚动列表中的指定项。
boolean isMultipleMode()
确定此列表是否允许进行多项选择。
boolean isSelected(int index)
已过时。 从 JDK version 1.1 开始,由 isIndexSelected(int) 取代。
void makeVisible(int index)
使指定索引处的项可视。
Dimension minimumSize()
已过时。 从 JDK version 1.1 开始,由 getMinimumSize() 取代。
Dimension minimumSize(int rows)
已过时。 从 JDK version 1.1 开始,由 getMinimumSize(int) 取代。
protected String paramString()
返回表示此滚动列表状态的参数字符串。
Dimension preferredSize()
已过时。 从 JDK version 1.1 开始,由 getPreferredSize() 取代。
Dimension preferredSize(int rows)
已过时。 从 JDK version 1.1 开始,由 getPreferredSize(int) 取代。
protected void processActionEvent(ActionEvent e)
处理发生在此列表上的动作事件,方法是将这些事件指派给所有已注册的 ActionListener 对象。
protected void processEvent(AWTEvent e)
此滚动列表的进程事件。
protected void processItemEvent(ItemEvent e)
处理发生在此列表上的项事件,方法是将这些事件指派给所有已注册的 ItemListener 对象。
void remove(int position)
从此滚动列表中移除指定位置处的项。
void remove(String item)
从列表中移除项的第一次出现。
void removeActionListener(ActionListener l)
移除指定的动作侦听器,以便不再从此列表接收动作事件。
void removeAll()
从此列表中移除所有项。
void removeItemListener(ItemListener l)
移除指定的项侦听器,以便不再从此列表接收项事件。
void removeNotify()
移除此列表的同位体。
void replaceItem(String newValue, int index)
使用新字符串替换滚动列表中指定索引处的项。
void select(int index)
选择滚动列表中指定索引处的项。
void setMultipleMode(boolean b)
设置确定此列表是否允许进行多项选择的标志。
void setMultipleSelections(boolean b)
已过时。 从 JDK version 1.1 开始,由 setMultipleMode(boolean) 取代。

③ java程序,将Excel表显示到Swing表格中

table = new JTable(dtModel);
table.setBounds(29, 24, 484, 216);
contentPane.add(table);

String path = textField.getText();
Read read=new Read();
read.openExcel(path);

String[][] data = new String[read.getRowCount(0)][read.getColCount(0)];
for (int i = 0; i <read.getRowCount(0); i++) {
for (int j = 0; j < read.getColCount(0); j++) {
data[i][j] = read.getCellContent(j, i);
}
}
String[] names = new String[] { "1", "2", "3" };
dtModel = new DefaultTableModel(data, names);

textField.getText();是你读取Excel文件的根目录版。权

④ JAVA点击Jtable表格如何将点击的那一行数据分别输出出来

importjava.awt.*;
importjava.awt.event.*;
importjavax.swing.*;
importjavax.swing.event.*;

{
String[]names={"姓名","等级"};
String[][]data={{"张三","A"},{"李四","B"},{"王五","C"}};

publicTableDemo(){
JTabletable=newJTable(data,names);
JScrollPanejsp=newJScrollPane(table);
add(jsp);
setSize(300,200);
setLocationRelativeTo(null);
setDefaultCloseOperation(EXIT_ON_CLOSE);

//推荐
table.getSelectionModel().addListSelectionListener(newListSelectionListener(){
@Override
publicvoidvalueChanged(ListSelectionEvente){
if(!e.getValueIsAdjusting()){
//支持拖动多选
int[]rows=table.getSelectedRows();
//int[]cols=table.getSelectedColumns();//选中的列
for(inti:rows){
System.out.println("#方法一: "+table.getValueAt(i,0)+" "+table.getValueAt(i,1));
}

//支持单选
// introw=table.getSelectedRow();//选中行
// //intcol=table.getSelectedColumn();//选中列
// System.out.println("方法一:"+table.getValueAt(row,0)+" "+table.getValueAt(row,1));
}
}
});

table.addMouseListener(newMouseAdapter(){
@Override
publicvoidmouseClicked(MouseEvente){
//单选
introw=table.rowAtPoint(e.getPoint());//选中行
//intcol=table.columnAtPoint(e.getPoint());//选中列
System.out.println("*方法二: "+table.getValueAt(row,0)+" "+table.getValueAt(row,1));
}
});
}

publicstaticvoidmain(String[]args){
EventQueue.invokeLater(newRunnable(){
publicvoidrun(){
newTableDemo().setVisible(true);
}
});
}
}

⑤ 如何用java应用程序创建表格

多少有点麻烦
建意不要用java来实现

JTable 组件:

类层次结构图:
java.lang.Object
--java.awt.Component
--java.awt.Container
--javax.swing.JComponent
--javax.swing.JTabel
在使用 JTable 以前,我们先看一下它的构造函数有哪些, 以及应该如何使用:

JTabel 构造函数:
JTable():建立一个新的 JTables,并使用系统默认的 Model.
JTable(int numRows,int numColumns):建立一个具有 numRows 行,numColumns 列的空表格,
使用的是 DefaultTableModel.
JTable(Object[ ][ ] rowData,Object[ ][ ] columnNames):建立一个显示二维数组数据的表格,且可
以显示列的名称。
JTable(TableModeldm):建立一个 JTable,有默认的字段模式以及选择模式,并设置数据模式。
JTable(TableModeldm,TableColumnModel cm):建立一个 JTable,设置数据模式与字段模式,并
有默认的选择模式。
JTable(TableModel dm,TableColumnModel cm,ListSelectionModel sm):建立一个 JTable,设置数
据模式、字段模式、与选择模式。
JTable(Vector rowData,Vector columnNames):建立一个以 Vector 为输入来源的数据表格,可显
示行的名称。

我们先以 Array 构造方式,说明如何利用 JTable 来建立一个简单的表格:
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
import java.util.*;
public class SimpleTable{

public SimpleTable(){
JFrame f=new JFrame();
Object[ ][ ] playerInfo={
{" 阿 呆 ",new Integer(66),new Integer(32),new Integer(98),new
Boolean(false)},
{"阿呆",new Integer(82),new Integer(69),new Integer(128),new
Boolean(true)},
};
String[ ] Names={"姓名","语文","数学","总分","及格"};
JTable table=new JTable(playerInfo,Names);
table.(new Dimension(550,30));
JScrollPane scrollPane=new JScrollPane(table);
f.getContentPane().add(scrollPane,BorderLayout.CENTER);
f.setTitle("SimpleTable");
f.pack();
f.show();
f.addWindowListener(newWindowAdapter() {
public void windowClosing(WindowEvent e) {
System.exit(0);
}
});
}
public static void main(String[] args){
SimpleTable b=new SimpleTable();
}
}
表格由两部份组成:分别是行标题(Column Header)与行对象(Column Object).利用 JTable
所提供的 getTableHeader()方法取得行标题。在这个例子中,我们将 JTable 放在 JScrollPane
中,这种做法可以将 Column Header 与 Colmn Object 完整的显示出来,因为 JScrollPane 会自
动 取 得 Column Header. 但 如 果 文 坛 读 者 将 上 面 第 15 行 去 掉 并 修 改 第 16 行 :
f.getContentPane().add(table,BorderLayout.CENTER);
则运行结果你会发现 Column Header 不见了。
如果你不想用 JScrollPane,要解决这个问题,你必须将程序修改如下:
JTable table=new JTable(p,n);
table.(new Dimension(550,30));
f.getContentPane().add(table.getTableHeader(),BorderLayout.NORTH);
f.getContentPane().add(table,BorderLayout.CENTER);
运行结果就会跟之前一样有行标题了.
上面的运行结果就会跟发现,每个字段的宽度都是一样的,除非你自行拉曳某个列宽。若
我们想一开始就设置列宽的值,可以利
用 TableColumn 类所提供的 setPreferredWidth()方法来设置,并可利用 JTable 类所提供的
setAutoResizeMode()方法来设置调整某个
列宽时其他列宽的变化情况,我们看下面这个例子:

import javax.swing.*;
import javax.swing.table.*;
import java.awt.*;
import java.awt.event.*;
import java.util.*;
public class SimpleTable2{
public SimpleTable2(){
JFrame f=new JFrame();
Object[][] p={
{" 阿 呆 ",new Integer(66),new Integer(32),new Integer(98),new
Boolean(false),new Boolean(false)},
{" 阿 呆 ",new Integer(82),new Integer(69),new Integer(128),new
Boolean(true),new Boolean(false)},
};
String[] n={"姓名","语文","数学","总分","及格","作弊"};
TableColumn column=null;
JTable table=new JTable(p,n);
table.(new Dimension(550,30));
table.setAutoResizeMode(JTable.AUTO_RESIZE_SUBSEQUENT_COLUMNS);
for (int i=0;i<6;i++){
//利用 JTable 中的 getColumnModel()方法取得 TableColumnModel 对象;再利用
TableColumnModel 界面所定义的 getColumn()方法取
//TableColumn 对象,利用此对象的 setPreferredWidth()方法就可以控制字段的宽度.
column=table.getColumnModel().getColumn(i);
if ((i%2)==0)
column.setPreferredWidth(150);
else
column.setPreferredWidth(50);
}
JScrollPane scrollPane=new JScrollPane(table);
f.getContentPane().add(scrollPane,BorderLayout.CENTER);
f.setTitle("SimpleTable");
f.pack();
f.show();
f.setVisible(true);
f.addWindowListener(newWindowAdapter() {
public void windowClosing(WindowEvent e) {
System.exit(0);
}
});
}
public static void main(String[] args){
new SimpleTable2();
}

}
列可调整的 5 个参数:
AUTO_RESIZE_SUBSEQUENT_COLUMENS:当调整某一列宽时,此字段之后的所有字段列
宽都会跟着一起变动。此为系统默认值。
AUTO_RESIZE_ALL_COLUMNS:当调整某一列宽时,此表格上所有字段的列宽都会跟着一
起变动。
AUTO_RESIZE_OFF:当调整某一列宽时,此表格上所有字段列宽都不会跟着改变。
AUTO_RESIZE_NEXT_COLUMN:当调整某一列宽时,此字段的下一个字段的列宽会跟着改
变,其余均不会变。
AUTO_RESIZE_LAST_COLUMN:当调整某一列宽时,最后一个字段的列宽会跟着改变,其
余均不会改变。

由以上范例可知,利用 Swing 来构造一个表格其实很简单的,只要你利用 Vector 或 Array
来作为我们表格的数据输入,将 Vector 或 Array 的
内容填入 JTable 中,一个基本的表格就产生了。不过,虽然利用 JTable(Object[][]
rowData,Object[][] columnNames)以及
JTable(Vector rowData,Vector columnNames)构造函数来构造构造 JTable 很方便,但却有些缺
点。例如上例中,我们表格中的每个字段
(cell)一开始都是默认为可修改的,用户因此可能修改到我们的数据;其次,表格中每个单元
(cell)中的数据类型将会被视为同一种。在我
们的例子中,数据类型皆被显示为 String 的类型,因此,原来的数据类型声明为 Boolean 的
数据会以 String 的形式出现而不是以检查框(
Check Box)出现。
除此之外,如果我们所要显示的数据是不固定的,或是随情况而变,例如同样是一份成绩
单,老师与学生所看到的表格就不会一样,显
示的外观或操作模式也许也不相同。为了因应这些种种复杂情况,上面简单的构造方式已不
宜使用,Swing 提供各种 Model(如:
TableModel、TableColumnModel 与 ListSelectionModel)来解决上述的不便,以增加我们设计
表格的弹性。我们下面就先对 TableModel 来
做介绍:

TableModel

TableModel类本身是一个interface,在这个interface里面定义了若干的方法:包括了存取表
格字段(cell)的内容、计算表格的列数等等的基本存取操作,让设计者可以简单地利用
TableModel 来实作他所想要的表格。TableModel 界面是放在 javax.swing.table package 中,
这个 package 定义了许多 JTable 会用到的各种 Model,读者可利用 java api 文件找到这个
package,并由此 package 找到各类或界面所定义的方法。

TableModel 方法:
void addTableModelListener(TableModelListener l):使表格具有处理 TableModelEvent 的能
力。当表格的 Table Model 有所变化时,会发出 TableModel Event 事件信息.
Class getColumnClass(int columnIndex):返回字段数据类型的类名称.

int getColumnCount():返回字段(行)数量.
String getColumnName(int columnIndex):返回字段名称.
int getRowCount():返回数据列数量.
Object getValueAt(int rowIndex,int columnIndex):返回数据某个 cell 中的值.
boolean isCellEditable(int rowIndex,int columnIndex):返回cell是否可编辑,true的话
为可编辑.
void removeTableModelListener(TableModelListener l):从 TableModelListener 中
移除一个 listener.
void setValueAt(Object aValue,int rowIndex,int columnIndex): 设 置 某 个
cell(rowIndex,columnIndex)的值;

由于TableModel本身是一个Interface,因此若要直接实现此界面来建立表格并不是件轻松
的事.幸好 java 提供了两个类分别实现了这个界面,一个是 AbstractTableModel 抽象类,一个是
DefaultTableModel 实体类.前者实现了大部份的 TableModel 方法,让用户可以很有弹性地构
造自己的表格模式;后者继承前者类,是 java 默认的表格模式.这三者的关系如下所示:
TableModel---implements--->AbstractTableModel-----extends--->DefaultTableModel

AbstractTableModel:

java 提供的 AbstractTableModel 是一个抽象类,这个类帮我们实现大部份的 TableModel 方
法,除了 getRowCount(),getColumnCount(),getValueAt()这三个方法外.因此我们的主要任务就
是去实现这三个方法.利用这个抽象类就可以设计出不同格式的表格.我们来看看它所
提供的方法:
AbstractTableModel 方法:
void addTableModelListener(TableModelListener l):使表格具有处理 TableModelEvent 的能
力.当表格的 Table Model 有所变化时,会发出 TableModelEvent 事件信息.
int findColumn(String columnName):寻找在行名称中是否含有 columnName 这个项目.若
有,则返回其所在行的位置;反之则返回-1 表示

void fireTableCellUpdated(int row, int column):通知所有的 Listener 在这个表格中的
(row,column)字段的内容已经改变了.
void fireTableChanged(TableModelEvent e):将所收的事件通知传送给所有在这个 table
model 中注册过的 TableModelListeners.
void fireTableDataChanged():通知所有的 listener 在这个表格中列的内容已经改变了.列的
数目可能已经改变了,因此 JTable 可能需要重新显示此表格的结构.
void fireTableRowsDeleted(int firstRow, int lastRow):通知所有的 listener 在这个表格中第
firstrow 行至 lastrow 列已经被删除了.
void fireTableRowsUpdated(int firstRow, int lastRow):通知所有的 listener 在这个表格中第
firstrow 行至 lastrow 列已经被修改了.
void fireTableRowsInserted(int firstRow, int lastRow):通知所有的 listener 在这个表格中第
firstrow 行至 lastrow 列已经被加入了
.

void fireTableStructureChanged():通知所有的listener在这个表格的结构已经改变了.行的数
目,名称以及数据类型都可能已经改变了
.
Class getColumnClass(int columnIndex):返回字段数据类型的类名称.
String getColumnName(int column): 若 没 有 设 置 列 标 题 则 返 回 默 认 值 , 依 次 为
A,B,C,...Z,AA,AB,..;若无此 column,则返回一个空的 String
.
Public EventListener[] getListeners(Class listenerType):返回所有在这个 table model 所建立的
listener 中符合 listenerType 的 listener,并以数组形式返回.
boolean isCellEditable(int rowIndex, int columnIndex):返回所有在这个 table model 所建立的
listener 中符合 listenerType 形式的 listener,并以数组形式返回.
voidremoveTableModelListener(TableModelListener l):从 TableModelListener 中移除一个
listener.
voidsetValueAt(Object aValue, int rowIndex, int columnIndex)
:设置某个 cell(rowIndex,columnIndex)的值.
若你仔细比较TableModel所定义的方法与上述AbstractTableModel所提供的方法,你可以发
现,AbstractTableModel 抽象类并没有实现
getRowCount(),getColumnCount(),getValueAt()这三个方法,这也就是为什么我们要去实现这
三个方法的原因.下面我们来看如何使用
AbstractTableModel 来实作出自己想要的表格模式.

范例:TableModel1.java

import javax.swing.table.AbstractTableModel;
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
public classTableModel1{
publicTableModel1() {
JFrame f = new JFrame();
MyTable mt=new MyTable();
JTable t=new JTable(mt);
t.(new Dimension(550, 30));
JScrollPane s = new JScrollPane(t);
f.getContentPane().add(s, BorderLayout.CENTER);
f.setTitle("JTable1");
f.pack();
f.setVisible(true);
f.addWindowListener(newWindowAdapter() {
public void windowClosing(WindowEvent e) {
System.exit(0);
}
});

}
public static void main(String args[]) {

newTableModel1();
}
}
class MyTable extendsAbstractTableModel{
Object[][] p = {
{"阿呆", new Integer(66),
new Integer(32), new Integer(98), new Boolean(false),new Boolean(false)},
{"阿瓜", new Integer(85),
new Integer(69), new Integer(154), new Boolean(true),new Boolean(false)},
};
String[] n = {"姓名",
"语文",
"数学",
"总分",
"及格",
"作弊"};
public int getColumnCount() {
return n.length;
}
public int getRowCount() {
return p.length;
}
public String getColumnName(int col) {
return n[col];
}
public Object getValueAt(int row, int col) {
return p[row][col];
}
public Class getColumnClass(int c) {
return getValueAt(0, c).getClass();
}
}

上例中表格内的数据类型不论是 String,int 或是 Boolean 类型,都均以 string 的类型显示.
例如在及格的字段中,原本的数据是以 Boolean
类型来表示,但显示在 JTable 上时便转换成字符串形式,若想要使表格能显示出不同的数据类
型,我们要在 MyTable 中 Override 写 getColumnCl
ass()方法,这个方法可以让我们分辨出表格中每一行的数据类型,并将此类型作适当的显示:
public Class getColumnClass(int c) {
return getValueAt(0, c).getClass();
}

这样"作弊"会以 Check Box 显示,数据类型一律靠右显示,String 类型一律靠左显示.
TableModel2.java
import javax.swing.table.AbstractTableModel;
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;

public classTableModel2 implementsActionListener{

JTable t = null;

publicTableModel2() {

JFrame f = new JFrame("DataModel");
JButton b1 = new JButton("数学老师");
b1.addActionListener(this);
JButton b2 = new JButton("学生阿呆");
b2.addActionListener(this);
JPanel panel = new JPanel();
panel.add(b1);
panel.add(b2);

t=new JTable(new MyTable(1));
t.(new Dimension(550, 30));
JScrollPane s = new JScrollPane(t);

f.getContentPane().add(panel, BorderLayout.NORTH);
f.getContentPane().add(s, BorderLayout.CENTER);
f.pack();
f.setVisible(true);

f.addWindowListener(newWindowAdapter() {
public void windowClosing(WindowEvent e) {
System.exit(0);
}
});
}

public void actionPerformed(ActionEvent e)
{
if (e.getActionCommand().equals("学生阿呆"))
t.setModel(new MyTable(1));
if (e.getActionCommand().equals("数学老师"))
t.setModel(new MyTable(2));

t.revalidate();
}

public static void main(String args[]) {

newTableModel2();
}
}

class MyTable extendsAbstractTableModel{

Object[][] p1 = {
{"阿呆", "1234",new Integer(66),
new Integer(50), new Integer(116), new Boolean(false),new Boolean(false)}};

String[] n1 = {"姓名","学号","语文","数学","总分","及格","作弊"};

Object[][] p2 = {
{"阿呆", "1234",new Integer(50), new Boolean(false),new Boolean(false),"01234"},
{"阿瓜", "1235",new Integer(75), new Boolean(true),new Boolean(false),"05678"}};

String[] n2 = {"姓名","学号","数学","及格","作弊","电话"};

int model = 1;

public MyTable(int i){
model = i;
}

public int getColumnCount() {
if(model ==1)
return n1.length;
else
return n2.length;
}

public int getRowCount() {
if(model ==1)
return p1.length;
else
return p2.length;
}

public String getColumnName(int col) {

if(model ==1)
return n1[col];
else
return n2[col];
}

public Object getValueAt(int row, int col) {
if(model == 1)
return p1[row][col];
else
return p2[row][col];
}

public Class getColumnClass(int c) {
return getValueAt(0, c).getClass();
}
}

TableColumnModel:

TableColumnModel 本身是一个 Interface,里面定义了许多与表格的"列(行)"有关的方法,例
如增加列,删除列,设置与取得"列"的相关信
息.通常我们不会直接实现 TableColumnModel 界面,而是会利用 JTable 的 getColumnModel()
方法取得 TableColumnModel 对象,再利用此对象对
字段做设置.举例来说,如果我们想设计的表格是包括有下拉式列表的 Combo Box,我们就能
利用 TableColumnModel 来达到这样的效果.
我们先看看下面的例子:
import javax.swing.table.AbstractTableModel;
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;

public class ColumnModelTest{

public ColumnModelTest() {

JFrame f = new JFrame();
/* 由 于 我 们 的 MyTable 类 继 承 了 AbstractTableModel 并 且 实 作 了
getColmunCount(),getRowCount(),getValueAt()方法.因此我们可以通
*过 MyTable 来产生 TableModel 的实体.
*/
MyTable mt=new MyTable();
JTable t=new JTable(mt);//我们利用 MyTable 来建立 JTable.

JComboBox c = new JComboBox();//建立一个 JComboBox 的对象.
c.addItem("Taipei");//我们在新建立的 JComboBox 对象里新增三个项目.
c.addItem("ChiaYi");
c.addItem("HsinChu");
/*我们利用 JTable 所提供的 getTableColumnModel()方法取得 TableColumnModel 对象,
再由 TableColumnModel 类所提供的 getColumn()方
*法取得 TableColumn 对象,TableColumn 类可针对表格中的每一行做具体的设置,例如
设置字段的宽度,某行的标头,设置输入较复杂的
*数据类型等等.在这里,我们利用 TableColumn 类所提供的 setCellEditor()方法,将
JComboBox 作为第二行的默认编辑组件.
*/
t.getColumnModel().getColumn(1).setCellEditor(new DefaultCellEditor(c));
t.(new Dimension(550, 30));
JScrollPane s = new JScrollPane(t);

f.getContentPane().add(s, BorderLayout.CENTER);
f.setTitle("ColumnModelTest");
f.pack();
f.setVisible(true);

f.addWindowListener(newWindowAdapter() {
public void windowClosing(WindowEvent e) {
System.exit(0);
}
});
}

public static void main(String args[]) {

new ColumnModelTest();
}

}

class MyTable extendsAbstractTableModel{

Object[][] p = {
{"阿呆", "Taipei",new Integer(66),
new Integer(32), new Integer(98), new Boolean(false),new Boolean(false)},
{"阿瓜", "ChiaYi",new Integer(85),
new Integer(69), new Integer(154), new Boolean(true),new Boolean(false)},
};

String[] n = {"姓名",

"居住地",
"语文",
"数学",
"总分",
"及格",
"作弊"};

public int getColumnCount() {
return n.length;
}

public int getRowCount() {
return p.length;
}

public String getColumnName(int col) {
return n[col];
}

public Object getValueAt(int row, int col) {
return p[row][col];
}
public Class getColumnClass(int c) {
return getValueAt(0, c).getClass();
}
/*pu

阅读全文

与javajtabel竖相关的资料

热点内容
什么东西代表了编程 浏览:698
网络中心如何关闭 浏览:258
k3编程是什么意思 浏览:296
vba和sql数据库哪个好 浏览:38
u启王u盘启动盘制作工具 浏览:228
深入理解android网络编程 浏览:615
javah无法访问 浏览:11
keyvalue内存数据库 浏览:446
2016年淘宝店铺装修教程 浏览:394
哪个地区把编程纳入高考范围中了 浏览:327
linuxc语言参数 浏览:688
win10电脑关机后重启 浏览:747
查公司注册信息怎么查app 浏览:403
iphone应用程序开网络连接失败 浏览:555
xp电脑没有运行程序 浏览:677
whatsapp在国内能用吗 浏览:976
怎么恢复空间视频文件 浏览:716
多线程读一个文件 浏览:939
查询社保缴纳情况用什么app 浏览:915
单机象棋代码 浏览:984

友情链接