我在Java中使用OpenCV,使用eclipse进行开发,并且以这种方式读取图像以进行模板匹配。

String inFile = "C:/image.png";
Mat img = Highgui.imread(inFile);

很好,但是我的图像不在本地计算机中。我应该比较mysql数据库中服务器上的2000个镜像。将2000张图像保存到我的计算机,然后读取它们没有任何意义。

所以我需要的是Highgui.imread(inFile)读取图像:Highgui.imread(Image inImage)或Highgui.imread(File inFile),我找不到要编辑/修改的Java源代码。我需要以某种方式将来自mysql数据库的图像转换为Mat类型以进行比较(模板匹配)...

更多信息:我有一个带有以下列的mysql表:ID,名称,描述,Image1,Image2。 Image1和2列的类型为“mediumblob”,当右键单击“MySQL Workbench”中的Image1或Image2列时,我选择“在编辑器中打开值”,然后有3个标签;二进制,文本,图像,在图像处我的图像完美显示。图片类型为png。最后,我想比较Image1和Image2。 Image2是inFile,Image1是templateFile。

对不起,我以为我的问题很清楚。我将尝试改写它。
我有一台本地计算机和一台服务器。图像存储在服务器上的mysql数据库中。我想从我的本地计算机运行一个应用程序,该应用程序检索/访问服务器上的2张图像,然后通过OpenCV模板匹配比较它们。 Afaik您无法使用/server/home/user/mysql/image_table/mypicture.png访问mysql的列,由于“guneykayim”的建议,我正在写这篇文章。因此,我打算如何检索图像,还没有尝试过,但是计划是:
Blob imageBlob = resultSet.getBlob(yourBlobColumnIndex);
InputStream binaryStream = imageBlob.getBinaryStream(0, imageBlob.length());

要么
InputStream binaryStream = resultSet.getBinaryStream(yourBlobColumnIndex);

要么
try{
    Class.forName(driverName);
    con = DriverManager.getConnection(url+dbName,userName,password);
    Statement stmt = con.createStatement();
    ResultSet rs = stmt.executeQuery("select image from image");
    int i = 0;
    while (rs.next()) {
        InputStream in = rs.getBinaryStream(1);
        OutputStream f = new FileOutputStream(new File("test"+i+".jpg"));
        i++;
        int c = 0;
        while ((c = in.read()) > -1) {
            f.write(c);
        }
        f.close();
        in.close();
    }
}catch(Exception ex){
    System.out.println(ex.getMessage());
}

我的问题:我想比较2张图像,我从mysql数据库中检索到。
Highgui.imread();

此方法期望使用字符串,但我想给 InputStream 或OutputStream文件...就像我说的那样,我不想在本地计算机上保存2000张图像。我也欢迎其他方式。

最终最简单的措辞:如何在存储在mysql数据库中的2张图像上使用Java OpenCV的模板匹配。

换句话说,如何将InputStream对象转换为Mat对象?

谢谢阅读。

最佳答案

我找到了这个人的here荣誉,他是我的英雄:)完美运行,如果您想要原始颜色而不是灰度的图像,则应将Highgui.IMREAD_GRAYSCALE更改为Highgui.IMREAD_UNCHANGED以获取更多信息check

10-08 07:17
查看更多