[英]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对象?
谢谢阅读。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.