繁体   English   中英

用于模板匹配的OpenCV阅读图像

[英]OpenCV Reading Image for Template Matching

我在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());
}

我的问题:我想比较从mysql数据库检索到的2张图像。

Highgui.imread(); 

此方法需要一个String,但是我想提供InputStream或OutputStream文件...就像我说的那样,我不想在本地计算机上保存2000个图像。 我也欢迎其他方式。

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

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

谢谢阅读。

我在这里找到了对这个家伙的荣誉,他是我的英雄:)完美工作,如果您想要原始颜色而不是灰度的图像,则应将Highgui.IMREAD_GRAYSCALE更改为Highgui.IMREAD_UNCHANGED以获取更多信息, 请检查

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM