我有以下代码:
class Files {
private static String files;
private static String duration;
private static String status;
public Files(String files, String duration, String status) {
this.files = files;
this.duration = duration;
this.status = status;
}
public static String getfiles() {
return files;
}
public static String getduration() {
return duration;
}
public static String getstatus() {
return status;
}
}
Map<Files, String> hmap = new HashMap<Files,String>();
private void AddFiles(String addfile,String addurr,String addstatus, String addpath){
Files f = new Files(addfile, addurr, addstatus);
hmap.put(f, addpath);
}
final JTable table = new JTable();
table.setBounds(26, 27, 664, 274);
table.setModel(new MyTableModel());
所以我创建了一个新的表和重写"getValueAt"。
class MyTableModel extends AbstractTableModel {
@Override
public int getColumnCount() {
// TODO Auto-generated method stub
return 0;
}
@Override
public int getRowCount() {
// TODO Auto-generated method stub
return 0;
}
@Override
public Object getValueAt(int rowIndex, int columnIndex) {
switch (columnIndex) {
case 0:
return Files.getfiles();
case 1:
return Files.getduration();
case 2:
return Files.getstatus();
default:
throw new IndexOutOfBoundsException();
}
}
}
但是我不能从HashMap的类"Files"中加载变量到JTable中。有人能告诉我我哪里做错了吗?我基本上已经被困了3天了,真的很感谢你的帮助。
有很多地方不对。
首先,为什么文件中的所有字段和方法都是静态的?这意味着一个Files实例实际上根本没有状态,所有的Files实例共享相同的文件、持续时间和状态。这些字段和方法当然应该是实例字段和方法(也就是说,你必须删除static
修饰符)。
然后,你的模型通过返回0来实现getColumnCount()
和getRowCount()
。这意味着您的表包含0行和0列。因此,如果你不打算在表中包含任何值,我真的不明白使用表的意义。
另一方面,getValueAt()
方法意味着所有行都包含相同的值,因为无论rowIndex
参数包含什么,您都返回相同的值。
最后,你说你有一个Map<Files, String>
,但你没有说这个映射和表之间的关系应该是什么。您不会在模型的任何地方使用这个映射,而且由于代码本身没有意义,因此很难猜测映射实际包含什么,以及表实际应该显示什么。
我需要一个键/值对。
作为参考,EnvTableTest
从现有的Map
构造一个AbstractTableModel
。它使用map的keySet()
作为第0列,并使用每个键来获取该行的值。
Ok刚刚找到解决方案:
private final Map<Files, String> list = new LinkedHashMap<Files,String>();
class MyTableModel extends AbstractTableModel {
private String[] columnNames = {"File","Duration","Status"};
public void addElement(String addfile,String addurr,String addstatus, String addpath) {
Files f = new Files(addfile, addurr, addstatus);
list.put(f, addpath); // edit
fireTableRowsInserted(list.size()-1, list.size()-1);
}
@Override
public int getColumnCount() {
return columnNames.length;
}
@Override
public int getRowCount() {
return list.size();
}
@Override
public String getColumnName(int col) {
return columnNames[col];
}
@Override
public Object getValueAt(int rowIndex, int columnIndex) {
List<Entry<Files,String>> randAccess = new ArrayList<Entry<Files,String>>(list.entrySet());
switch (columnIndex) {
case 0:
return randAccess.get(rowIndex).getKey().getfiles();
case 1:
return randAccess.get(rowIndex).getKey().getduration();
case 2:
return randAccess.get(rowIndex).getKey().getstatus();
default:
throw new IndexOutOfBoundsException();
}
}
}