java基于OpenCv图像处理
2021/10/28 17:14:16
本文主要是介绍java基于OpenCv图像处理,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
java基于openCv图像处理
本文使用javaCV封装后的OpenCv
<dependency> <groupId>org.bytedeco</groupId> <artifactId>javacv-platform</artifactId> <version>1.5.5</version> </dependency>
1、图片读取、保存
在openCv中有一函数用于读取图片 imread(),保存图片imwrite()
由于javaCv二次封装,所以函数目录和openCv目录不同,javaCv函数在opencv_imgcodecs中,因为javaCv目前没有完整的文档所以只能查看源代码一个个找,后面自己使用别的功能时是需要自己看源代码的,反正挺苦逼的。
1.1、图片读取
public static void main(String[] args) { Mat mat = opencv_imgcodecs.imread("D:\\leiningen\\cat.jpg"); ImageViewer imageViewer = new ImageViewer(mat); imageViewer.imshow(); }
ImageViewer 我着实没有找到在javaCv中相应的类,不过找到一个opencv_highgui.imshow()方法但是用不了,我看了里面的注释需要搭配线程使用反正我没搞出来。所以我也把这个类ImageViewer源代码贴出来吧(我放在最后了)。
1.2、图片保存
public static void main(String[] args) { Mat mat = opencv_imgcodecs.imread("D:\\leiningen\\cat.jpg"); opencv_imgcodecs.imwrite("D:\\leiningen\\cat1.png",mat); }
补充:
从代码中可以看到陌生的对象Mat,这个是矩阵的意思,这个对象是openCv的核心,简单介绍一下。
首先我们来创建一个矩阵开始。
public static void main(String[] args) { //创建RGB颜色当前是蓝色 Scalar scalar = new Scalar(255, 0, 0, 0); // R G B 0 //Size:width、height Mat mat = new Mat(new Size(100,200), opencv_core.CV_8UC3,scalar); ImageViewer imageViewer = new ImageViewer(mat); imageViewer.imshow(); }
上面代码片先是读取在保存,唯一区别就是保存时用的格式使用的是png,不需要进行图像编码和令人发狂的字节操作
按照官方说法:
JPEG可以使用CV_IMWRITE_JPEG_OUALITY参数,参数值范围在0 ~ 100 (值越大图像质量越高)默认值是95。
PNG,可以使用0 ~ 9 作为压缩程度的参数值,值越大图像质量越小,压缩时间越长,默认值是3.
package com.cloud.iot.util; import org.bytedeco.javacpp.BytePointer; import org.bytedeco.opencv.opencv_core.Mat; import javax.swing.*; import java.awt.*; import java.awt.image.BufferedImage; import java.awt.image.DataBufferByte; import java.nio.ByteBuffer; public class ImageViewer { private JLabel imageView; private Mat image; private String windowName; public ImageViewer(Mat image) { this.image = image; } public ImageViewer(Mat image, String windowName) { this.image = image; this.windowName = windowName; } /** * 窗口展示 */ public void imshow() { setSystemLookAndFeel(); Image loadedImage = toBufferedImage(image); JFrame frame = createJFrame(windowName, image.arrayWidth(), image.arrayHeight()); imageView.setIcon(new ImageIcon(loadedImage)); frame.pack(); frame.setLocationRelativeTo(null); frame.setVisible(true); frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);// 用户点击窗口关闭 } private void setSystemLookAndFeel() { try { UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName()); } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (InstantiationException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); } catch (UnsupportedLookAndFeelException e) { e.printStackTrace(); } } private JFrame createJFrame(String windowName, int width, int height) { JFrame frame = new JFrame(windowName); imageView = new JLabel(); final JScrollPane imageScrollPane = new JScrollPane(imageView); imageScrollPane.setPreferredSize(new Dimension(width, height)); frame.add(imageScrollPane, BorderLayout.CENTER); frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE); return frame; } private Image toBufferedImage(Mat matrix) { int type = BufferedImage.TYPE_BYTE_GRAY; if (matrix.channels() > 1) { type = BufferedImage.TYPE_3BYTE_BGR; } ByteBuffer byteBuffer = matrix.getByteBuffer(); byte[] b = new byte[byteBuffer.remaining()]; byteBuffer.get(b,0,b.length); BufferedImage image = new BufferedImage(matrix.cols(), matrix.rows(), type); final byte[] targetPixels = ((DataBufferByte) image.getRaster().getDataBuffer()).getData(); System.arraycopy(b, 0, targetPixels, 0, b.length); return image; } }
今天就到这·······································································over
这篇关于java基于OpenCv图像处理的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-01基于Python+Vue开发的医院门诊预约挂号系统
- 2024-10-01基于Python+Vue开发的旅游景区管理系统
- 2024-10-01RestfulAPI入门指南:打造简单易懂的API接口
- 2024-10-01初学者指南:了解和使用Server Action
- 2024-10-01Server Component入门指南:搭建与配置详解
- 2024-10-01React 中使用 useRequest 实现数据请求
- 2024-10-01使用 golang 将ETH账户的资产平均分散到其他账户
- 2024-10-01JWT用户校验课程:从入门到实践
- 2024-10-01Server Component课程入门指南
- 2024-09-30Dnd-Kit学习:新手快速入门指南