利用自定义的CellEditor实现第四列第二行为下拉框,本列其余行为文本框
利用默认的DefaultCellEditor设置第五列整列为下拉框
 
package mypackage;
import java.awt.BorderLayout;
import java.awt.Component;
import java.awt.Dimension;
import java.util.EventObject;
import javax.swing.AbstractCellEditor;
import javax.swing.JComboBox;
import javax.swing.JPanel;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.table.TableCellEditor;
/**
 * 自定义celleditor实现
 * 指定单元格设置下拉框,其他单元格设置文本框
 *
 */
public class JBoxTestCell  extends AbstractCellEditor implements
TableCellEditor {
    int row;
    private JTable table;
    private JPanel p1;
    private JComboBox jbox;
    private Object val = null;
    private JTextField jt_0=new JTextField();
    private JTextField jt_2=new JTextField();
    public JBoxTestCell() {
        p1 = new JPanel(new BorderLayout());
  
        p1.setPreferredSize(new Dimension(300, 30));
        String[] interest1 = { "rap", "手指舞", "理发","冲天炮"};
        jbox = new JComboBox(interest1);
        jbox.setPreferredSize(new Dimension(200,25));
        jbox.setSelectedIndex(0);
        p1.add(jbox, BorderLayout.CENTER);
    }
    @Override
    public boolean isCellEditable(EventObject anEvent) {
        return true;
    }
    public void showSave() {
     jbox.setVisible(true);
    }
    public Object getCellEditorValue() {
       if(row==1) {
     String v1 = jbox.getSelectedItem().toString();
        return v1;
       }
       String result="";
       switch(this.row) {
  case 0 : result = jt_0.getText().trim(); break;
  case 2 : result = jt_2.getText().trim(); break;
       }
       return result;
    }
   
    public Component getTableCellEditorComponent(JTable table, Object value,
            boolean isSelected, int row, int column) {
        this.table = table;
        this.row = row;
        val = value;
        JTextField result = new JTextField();
  switch(this.row) {
  case 0 : result = jt_0; break;
  case 1 : return this.jbox;
  case 2 : result = jt_2; break;
  }
  return result;
    }
}
 
 
 
 
package mypackage;
import java.awt.Dimension;
import java.util.Vector;
import javax.swing.DefaultCellEditor;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.ScrollPaneConstants;
import javax.swing.table.TableColumnModel;
import java.awt.Font;
/**
 * 测试类
 * 实现第四列第二行为下拉框,其余行为文本框
 * 第五列一列为下拉框
 */
public class Test {
 
 public static void main(String[] args) {
  JFrame frame = new JFrame();
  frame.setBounds(100, 100, 500, 400);
  frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
  frame.getContentPane().setLayout(null);
  JPanel panel = new JPanel();
  panel.setLayout(null);
  panel.setBounds(0, 0, 484, 361);
  frame.getContentPane().add(panel);
  frame.setVisible(true);
  
  String[][] str= {{"小贾","13","160","帽子",""},{"阿P","16","165","rap",""},{"小李","19","158","做头发",""}};
  String[] title= {"姓名","年龄","身高","爱好1","爱好2"};
  JTable table = new JTable(str,title);//测试表格
  table.setFont(new Font("微软雅黑", Font.PLAIN, 12));
  
  JScrollPane scrollPane_1 = new JScrollPane(table);//滚动组件
  scrollPane_1.setBounds(0, 0, 484, 361);
  scrollPane_1.setVerticalScrollBarPolicy(ScrollPaneConstants.VERTICAL_SCROLLBAR_ALWAYS);
  panel.add(scrollPane_1);
  
  JBoxTestCell jc = new JBoxTestCell();//第四列第二行为下拉框,其余行为文本框
  TableColumnModel tcm = table.getColumnModel();
  tcm.getColumn(3).setCellEditor(jc);
  
  String[] str2 = { "rap", "手指舞", "理发","冲天炮"};
  JComboBox jbox= new JComboBox(str2);
  jbox.setSelectedIndex(0);
  TableColumnModel col = table.getColumnModel();
  col.getColumn(4).setCellEditor(new DefaultCellEditor(jbox));//设置第5列一列为下拉框
 }
}
 
效果图:

java swing 中JTable实现指定单元格为下拉框的更多相关文章

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

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

  2. 【Excel】单元格的下拉框是怎么做的?

    如果我们希望将产品这一列的每个单元格都能选择 左侧的产品就好了,就像这样 这里使用的是"验证数据有效性"功能 在这里: 点击F,选择F列后,打开“数据验证”,如图,选择序列,选择来 ...

  3. C# Winform 中DataGridView 实现单元格输入下拉框功能

    https://blog.csdn.net/ad13adsa/article/details/82108969 private void dataGridViewX1_EditingControlSh ...

  4. LibreOffice/Calc:单元格设置下拉菜单

     造冰箱的大熊猫,本文适用于LibreOffice Calc 5.1.6.2 + Ubuntu 16.04@cnblogs 2019/1/2 LibreOffice是一个类似Microsoft Off ...

  5. js中遍历出查询后的listmodel(下拉框系列)

    function selectclassname(){ $.ajax({ url:"queryschoolclasslists.action", async:false, data ...

  6. js中给easyUI年份,月份选择下拉框赋值

    sp中定义 js中初始化 //年度下拉框初始化 $("#yearChoose").combobox({    valueField:'year',     textField:'y ...

  7. Excel的单元格设置下拉选项并填充颜色

    如何在Excel的单元格中加入下拉选项   方法/步骤     第一步:打开excel文档,选中需加入下拉选项的单元格.      第二步:点击菜单中的“数据”->“数据有效性”->“数据 ...

  8. 在elementUI中使用 el-autocomplete 实现远程搜索的下拉框

    参考;https://blog.csdn.net/qq_37746973/article/details/78402812?utm_source=blogxgwz1 https://blog.csdn ...

  9. java swing 开发 -JTable

    最近利用空闲时间自己琢磨了一下java swing 编程,其实在从事javaweb之前我一直向往的就是java swing 开发,不知道为什么可能当时觉得Windows上的exe程序很是神奇,关于wi ...

随机推荐

  1. 前端模块化开发的价值(seaJs)

    随着互联网的飞速发展,前端开发越来越复杂.本文将从实际项目中遇到的问题出发,讲述模块化能解决哪些问题,以及如何使用 Sea.js 进行前端的模块化开发. 恼人的命名冲突 我们从一个简单的习惯出发.我做 ...

  2. Mybatis的分支选择和In循环

    Mybatis的分支选择: <choose> <when test="patientNo != null and patientNo != ''"> and ...

  3. A Bite Of React(1)

    react: component and views : produce html abd add them on a page( in the dom) <import React from ...

  4. spring boot 多环境(dev、test、prod)配置文件---命令行切换

    properties配置格式 在Spring boot 中多环境配置文件名需要满足application-{profile}.properties的格式,其中{profile}对于你的环境标识,比如: ...

  5. 动画FPS计算

    1.chrome的debug 2.PerformanceObserver var observer = new PerformanceObserver(function (list) { var pe ...

  6. Php 十六进制短浮点数转十进制,带符号位

    /** * 十六进制浮点型转为十进制 * @param String $strHex 十六进制浮点数 * @return 十进制 */ public static function hexToDecF ...

  7. .NET Core TDD 前传: 编写易于测试的代码 一 -- 缝

    转载于: https://www.cnblogs.com/cgzl/p/9365955.html 有时候不是我们不想做单元测试, 而是这代码写的实在是没法测试.... 举个例子, 如果一辆汽车在产出后 ...

  8. 转载:java面试题(二)

    这部分主要是开源Java EE框架方面的内容,包括Hibernate.MyBatis.Spring.Spring MVC等,由于Struts 2已经是明日黄花,在这里就不讨论Struts 2的面试题, ...

  9. day01 html介绍 文档声明头 head标签 body标签

    day01 html   初识html <!--文档的声明--> <!doctype html>   <html lang="en">    # ...

  10. python 常用技巧 — 字典 (dictionary)

    目录: 1. python 相加字典所有的键值 (python sum all values in dictionary) 2. python 两个列表分别组成字典的键和值 (python two l ...