利用自定义的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. git提交时,仓库是空的,本地有源码。

    应该打开cmd   归到项目路径 然后输入git push -u origin master -f 是把本地的项目强制推送到空的仓库 git init (在当前文件夹下初始化一个git仓库) git ...

  2. 一步一步学Vue(九) 路由元数据

    一步一步学Vue(九):https://www.cnblogs.com/Johnzhang/p/7260888.html

  3. HttpClient 之 4.x.x版本以上的发送Https请求

    https请求比http更安全 是在http的基础上加了SSL数据加密协议. http的连接很简单,是无状态的:HTTPS协议是由SSL+HTTP协议构建的可进行加密传输.身份认证的网络协议,比htt ...

  4. JavaScript — event介绍以及兼容处理

    JavaScript - event介绍以及兼容处理 1.事件流 浏览器发展到第四代时(IE4及 Netscape Communicator 4),浏览器开发团队遇到一个问题:页面的哪个部分会拥有某个 ...

  5. rabbitmq的管理软件以及PHP7安装rabbitmq的

    rabbitmq-server管理软件的安装 1.mac下载rabbitmq-server brew install rabbitmq 2.启动服务rabbitmq-server rabbitmq-s ...

  6. Mongo导出、导入

    1.mongodb 数据导出: connection options: /h, /host:<hostname> mongodb host to connect to (setname/h ...

  7. 19.并发下的ArrayList、HashMap,Integer加锁问题

    import java.util.ArrayList; import java.util.Vector; /** * 并发下的ArrayList */ public class ArrayListMu ...

  8. PHP上传文件和下载

    PHP 中文件上传的基础知识: 1)客户端 form 表单设置 必须设置的 form 表单项: <!DOCTYPE html> <html> <head> < ...

  9. php7类型约束的意义

    在PHP7之前,函数和类方法不需要声明变量类型,任何数据都可以被传递和返回,导致几乎大部分的调用操作都要判断返回的数据类型是否合格. 为了解决这个问题,PHP7引入了类型声明. 目前有两类变量可以声明 ...

  10. python用户名密码限定次数登录

    """ 1. 用户输入帐号密码进行登陆 2. 用户信息保存在文件内 3. 用户密码输入错误三次后锁定用户"""" test.txt ...