在给自己的jtable控件加了jcombobox下拉控件后,只要鼠标一单击单元格就进入编辑状态了。有什么办法可以让其双击后才出现自己的控件进行编辑。 我发现只要加了自定义的控件,就会变成单击编辑。请问有什么办法可以像它默认那样,双击以后才进入编辑状态。谢谢了
解决方案 »
- ANDROID 模拟器重启后ALARMMANAGER设置的闹钟不能自己运行
- 计算两个日期间隔天数的问题?
- 关于Java的传值问题,个人感觉书上说的都不好,请进来听听我的看法。
- 关于Robocode的大问题
- Java编程时如何设置让JFrame最大化显示?
- 请问如何让我的JTextArea可以显示html格式的内容
- JLayeredPane是不是只能对组件排序?有没有能对窗口排序的?
- 为什么我从数据库中取出来的内容显示不到ckeditor编辑器中?
- 谁有 有关 Data Express DBSwing页面上控件用法的资料(要是中文的)?我找了好久,都没有找到合适的资料
- java迭代器怎么实现遍历
- 请教判断空值的几种方式的区别
- 在构造方法中调用被子类重写的方法抛出异常
package swing;import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.Vector;import javax.swing.DefaultCellEditor;
import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.AbstractTableModel;
import javax.swing.table.TableColumnModel;/**
* JTable的实用小例子
*
* @author 五斗米 <如转载请保留作者和出处>
* @blog http://blog.csdn.net/mq612
*/public class TestTable {
private JFrame frame = null; private JTable table = null; private Table_Model model = null; private JScrollPane s_pan = null; private JButton button_1 = null, button_2 = null, button_3 = null; private JPanel pane = null; public TestTable() {
frame = new JFrame("JTableTest");
pane = new JPanel();
button_1 = new JButton("清除数据");
button_1.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
removeData();
}
});
button_2 = new JButton("添加数据");
button_2.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
addData();
}
});
button_3 = new JButton("保存数据");
button_3.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
saveData();
}
});
pane.add(button_1);
pane.add(button_2);
pane.add(button_3);
model = new Table_Model(20);
table = new JTable(model);
table.setBackground(Color.pink);
table.setRowHeight(25);
String[] age = { "16", "17", "18", "19", "20", "21", "22" };
JComboBox com = new JComboBox(age);
TableColumnModel tcm = table.getColumnModel();
tcm.getColumn(3).setCellEditor(new DefaultCellEditor(com));
tcm.getColumn(0).setPreferredWidth(50);
tcm.getColumn(1).setPreferredWidth(100);
tcm.getColumn(2).setPreferredWidth(50); s_pan = new JScrollPane(table); frame.getContentPane().add(s_pan, BorderLayout.CENTER);
frame.getContentPane().add(pane, BorderLayout.NORTH);
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.setSize(300, 200);
frame.setVisible(true); } private void addData() {
model.addRow("李逵", true, "19");
table.updateUI();
} private void removeData() {
model.removeRows(0, model.getRowCount());
table.updateUI();
} // 保存数据,暂时是将数据从控制台显示出来
private void saveData() {
int col = model.getColumnCount();
int row = model.getRowCount();
for (int i = 0; i < col; i++) {
System.out.print(model.getColumnName(i) + "\t");
}
System.out.print("\r\n");
for (int i = 0; i < row; i++) {
for (int j = 0; j < col; j++) {
System.out.print(model.getValueAt(i, j) + "\t");
}
System.out.print("\r\n");
}
System.out.println("------------------------------------");
} public static void main(String args[]) {
new TestTable();
}}/**
* TableModel类,继承了AbstractTableModel
*
* @author 五斗米
*
*/
class Table_Model extends AbstractTableModel { private static final long serialVersionUID = -7495940408592595397L; private Vector content = null; private String[] title_name = { "ID", "姓名", "性别", "年龄" }; public Table_Model() {
content = new Vector();
} public Table_Model(int count) {
content = new Vector(count);
} public void addRow(String name, boolean sex, String age) {
Vector v = new Vector(4);
v.add(0, new Integer(content.size()));
v.add(1, name);
v.add(2, new Boolean(sex));
v.add(3, age);
content.add(v);
} public void removeRow(int row) {
content.remove(row);
} public void removeRows(int row, int count) {
for (int i = 0; i < count; i++) {
if (content.size() > row) {
content.remove(row);
}
}
} /**
* 让表格中某些值可修改,但需要setValueAt(Object value, int row, int col)方法配合才能使修改生效
*/
public boolean isCellEditable(int rowIndex, int columnIndex) {
if (columnIndex == 0) {
return false;
}
return true;
} /**
* 使修改的内容生效
*/
public void setValueAt(Object value, int row, int col) {
((Vector) content.get(row)).remove(col);
((Vector) content.get(row)).add(col, value);
this.fireTableCellUpdated(row, col);
} public String getColumnName(int col) {
return title_name[col];
} public int getColumnCount() {
return title_name.length;
} public int getRowCount() {
return content.size();
} public Object getValueAt(int row, int col) {
return ((Vector) content.get(row)).get(col);
} /**
* 返回数据类型
*/
public Class getColumnClass(int col) {
return getValueAt(0, col).getClass();
}}
那么,既然你说自定义的编辑器,那么一定会使用继承默认的CellEditor或者实现相应的接口。
当然默认的编辑器也实现了CellEditor接口。
或许你没有注意到,有这样的一个方法:isCellEditable
boolean isCellEditable(EventObject anEvent)询问编辑器它是否可以使用 anEvent 开始进行编辑。anEvent 在将要调用的组件的坐标系统中。编辑器不能假定由 getCellEditorComponent 返回的 Component 已被安装。此方法供客户端使用,以避免不可能进行编辑时设置和安装编辑器组件所带来的花费。如果可以开始进行编辑,则此方法返回 true。 参数:
anEvent - 编辑器考虑是否开始进行编辑时应该使用的事件
返回:
如果可开始进行编辑,则返回 true改写此方法,足矣。若还有问题,请描述的更详细一些