我面临同样的问题。目前新的 3.4(和 3.4.1)Highgui API 中没有 imshow() 方法。我找到了一些解决方法,这不是我们想要的,但它至少可以轻松地显示 OpenCV Mat。你可以试试:
Highgui.selectROI(Imgcodecs.imread("img.jpg"));
Highgui.waitKeyEx();
selectROI() 方法打开带有所需图像的新 JFrame 窗口,您可以在其中选择感兴趣的区域,该区域在窗口关闭后返回。诀窍是您不必选择任何 ROI 并将其仅用作图像查看器。
目前最好的方法仍然是制作自己的从 Mat 到 BufferedImage 或到 Image(JavaFX) 对象的转换方法,然后显示自定义窗口。我目前正在为我自己的项目使用以下方法。只是给你一个想法。希望能帮助到你!
public static BufferedImage convertMatToBufferedImage(Mat m){
byte [] buffer = new byte[m.channels()*m.cols()*m.rows()];
m.get(0, 0, buffer);
BufferedImage image = new BufferedImage(m.cols(), m.rows(), BufferedImage.TYPE_BYTE_GRAY);
final byte[] targetPixels = ((DataBufferByte) image.getRaster().getDataBuffer()).getData();
System.arraycopy(buffer, 0, targetPixels, 0, buffer.length);
return image;
}
public static Image convertMatToImage(Mat m) {
if (m == null || m.width() == 0 || m.height() == 0) return null;
Mat resultMat = m.clone();
WritableImage image = new WritableImage(m.width(), m.height());
byte[] data = new byte[m.cols() * m.rows() * 3]; // * 3 because Image needs 3 bytes per pixel even if grayscale
if (resultMat.channels() == 1)
Imgproc.cvtColor(resultMat, resultMat, Imgproc.COLOR_GRAY2RGB);
else if (resultMat.channels() == 3)
Imgproc.cvtColor(resultMat, resultMat, Imgproc.COLOR_BGR2RGB);
resultMat.get(0, 0, data);
image.getPixelWriter().setPixels(0, 0, m.width(), m.height(), PixelFormat.getByteRgbInstance(), data, 0, m.width() * 3);
return image;
}