我正在为我的项目构建一个应用程序来管理商店的产品。我面临一个问题,我真的需要你的想法来解决它。
我使用 DefaultTableCellRenderer 在主屏幕的产品基本信息表中成功显示图像。但我只能为所有产品显示 1 张图片。每个产品都有不同的图像,所以我需要在产品基本信息 JTable 中为每一行显示不同的图像。
这是我的一些作品。
这是我的 DefaultTableCellRenderer 扩展类:
class ImageRenderer extends DefaultTableCellRenderer {
JLabel lbl = new JLabel();
ImageIcon icon = new ImageIcon("./src/comicbookandgamingzone/productpicture/NFS-Shift-2-Unleashed-Limited-Edition-Revealed-2.jpg");
public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected,
boolean hasFocus, int row, int column) {
lbl.setText((String) value);
lbl.setIcon(icon);
lbl.setBounds(0, 0, 100, 100);
return lbl;
}
}
自定义产品基本信息表模型
class ProductTableModel extends AbstractTableModel{
String[] colname = {"ID","Picture","Name","Cost","In stock"};
ArrayList<Product> list;
public ProductTableModel(ArrayList<Product> prolist){
this.list=prolist;
}
public String getColumnName(int col){
return colname[col];
}
@Override
public int getRowCount() {
//throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
return list.size();
}
@Override
public int getColumnCount() {
//throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
return colname.length;
}
@Override
public Object getValueAt(int rowIndex, int columnIndex) {
//throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
switch(columnIndex){
case 0: return list.get(rowIndex).ID;
case 1: return list.get(rowIndex).Picture;
case 2: return list.get(rowIndex).Name;
case 3: return list.get(rowIndex).Cost;
case 4: return list.get(rowIndex).Stock;
default : return null;
}
...并在显示结果方法中
public void ShowResult(ArrayList<Product> list){
tabProduct.setModel(new ProductTableModel(list));
tabProduct.getColumnModel().getColumn(1).setCellRenderer(new ImageRenderer());
tabProduct.setRowHeight(100);
}
这是我的 SQL 创建表脚本。我将产品图像的路径存储在数据库中
create table ProductDetails
(
ProductID int identity (1,1) not null,
ProductTypeID int foreign key references ProductType(TypeID),
ProductName text,
ProductPicture text,
ProductCost float,
ProductPoint int,
ProductStock int,
primary key (ProductID)
)
非常感谢。