【发布时间】:2017-05-07 06:19:25
【问题描述】:
我知道这将是一个重复的问题,但我在我的案例中找不到答案。我已经使用数据库中的数据成功创建了我的JTable。在我的JTable 中,其中一列包含图像。我试图用getColumnClass(int column) 显示这些图像,但我不明白如何使用这种方法并且没有好的教程我发现我可以理解......如何在我的JTable 中显示这些图像?
import java.sql.*;
import java.util.*;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.DefaultTableCellRenderer;
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
class BurgerData extends JFrame
{
JTable BurgerList;
public BurgerData()
{
setSize(800,800);
setLayout(new FlowLayout());
setVisible(true);
try
{
Class.forName("com.mysql.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/image","root","");
Statement stmnt = con.createStatement();
ResultSet rs = stmnt.executeQuery("SELECT * FROM `icon`");
ResultSetMetaData rsmetadata = rs.getMetaData();
int col = rsmetadata.getColumnCount();
DefaultTableModel dtm = new DefaultTableModel();
Vector<String> col_name = new Vector<String>();
Vector<Object> row_data = new Vector<Object>();
for(int i=1;i<=col;i++)
{
col_name.addElement(rsmetadata.getColumnName(i));
}
dtm.setColumnIdentifiers(col_name);
while(rs.next())
{
row_data = new Vector<Object>();
for(int i=1;i<=col;i++)
{
row_data.addElement(rs.getObject(i));
}
dtm.addRow(row_data);
}
BurgerList = new JTable( dtm )
{
public Class getColumnClass(int column)
{
return getValueAt(0, column).getClass();
}
};
BurgerList.setModel(dtm);
add(BurgerList);
}
catch(SQLException e)
{
System.out.println("Unknown Error");
}
catch(Exception eg)
{
System.out.println("Unknown Error");
}
}
public static void main(String args[])
{
BurgerData n = new BurgerData();
}
}
【问题讨论】:
-
分而治之,创建一个带有 1 或 2 列的
JTable的简单类,在其中硬编码图像(如 here 所示),然后如果正确,请尝试拉来自数据库的图像如果这不起作用,那么您知道数据库出了什么问题,为了获得更好的帮助,请尽快发布有效的minimal reproducible example,我们可以在没有数据库连接的情况下复制粘贴,因为这个问题不相关给它。此外,在将所有元素添加到框架之前,您正在使框架可见 -
我已经将图像(来自数据库)作为对象插入到我的 JTable“BurgerList”中。但是当我将 JTable 添加到框架时,一切正常,但图像没有显示(它显示了一些像这样的字符串:[B@6b4455f0])
-
我在您的代码中没有看到任何
ImageIcon实例,您的数据应该是ImageIcon类型而不是Object然后
标签: java mysql database swing jtable