繁体   English   中英

两个具有相同自定义模型的JXTables-如何使单元在一个表中可编辑但在第二个表中不可编辑?

[英]Two JXTables with same custom model - How to make cells editable in one table but non-editable in the second?

我有一个自定义表模型,我想在一个JXTable中编辑其数据,但在第二个JXTable中仅查看。 无需两个单独的模型就可以做到吗? 有什么方法可以替代仅查看表的model.isCellEditable吗?

import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Component;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.TreeMap;
import javax.swing.*;
import javax.swing.table.AbstractTableModel;
import org.jdesktop.swingx.JXTable;
import org.jdesktop.swingx.decorator.ColorHighlighter;
import org.jdesktop.swingx.decorator.ComponentAdapter;
import org.jdesktop.swingx.decorator.HighlightPredicate;

public class SSCCE extends JPanel {

  private JSplitPane splitPane;
  private JXTable viewTable, editTable;

  private class CustomModel extends AbstractTableModel {

    public static final int SPORT_COL = 0;
    public static final int EQUIPMENT_COL = 1;
    private final String[] COLUMN_NAMES = {
      "Sport",
      "Equipment"
    };
    private Map<String, String> sports;
    private List<String> set;

    public CustomModel() {
      sports = new TreeMap<String, String>();
      sports.put("Rugby", "Headguard");
      sports.put("Hurling", "Sliotar");
      sports.put("Tennis", "Racket");
      set = new ArrayList<String>(sports.keySet());
    }

    public int getRowCount() {
      return sports.size();
    }

    public int getColumnCount() {
      return COLUMN_NAMES.length;
    }

    @Override
    public String getColumnName(int columnIndex) {
      return COLUMN_NAMES[columnIndex];
    }

    public Object getValueAt(int rowIndex, int columnIndex) {
      String sport = set.get(rowIndex);
      switch (columnIndex) {
        case SPORT_COL:
          return sport;
        case EQUIPMENT_COL:
          return sports.get(sport);
      }
      return null;
    }

    @Override
    public void setValueAt(Object aValue, int rowIndex, int columnIndex) {
      if (columnIndex == EQUIPMENT_COL) {
        if (aValue != null) {
          String sport = (String) getValueAt(rowIndex, SPORT_COL);
          String equip = (String) aValue;
          sports.put(sport, equip);
          fireTableDataChanged();
        }
      }
    }

    @Override
    public boolean isCellEditable(int rowIndex, int columnIndex) {
      return columnIndex == EQUIPMENT_COL;
    }
  }
  private CustomModel model;

  public SSCCE() {
    super();

    model = new CustomModel();
    viewTable = new JXTable(model);
    editTable = new JXTable(model);
    editTable.addHighlighter(new ColorHighlighter(new HighlightPredicate() {
      @Override
      public boolean isHighlighted(Component renderer, ComponentAdapter adapter) {
        return adapter.isEditable();
      }
    }, Color.GREEN.brighter(), Color.BLACK));

    JPanel panelLeft = new JPanel(new BorderLayout(0, 10));
    panelLeft.add(new JLabel("Editable"), BorderLayout.NORTH);
    panelLeft.add(new JScrollPane(editTable));
    JPanel panelRight = new JPanel(new BorderLayout(0, 10));
    panelRight.add(new JLabel("How to make non-editable?"), BorderLayout.NORTH);
    panelRight.add(new JScrollPane(viewTable));

    splitPane = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT, panelLeft, panelRight);
    add(splitPane);
  }

  public static void main(String args[]) {
    JFrame frame = new JFrame("One Model | Two Views");
    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    frame.getContentPane().add(new SSCCE(), BorderLayout.CENTER);
    frame.setSize(360, 240);
    frame.setVisible(true);
  }
}

SwingX支持在视图层上配置可编辑性。 无需触摸模型,并根据需要对其进行编辑:

viewTable = new JXTable(model);
viewTable.setEditable(false);
editTable = new JXTable(model);

创建一个WrapperTableModel ,它将所有调用委派给内部TableModel但从isCellEditable().返回false isCellEditable().

将第一个可编辑模型设置为table1,并将包装模型设置为table2中的包装模型(保留对第一个模型的引用)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM