http://bbs.csdn.net/topics/390195204

————————————————————————————————————————

java 达人,

最近在开发一个 java 模块,用到了 JTable。现在对 JTable 里的单元格的操作中,在双击进入单元格后,单元格的内容不是全选中状态。

请问有啥办法使得双击进入单元格后,单元格的内容处于全选中状态?如下面的图片所示

十分感谢!

下面是已经写好的代码:

Java code?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
import java.awt.BorderLayout;
import java.awt.Component;
import java.awt.Dimension;
import java.awt.FlowLayout;
import java.awt.GridLayout;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Vector;
 
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.ListSelectionModel;
import javax.swing.ScrollPaneLayout;
import javax.swing.SwingConstants;
import javax.swing.event.ListSelectionEvent;
import javax.swing.event.ListSelectionListener;
import javax.swing.table.DefaultTableCellRenderer;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableCellRenderer;
import javax.swing.table.TableColumn;
 
public class GlobalVari_6 extends JFrame {
    private static final long serialVersionUID = 1L;
 
    private static double select = 0;
    private static int rowIndex = 0;
 
    public JTable table = null;
 
    // 表格方法使用
    public GlobalVari_6() {
        init();
 
        this.setTitle("Global Variables");
        this.setSize(new Dimension(650400));
        this.setLocationRelativeTo(null);
        this.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
        this.setVisible(true);
        // this.setResizable(false);
    }
 
    private void init() {
        Vector<String> colHeader = new Vector<String>();
 
        Vector<Vector<String>> dataVec = new Vector<Vector<String>>();
 
        colHeader.add("  Variable");
        colHeader.add("Value  ");
        colHeader.add("Time  ");
 
        table = new JTable(dataVec, colHeader) {
            private static final long serialVersionUID = 1L;
 
            public boolean isCellEditable(int row, int column) {
                if (column > 1) {
                    return false;
                else {
                    return true;
                }
            }
        };
 
        // 2设置表头行高
        table.getTableHeader().setPreferredSize(new Dimension(020));
        // 3设置表内容行高
        table.setRowHeight(20);
        // 4设置单选模式
        table.getSelectionModel().setSelectionMode(
                ListSelectionModel.SINGLE_SELECTION);
        // 5设置单元格不可拖动
        table.getTableHeader().setReorderingAllowed(false);
        // 6设置不可改变列宽
        table.getTableHeader().setResizingAllowed(false);
        // 7设置列宽
        table.getColumnModel().getColumn(0).setPreferredWidth(95);
        table.getColumnModel().getColumn(1).setPreferredWidth(55);
        table.getColumnModel().getColumn(2).setPreferredWidth(30);
        // 注意索引越界
 
        DefaultTableCellRenderer right = new DefaultTableCellRenderer();
        // right.setHorizontalAlignment(JLabel.RIGHT);
        right.setHorizontalAlignment(SwingConstants.RIGHT);
        table.getColumnModel().getColumn(1).setCellRenderer(right);
        table.getColumnModel().getColumn(2).setCellRenderer(right);
        // table.getColumn(table.getColumnName(1)).setHeaderRenderer(right);
        // table.getTableHeader().setDefaultRenderer(new HeaderRenderer(table));
        ((DefaultTableCellRenderer) table.getTableHeader().getDefaultRenderer())
                .setHorizontalAlignment(JLabel.RIGHT);
 
        TableColumn column = table.getColumnModel().getColumn(0);
        MultiLineHeaderRenderer headerRenderer = new MultiLineHeaderRenderer(
                SwingConstants.LEFT, SwingConstants.BOTTOM);
        column.setHeaderRenderer(headerRenderer);
 
        /*
         * column = table.getColumnModel().getColumn(1); headerRenderer = new
         * MultiLineHeaderRenderer( SwingConstants.LEFT, SwingConstants.BOTTOM);
         * column.setHeaderRenderer(headerRenderer);
         */
 
        final JButton buttonAdd = new JButton("Add");
        final JButton buttonDel = new JButton("Delete");
        final JButton buttonCls = new JButton("Close");
 
        rowIndex = table.getSelectedRow();
        System.out.println("index:" + rowIndex);
        // 监听事件
        table.getSelectionModel().addListSelectionListener(
                new ListSelectionListener() {
                    public void valueChanged(ListSelectionEvent e) {
                        if (e.getValueIsAdjusting()) {// 连续操作
                            rowIndex = table.getSelectedRow();
                            if (rowIndex != -1) {
                                System.out.println("表格行被选中" + rowIndex);
                                buttonDel.setEnabled(true);
                                select = 1;
                            }
                        }
                    }
                });
 
        JScrollPane scrollPane = new JScrollPane();
        scrollPane.setLayout(new ScrollPaneLayout());
        scrollPane.setViewportView(table);
        scrollPane.setBounds(55515350);
        this.getContentPane().add(scrollPane);
 
        buttonAdd.setEnabled(true);
        buttonDel.setEnabled(false);
        buttonCls.setEnabled(true);
 
        JPanel panel = new JPanel();
        panel.setBounds(520510350);
        this.getContentPane().add(panel);
 
        panel.setLayout(null);
        panel.add(buttonAdd);
        buttonAdd.setSize(10022);
        buttonAdd.setLocation(5306);
        panel.add(buttonDel);
        buttonDel.setSize(10022);
        buttonDel.setLocation(53040);
        panel.add(buttonCls);
        buttonCls.setSize(10022);
        buttonCls.setLocation(530322);
 
        buttonAdd.addMouseListener(new MouseListener() {
            public void mouseClicked(MouseEvent e) {
                DefaultTableModel model = (DefaultTableModel) table.getModel();
                int rownum = table.getRowCount() + 1;
                boolean exist = true;
                for (int i = 0; i < model.getRowCount(); i++) {
                    if (model.getValueAt(i, 0).equals("gvar" + rownum)) {
                        exist = false;
                        break;
                    }
                }
 
                if (exist == true)
                    model.addRow(new Object[] {
                            "gvar" + rownum,
                            "",
                            new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")
                                    .format(new Date()) });
            }
 
            public void mousePressed(MouseEvent e) {
            }
 
            public void mouseReleased(MouseEvent e) {
            }
 
            public void mouseEntered(MouseEvent e) {
            }
 
            public void mouseExited(MouseEvent e) {
            }
        });
 
        buttonDel.addMouseListener(new MouseListener() {
            public void mouseClicked(MouseEvent e) {
                if (select == 1) {
                    DefaultTableModel model = (DefaultTableModel) table
                            .getModel();
                    model.removeRow(rowIndex);
                    select = 0;
                    buttonDel.setEnabled(false);
                }
            }
 
            public void mousePressed(MouseEvent e) {
            }
 
            public void mouseReleased(MouseEvent e) {
            }
 
            public void mouseEntered(MouseEvent e) {
            }
 
            public void mouseExited(MouseEvent e) {
            }
        });
 
        buttonCls.addMouseListener(new MouseListener() {
            public void mouseClicked(MouseEvent e) {
                setVisible(false);
            }
 
            public void mousePressed(MouseEvent e) {
            }
 
            public void mouseReleased(MouseEvent e) {
            }
 
            public void mouseEntered(MouseEvent e) {
            }
 
            public void mouseExited(MouseEvent e) {
            }
        });
 
        this.pack();
    }
     
    public static void main(String[] args) {
        new GlobalVari_6();
    }
}

在你的init较后面的地方加。

Java code?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
        TableCellEditor tce =  table.getDefaultEditor(String.class);
        if (tce instanceof DefaultCellEditor) {
            DefaultCellEditor dce = (DefaultCellEditor) tce;
            final Component c = dce.getComponent();
            c.addFocusListener(new FocusListener() {
                @Override
                public void focusGained(FocusEvent arg0) {
                    System.out.println("focusGained");
                    if (c instanceof JTextComponent) {
                        ((JTextComponent) c).selectAll();
                    
                }
 
                @Override
                public void focusLost(FocusEvent arg0) {
                }
            });
        }

但是如果你的JTable里某列自己加过JTextField等。
例如:
写过类似这样的

Java code?
1
column.setCellEditor(new DefaultCellEditor(textField));

那么下面那段也许也要加上。

Java code?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
int count = table.getColumnModel().getColumnCount();
        for (int i = 0; i < count; i++) {
            TableColumn tableColumn = table.getColumnModel().getColumn(i);
            if (tableColumn.getCellEditor() == null) {
                continue;
            }
            if (tableColumn.getCellEditor() instanceof DefaultCellEditor) {
                DefaultCellEditor dce = (DefaultCellEditor) tableColumn
                        .getCellEditor();
                final Component c = dce.getComponent();
                c.addFocusListener(new FocusListener() {
                    @Override
                    public void focusGained(FocusEvent arg0) {
                        if (c instanceof JTextComponent) {
                            ((JTextComponent) c).selectAll();
                        
                    }
 
                    @Override
                    public void focusLost(FocusEvent arg0) {
                    }
                });
            }
        }

请教 JTable 里的单元格如何使得双击进入单元格后,单元格的内容处于全选中状态的更多相关文章

  1. Html Table用JS导出excel格式问题 导出EXCEL后单元格里的000412341234会变成412341234 7-14 会变成 2018-7-14(7月14) 自定义格式 web利用table表格生成excel格式问题 js导出excel增加表头、mso-number-format定义数据格式 数字输出格式转换 mso-number-format:"\@"

    Html Table用JS导出excel格式问题 我在网上找的JS把HTML Tabel导出成EXCEL.但是如果Table里的数字内容为0开的的导成Excel后会自动删除0,我想以text的格式写入 ...

  2. delphi 需要应用一个单元是,需要在工程里面先添加单元

    delphi 需要应用一个单元是,需要在工程里面先添加单元

  3. BUAA-OO-最后单元总结

    BUAA-OO-最后单元总结 经过一学期的魔鬼"折磨"后,OO课程终于要结束了!总体来说我对于作业的总体完成情况还是比较满意的,希望最后可以取得一个理想成绩. 一.第四单元架构设计 ...

  4. excel如何设置输入数字后单元格自动填充颜色

    在使用excel的过程中,有时需要在输入数字时,突出显示这些单元格,突出显示可以用有填充颜色的单元格来表示.为了实现这样的效果,需要借助excel的条件格式. 工具/原料 电脑 Excel 2010 ...

  5. 【原创】有关Silverlight控件DataGrid的绑定数据后单元格单独复制的功能实现分析

    前些日子,公司新需求需要对silverlight的datagrid进行局部任意单元格数据可复制,查阅了半天网络资料愣是没找到相关资料,开始还以为是silverlight的bug根部无法实现, 最后还是 ...

  6. EXCEL中,如何引用一个单元格中的数据,作为另一个单元格内容中的一部分?

    https://zhidao.baidu.com/question/230715654.html 假设单元格A1值是8(该值由函数计算得出),我要在单元格B1中引用A1的值,但只是作为B1单元格内容中 ...

  7. NPOI 生成Excel (单元格合并、设置单元格样式:字段,颜色、设置单元格为下拉框并限制输入值、设置单元格只能输入数字等)

    NPIO源码地址:https://github.com/tonyqus/npoi NPIO使用参考:源码中的 NPOITest项目 下面代码包括: 1.包含多个Sheet的Excel 2.单元格合并 ...

  8. DataGridView中EnditCommit()调用之后,单元格的内容被全选了,每次输入都要鼠标点击定位到最后才能继续输入

    因为某些需求,DataGridView在输入一次内容,就要调用ECommitEdit(DataGridViewDataErrorContexts.Commit)来将内容提交,但是这样做之后,控件就会当 ...

  9. POI使用cell.getCellStyle()设置指定单元格颜色,但是其它没有指定的单元格也会变色

    HSSFCell cell = row.createCell((short)i); cell.getCellStyle().setAlignment(HSSFCellStyle.ALIGN_RIGHT ...

随机推荐

  1. excel文件导入mysql

    在数据处理的过程中,常常要把windows下的excel文件导入linux下的mysql.这其中会出现一些问题. 1.首先,要在mysql中建表.命令最好存在记事本中,可以随时修改,随时执行 crea ...

  2. 小程序踩过的一个小坑---解析二维码decodeURIComponent() url解码

    因为我们需要用户扫码进入小程序,每一个货柜都有一个对应的二维码,当然每个二维码里的信息也不一样.用户扫码进入小程序之后,二维码的信息会以参数q带进去,而我们只能在onLoad事件中拿到这个参数, 但是 ...

  3. php使用CURL不依赖COOKIEJAR获取COOKIE的方法

    本文实例讲述了php使用CURL不依赖COOKIEJAR获取COOKIE的方法.分享给大家供大家参考.具体分析如下: PHP中CURL类是一个非常牛逼的工具类,具体怎么牛逼就不啰嗦了. 对于COOKI ...

  4. kail linux 系统下利用metaspolit工具渗透win7电脑

     注:只是测试,不可干违法的事. 一.metaspolit工具的介绍 1.1.metaspolit 是一款开源安全漏洞检测工具,附带数百个已知的软件漏洞,并保持频繁更新.被安全社区冠以“可以黑掉整个宇 ...

  5. 使用MySQL Proxy和MySQL Replication实现读写分离

    MySQL Replication可以将master的数据复制分布到多个slave上,然后可以利用slave来分担master的读压力.那么对于前台应用来说,就要考虑如何将读的压力分布到多个slave ...

  6. Atitit 获取剪贴板内容

    Atitit 获取剪贴板内容 1.1. Java当然有这个功能,但是体积大,先使用script语言实现吧..1 1.2. node.js 好像没这个api  ...1 1.3. Ahk也没有..Aut ...

  7. 服务器重启后如何开启由docker部署的redmine

    1. 服务器重启后,需要重新开启docker服务 systemctl start docker 2. 查看全部container,包括exited的容器,找出redmine所对应的NAMES标签名称 ...

  8. 【MyBean调试笔记】关于单元的释放顺序

    [概述] DEMO提交人:惠商软件  2508696439 问题描述:MDIConsole, DEMO如果Forms单元引用顺序放在mybean.console.pas文件之后如下图所示时: 创建同一 ...

  9. CSAPP 读书笔记 - 2.31练习题

    根据等式(2-14) 假如w = 4 数值范围在-8 ~ 7之间 2^w = 16 x = 5, y = 4的情况下面 x + y = 9 >=2 ^(w-1)  属于第一种情况 sum = x ...

  10. Asp.Net正则获取链接地址

    string html = “html代码”; Regex reg = new Regex(@"(?is)<a[^>]*?href=(['""]?)(?< ...