详解OpenCV For Java环境搭建与功能演示

作者:gloomyfish 时间:2023-05-27 09:13:50 

OpenCV概述

OpenCV做为功能强大的计算机视觉开源框架,包含了500多个算法实现,而且还在不断增加,其最新版本已经更新到3.2。其SDK支持Android与Java平台开发,对于常见的图像处理需求几乎都可以满足,理应成为广大Java与Android程序员的首先的图像处理框架。Java中使用OpenCV的配置及其简单,可以毫不客气的说几乎是零配置都可以。

一:配置

配置引入OpenCV相关jar包,首先要下载OpenCV的自解压版本,下载地址: http://opencv.org/opencv-3-2.html

然后拉到网页的最下方,下载Windows自解压开发包

详解OpenCV For Java环境搭建与功能演示

下载好了双击解压缩之后找到build路径,显示如下:

详解OpenCV For Java环境搭建与功能演示

双击打开Java文件夹,

详解OpenCV For Java环境搭建与功能演示

里面有一个jar直接导入到Eclipse中的新建项目中去, 然后把x64里面的dll文件copy到Eclipse中使用的Java JDK bin和jre/bin目录下面即可。环境就配置好啦,简单吧!配置好的最终项目结构:

详解OpenCV For Java环境搭建与功能演示

二:加载图像与像素操作

读入一张图像 -, 一句话搞定


Mat src = Imgcodecs.imread(imageFilePath);
if(src.empty()) return;

将Mat对象转换为BufferedImage对象


public BufferedImage conver2Image(Mat mat) {
int width = mat.cols();
int height = mat.rows();
int dims = mat.channels();
int[] pixels = new int[width*height];
byte[] rgbdata = new byte[width*height*dims];
mat.get(0, 0, rgbdata);
BufferedImage image = new BufferedImage(width, height,
      BufferedImage.TYPE_INT_ARGB);
int index = 0;
int r=0, g=0, b=0;
for(int row=0; row<height; row++) {
 for(int col=0; col<width; col++) {
  if(dims == 3) {
   index = row*width*dims + col*dims;
   b = rgbdata[index]&0xff;
   g = rgbdata[index+1]&0xff;
   r = rgbdata[index+2]&0xff;
   pixels[row*width+col] = ((255&0xff)<<24) |
   ((r&0xff)<<16) | ((g&0xff)<<8) | b&0xff;
  }
  if(dims == 1) {
   index = row*width + col;
   b = rgbdata[index]&0xff;
   pixels[row*width+col] = ((255&0xff)<<24) |
   ((b&0xff)<<16) | ((b&0xff)<<8) | b&0xff;
  }
 }
}
setRGB( image, 0, 0, width, height, pixels);
return image;
}

将BufferedImage对象转换为Mat对象


public Mat convert2Mat(BufferedImage image) {
int width = image.getWidth();
int height = image.getHeight();
Mat src = new Mat(new Size(width, height), CvType.CV_8UC3);
int[] pixels = new int[width*height];
byte[] rgbdata = new byte[width*height*3];
getRGB( image, 0, 0, width, height, pixels );
int index = 0, c=0;
int r=0, g=0, b=0;
for(int row=0; row<height; row++) {
 for(int col=0; col<width; col++) {
  index = row*width + col;
  c = pixels[index];
  r = (c&0xff0000)>>16;
  g = (c&0xff00)>>8;
  b = c&0xff;

index = row*width*3 + col*3;
  rgbdata[index] = (byte)b;
  rgbdata[index+1] = (byte)g;
  rgbdata[index+2] = (byte)r;
 }
}

src.put(0, 0, rgbdata);
return src;
}

特别要说明一下,BufferedImage与Mat的RGB通道顺序是不一样,正好相反,在Mat对象中三通道的顺序为BGR而在BufferedImage中为RGB。

从Mat中读取全部像素(其中image为Mat类型数据)


int width = image.cols();
int height = image.rows();
int dims = image.channels();
byte[] data = new byte[width*height*dims];
image.get(0, 0, data);

遍历像素操作与保存改变


int index = 0;
int r=0, g=0, b=0;
for(int row=0; row<height; row++) {
for(int col=0; col<width*dims; col+=dims) {
 index = row*width*dims + col;
 b = data[index]&0xff;
 g = data[index+1]&0xff;
 r = data[index+2]&0xff;

r = 255 - r;
 g = 255 - g;
 b = 255 - b;

data[index] = (byte)b;
 data[index+1] = (byte)g;
 data[index+2] = (byte)r;
}
}
image.put(0, 0, data);

保存Mat对象为图像文件 - 一句话可以搞定


Imgcodecs.imwrite(filePath, src);

OpenCV代码运行与测试

调节明暗程度 - 亮度降低

详解OpenCV For Java环境搭建与功能演示

调节明暗程度 - 亮度提升

详解OpenCV For Java环境搭建与功能演示

高斯模糊

详解OpenCV For Java环境搭建与功能演示

锐化

详解OpenCV For Java环境搭建与功能演示

梯度

详解OpenCV For Java环境搭建与功能演示

灰度化

详解OpenCV For Java环境搭建与功能演示

上述效果完整Java代码如下:


package com.gloomyfish.opencvdemo;

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.core.Size;
import org.opencv.imgproc.Imgproc;

public class ImageFilters {

/** - 反色处理 - */
public Mat inverse(Mat image) {
 int width = image.cols();
 int height = image.rows();
 int dims = image.channels();
 byte[] data = new byte[width*height*dims];
 image.get(0, 0, data);

int index = 0;
 int r=0, g=0, b=0;
 for(int row=0; row<height; row++) {
  for(int col=0; col<width*dims; col+=dims) {
   index = row*width*dims + col;
   b = data[index]&0xff;
   g = data[index+1]&0xff;
   r = data[index+2]&0xff;

r = 255 - r;
   g = 255 - g;
   b = 255 - b;

data[index] = (byte)b;
   data[index+1] = (byte)g;
   data[index+2] = (byte)r;
  }
 }

image.put(0, 0, data);
 return image;
}

public Mat brightness(Mat image) {
 // 亮度提升
 Mat dst = new Mat();
 Mat black = Mat.zeros(image.size(), image.type());
 Core.addWeighted(image, 1.2, black, 0.5, 0, dst);
 return dst;
}

public Mat darkness(Mat image) {
 // 亮度降低
 Mat dst = new Mat();
 Mat black = Mat.zeros(image.size(), image.type());
 Core.addWeighted(image, 0.5, black, 0.5, 0, dst);
 return dst;
}

public Mat gray(Mat image) {
 // 灰度
 Mat gray = new Mat();
 Imgproc.cvtColor(image, gray, Imgproc.COLOR_BGR2GRAY);
 return gray;
}

public Mat sharpen(Mat image) {
 // 锐化
 Mat dst = new Mat();
 float[] sharper = new float[]{0, -1, 0, -1, 5, -1, 0, -1, 0};
 Mat operator = new Mat(3, 3, CvType.CV_32FC1);
 operator.put(0, 0, sharper);
 Imgproc.filter2D(image, dst, -1, operator);
 return dst;
}

public Mat blur(Mat image) {
 // 高斯模糊
 Mat dst = new Mat();
 Imgproc.GaussianBlur(image, dst, new Size(15, 15), 0);
 return dst;
}

public Mat gradient(Mat image) {
 // 梯度
 Mat grad_x = new Mat();
 Mat grad_y = new Mat();
 Mat abs_grad_x = new Mat();
 Mat abs_grad_y = new Mat();

Imgproc.Sobel(image, grad_x, CvType.CV_32F, 1, 0);
 Imgproc.Sobel(image, grad_y, CvType.CV_32F, 0, 1);
 Core.convertScaleAbs(grad_x, abs_grad_x);
 Core.convertScaleAbs(grad_y, abs_grad_y);
 grad_x.release();
 grad_y.release();
 Mat gradxy = new Mat();
 Core.addWeighted(abs_grad_x, 0.5, abs_grad_y, 0.5, 10, gradxy);
 return gradxy;
}
}

可以说简单到哭,此外OpenCV For Java支持各种的图像处理包括形态学操作,二值图像分析、图像特征检测与识别、模板匹配、直方图相关功能等等。常见的机器学习算法与图像分析方法。可以说是功能最强大的图像处理SDK与开发平台之一,本人继续发掘分享!

特别注意

在调用之前,一定要加上这句话


System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

目的是加载OpenCV API相关的DLL支持,没有它是不会正确运行的。以上代码与功能实现是基于JDK8 64位与OpenCV 3.2版本。

来源:https://blog.csdn.net/jia20003/article/details/68944486

标签:OpenCV,Java,环境搭建
0
投稿

猜你喜欢

  • C#获取汉字字符串拼音首字母的方法

    2022-09-06 14:01:12
  • 简单了解Android性能优化方向及相关工具

    2022-10-15 19:10:54
  • Android使用gallery和imageSwitch制作可左右循环滑动的图片浏览器

    2021-08-31 22:49:45
  • C#中异步回调函数用法实例

    2023-01-05 13:10:53
  • 探讨:如何使用委托,匿名方法对集合进行万能排序

    2022-06-15 02:17:23
  • Java构造代码块,静态代码块原理与用法实例分析

    2023-11-03 09:03:45
  • MyBatis使用动态SQL标签的小陷阱

    2023-09-11 04:42:57
  • Java 使用 HttpClient 发送 GET请求和 POST请求

    2023-07-23 07:56:13
  • java中两个byte数组实现合并的示例

    2021-10-16 20:26:48
  • Android Gradle依赖管理、去除重复依赖、忽略的方式

    2023-06-08 16:07:12
  • Java时间转换成unix时间戳的方法

    2022-06-09 14:39:36
  • Android使用百度地图出现闪退及定位时显示蓝屏问题的解决方法

    2023-08-01 11:57:39
  • 详解Android App中使用VideoView来实现视频播放的方法

    2022-05-01 00:20:11
  • Java文件上传与文件下载实现方法详解

    2023-11-20 12:28:45
  • Java基于socket实现简易聊天室实例

    2021-10-30 00:24:56
  • java实现顺序结构线性列表的函数代码

    2023-01-28 13:49:31
  • C#文件路径操作详细总结

    2021-06-06 04:07:41
  • 使用C++程序获取新浪行情数据的方法

    2022-06-16 13:14:35
  • C#实现带搜索功能的ComboBox

    2022-08-29 06:52:48
  • Unity 如何获取鼠标停留位置下的物体

    2023-09-05 17:17:14
  • asp之家 软件编程 m.aspxhome.com