Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/62.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 在JTable中显示图像_Java_Mysql_Database_Swing_Jtable - Fatal编程技术网

Java 在JTable中显示图像

Java 在JTable中显示图像,java,mysql,database,swing,jtable,Java,Mysql,Database,Swing,Jtable,我知道这将是一个重复的问题,但我找不到我的案件的答案。我已使用数据库中的数据成功创建了我的JTable。在myJTable中,其中一列包含图像。我曾尝试使用getColumnClass(int-column)显示这些图像,但我不知道如何使用此方法&我发现我无法理解任何好的教程。。。如何在我的JTable中显示这些图像 import java.sql.*; import java.util.*; import javax.swing.table.DefaultTableModel; import

我知道这将是一个重复的问题,但我找不到我的案件的答案。我已使用数据库中的数据成功创建了我的
JTable
。在my
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();
}
}
import java.sql.*;
导入java.util.*;
导入javax.swing.table.DefaultTableModel;
导入javax.swing.table.DefaultTableCellRenderer;
导入javax.swing.*;
导入java.awt.*;
导入java.awt.event.*;
类数据扩展JFrame
{
JTable列表;
公共数据()
{
设置大小(800800);
setLayout(新的FlowLayout());
setVisible(真);
尝试
{
Class.forName(“com.mysql.jdbc.Driver”);
Connection con=DriverManager.getConnection(“jdbc:mysql://localhost:3306/image“,”根“,”);
语句stmnt=con.createStatement();
ResultSet rs=stmnt.executeQuery(“从“图标”中选择*”;
ResultSetMetaData rsmetadata=rs.getMetaData();
int col=rsmetadata.getColumnCount();
DefaultTableModel dtm=新的DefaultTableModel();
向量col_name=新向量();
向量行_数据=新向量();
对于(int i=1;i

我已经插入了图像

它显示一些字符串,如:[B@6b4455f0])

JTable
没有图像的默认呈现程序,因此您可以看到图像的
toString()
表示形式

相反,您需要使用
Image
创建
ImageIcon
JTable
将使用JLabel来呈现
图标

例如:

因此,您不能只将所有对象复制到表模型中。您需要检查对象是否为图像,然后创建图像图标并将其添加到模型中

另一种解决方案是为Image类创建自定义渲染器(然后您可以直接将对象复制到模型中)。有关详细信息,请参阅上的Swing教程中的部分


我已经插入了图像

它显示一些字符串,如:[B@6b4455f0])

JTable
没有图像的默认呈现程序,因此您可以看到图像的
toString()
表示形式

相反,您需要使用
Image
创建
ImageIcon
JTable
将使用JLabel来呈现
图标

例如:

因此,您不能只将所有对象复制到表模型中。您需要检查对象是否为图像,然后创建图像图标并将其添加到模型中


另一种解决方案是为Image类创建自定义渲染器(然后您可以直接将对象复制到模型)。有关详细信息,请参阅Swing教程中的部分。

分而治之,创建一个简单的类,其中包含一列或两列的
JTable
,您可以在其中硬编码图像(如图所示),如果这样做是正确的,那么尝试从数据库中提取图像,如果这样做不起作用,那么您就知道问题出在数据库中,为了更好地帮助您尽快发布一个有效的帖子,我们可以复制粘贴w/o DB connections,因为这个问题与此无关。此外,在将所有元素添加到itI之前,您正在使您的帧可见ady将图像(来自数据库)作为对象插入我的JTable“BurgerList”中。但当我将JTable添加到帧中时,一切正常,但图像没有显示(它显示一些字符串,如:[B@6b4455f0] )我在你的代码中没有看到任何
ImageIcon
实例,你的数据应该是
ImageIcon
类型,而不是
Object
然后分而治之,用
JTable
创建一个简单的类,其中有1列或2列,你可以硬编码一个图像(如图所示),如果这样做是正确的,那么尝试从数据库中提取图像,如果这样做不起作用,那么您就知道问题出在数据库中,为了更好地帮助您尽快发布一个有效的帖子,我们可以复制粘贴w/o DB connections,因为这个问题与此无关。此外,在将所有元素添加到itI之前,您正在使您的帧可见ady将图像(来自数据库)作为对象插入我的JTable“BurgerList”中。但当我将JTable添加到帧中时,一切正常,但图像没有显示(它显示一些字符串,如:[B@6b4455f0] )我在你的代码中没有看到任何
ImageIcon
实例,你的数据应该是
ImageIcon
类型,而不是
Object
类型。哦,这很有帮助。我知道哪一列得到了图像,所以,如果我用vector做的话,我的vector类型是什么?@Hasan,你看过我提供的链接中的代码了吗?其中使用了什么数据类型链接?是的,我以前在搜索答案时也看到过你的链接。我想我必须使用ImageIcon类型column@Hasan,您之前的评论询问的是向量,而不是列。这是两件不同的事情。向量包含对象,因为您可以为每行设置字符串、整数、图像图标、getColumnClass return为每行的列指定适当的值。哦,这很有用。我知道哪一列得到了图像,所以,如果我使用vector-我的vector类型是什么?@Hasan,你看过我提供的链接中的代码了吗?该链接中使用了什么数据类型?是的,我以前在搜索答案时也看到过你的链接。我想我看到了我必须为该特定对象使用ImageIcon类型column@Hasan,您之前的评论询问的是向量,而不是列。这是两件不同的事情。向量包含对象,因为您可以为每行设置String、Integer和ImageIcon,getColumnClass会为每行的列返回适当的值。
row_data.addElement(rs.getObject(i));