怎样在指定的table单元格处生成下拉列表

原创 2007年09月23日 17:59:00
 在写table时花了本人几天的时间,最后终于搞定了,与大家共同分享。
以下是调用方法:
/****************************************************************/

DefaultTableModel model = new DefaultTableModel(); //
/*设置表格模型*/
model.setDataVector(rowDatas, tableHeadName);

/*表格使用模型*/
// JBTable table = new JBTable(tableModel);
JBTable table = new JBTable();
table.setRowSelectionAllowed(true); //add
table.setModel(model);
JTextField text = new JTextField(); //

JComboBox com_size = new JComboBox(); //字体大小
com_size.addItem("1");
com_size.addItem("2");
com_size.addItem("3");
com_size.addItem("4");
com_size.addItem("5");
com_size.addItem("6");

JBMutiTypeEditor com_edit = new JBMutiTypeEditor(text, com_size); //
TableColumn aColumn1 = table.getColumn("属性");
aColumn1.setCellEditor(com_edit);

/****************************************************************/
上边代码没什么特别的,关键在以下的类。

package jbpd.application;

import javax.swing.*;
import java.awt.event.*;
import java.util.*;
import java.awt.*;
import javax.swing.table.*;
import java.util.EventObject;
import javax.swing.table.*;

class JBMutiTypeEditor
extends DefaultCellEditor {
JTable editingTable = new JTable();
JTextField textComponent;
JComboBox comboComponent;
boolean textOrNot = true;

public JBMutiTypeEditor(JTextField text, JComboBox combo) {
super(text);
textComponent = text;
comboComponent = combo;
}

public void setTextOrNot(boolean textOrNot) {
this.textOrNot = textOrNot;
}

public Component getTableCellEditorComponent(JTable table, Object value,
boolean isSelected,
int row, int column) {
editingTable = table;
String flag = (String) table.getValueAt(row, 0);
//与jbpage表中的“页面字体”列对应
if (flag.equals("存储方式") || flag.equals("是否被选中")) {
String item = (value != null) ? value.toString() : "1";
DefaultComboBoxModel model = (DefaultComboBoxModel) comboComponent.
getModel();
for (int i = 0; i < model.getSize(); i++) {
String aItem = (String) model.getElementAt(i);
if (aItem.equals(item)) {
comboComponent.setSelectedIndex(i);
}
}
return comboComponent;
}
if (flag.equals("字体大小") && row == 3) {
String item = (value != null) ? value.toString() : "1";
DefaultComboBoxModel model = (DefaultComboBoxModel) comboComponent.
getModel();
for (int i = 0; i < model.getSize(); i++) {
String aItem = (String) model.getElementAt(i);
if (aItem.equals(item)) {
comboComponent.setSelectedIndex(i);
}
}
return comboComponent;
}
else {
textComponent.setText( (value != null) ? value.toString() : "");
return textComponent;
}
}

public boolean stopCellEditing() {
JTable aTable = this.editingTable;
int rowNo = aTable.getEditingRow();
String flag = "";
if (rowNo != -1) {
flag = (String) aTable.getValueAt(rowNo, 0);
}
if (flag.equals("存储方式")|| flag.equals("是否被选中")) {
this.delegate.setValue(comboComponent.getSelectedItem());
}
if(flag.equals("字体大小")){
this.delegate.setValue(comboComponent.getSelectedItem());
}
return super.stopCellEditing();
}
}
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Ext.grid.EditorGridPanel单元格内套用下拉列表,且列表数据为动态加载,支持模糊查询,有描述信息

function familyMemberStore(familyId){ var familyMemberResultGridStore = new Ext.data.JsonStore({ r...

MFC List Control 控件添加单元格编辑和单元格下拉列表项

原理很简单:就是在点击到列表相应单元格的时候,在相应的位置生成一个跟单元格大小相当的编辑框或者下拉列表框并贴在单元格上面而已。 实现如下: 在对话框类声明中添加如下变量和函数:头文件中添加:int ...

MFC List Control控件添加单元格编辑和单元格下拉列表项以适用于数据库相关操作

作为现代的软件,往往是连着数据库的,而连着和操作方便之间,还有着用户界面这道坎。MFC是Windows上比较好开发用户界面的封装类,然而其自带的控件中没有对于数据库表格支持较好的控件,这时利Activ...

js动态生成table 合并单元格

js操作表格 .domian_tab     { width:1000px; border:#000000 1px solid; border-collapse:collapse;} ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)