返回顶部
首页 > 资讯 > 精选 >如何使用OpenCV与JVM实现矩阵处理图像
  • 709
分享到

如何使用OpenCV与JVM实现矩阵处理图像

2023-06-26 05:06:53 709人浏览 八月长安
摘要

这篇文章给大家分享的是有关如何使用OpenCV与JVM实现矩阵处理图像的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。submat(int rowStart, int rowEnd, int colStart, i

这篇文章给大家分享的是有关如何使用OpenCVJVM实现矩阵处理图像的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

submat(int rowStart, int rowEnd, int colStart, int colEnd) 函数的返回值是一个矩阵对象。内容是原图的子矩阵或子区域。

如何使用OpenCV与JVM实现矩阵处理图像

首先我们用imread来读取图片,然后输出矩阵对象本身的一些信息

import org.opencv.core.CvType;import org.opencv.core.Mat;import org.opencv.core.Core;import org.opencv.core.MatOfInt;import org.opencv.imGCodecs.Imgcodecs;import origami.Origami;public class HelloCv {    public static void main(String[] args) throws Exception {        System.loadLibrary(Core.NATIVE_LIBRARY_NAME);        Mat mat = Imgcodecs.imread("./images/test.jpg",Imgcodecs.IMREAD_GRAYSCALE);        System.out.println(mat);    }}

如何使用OpenCV与JVM实现矩阵处理图像

由于这个矩阵是原始图片,所以它的isSubmat是false。

现在我们使用submat函数的第一种形式,输入参数是每一行和每一列的起始和终止值。

图片裁剪

import org.opencv.core.CvType;import org.opencv.core.Mat;import org.opencv.core.Core;import org.opencv.core.MatOfInt;import org.opencv.imgcodecs.Imgcodecs;import origami.Origami;public class HelloCv {    public static void main(String[] args) throws Exception {        System.loadLibrary(Core.NATIVE_LIBRARY_NAME);        Mat mat = Imgcodecs.imread("C:/HWKJ/ZRQ/OpenCv/matrixcv/images/test.jpg");        System.out.println(mat);        Mat submat = mat.submat(200, 240, 300, 350);        System.out.println(submat);    }}

如何使用OpenCV与JVM实现矩阵处理图像

这里注意submat里的尺寸,尺寸根据原图的尺寸,超出原图的尺寸会报错,报错如下

如何使用OpenCV与JVM实现矩阵处理图像

然后我们输出裁剪的图片。

那么如何确认你想要截取图片的区域范围呢?也就是说怎么确定这四个参数的填写?我们以下图为例

如何使用OpenCV与JVM实现矩阵处理图像

截取后的图片

如何使用OpenCV与JVM实现矩阵处理图像

另外两种submat方式

Range(int row,int column)

row:宽开始结束范围

column:高开始结束范围

Mat submat2 = mat.submat(new Range(20,300),new Range(100,500));Imgcodecs.imwrite("./images/output2.png",submat2);

Rect(int x, int y,int width, int height)

x:横坐标

y:纵坐标

width :宽

height:高

Mat submat3 = mat.submat(new Rect(0,200,100,100));//submat3.setTo(new Scalar(255,0,0));//将图片绘制为蓝色Imgcodecs.imwrite("./images/output3.png",submat3);

如何使用OpenCV与JVM实现矩阵处理图像

打开setTo如下:

如何使用OpenCV与JVM实现矩阵处理图像

Imgcodecs.imwrite("./images/blurtest.png",mat);

如何使用OpenCV与JVM实现矩阵处理图像

完整代码:

import org.opencv.core.CvType;import org.opencv.core.Scalar;import org.opencv.core.Mat;import org.opencv.core.Rect;import org.opencv.core.Range;import org.opencv.core.Core;import org.opencv.core.Size;import org.opencv.core.MatOfInt;import org.opencv.imgcodecs.Imgcodecs;import org.opencv.imgproc.Imgproc;import origami.Origami;public class HelloCv {    public static void main(String[] args) throws Exception {        System.loadLibrary(Core.NATIVE_LIBRARY_NAME);        Mat mat = Imgcodecs.imread("C:/HWKJ/ZRQ/OpenCv/matrixcv/images/test.jpg");        System.out.println(mat);        Mat submat = mat.submat(200, 400, 200, 550);        //System.out.println(submat);        Imgcodecs.imwrite("./images/output.png",submat);        Mat submat2 = mat.submat(new Range(20,300),new Range(100,500));        Imgcodecs.imwrite("./images/output2.png",submat2);        Mat submat3 = mat.submat(new Rect(0,200,400,200));        submat3.setTo(new Scalar(255,0,0));        Imgcodecs.imwrite("./images/output3.png",submat3);        //Imgproc.blur(submat,submat,new Size(25.0,25.0));        Imgcodecs.imwrite("./images/blurtest.png",mat);    }}

图片模糊处理

import org.opencv.core.CvType;import org.opencv.core.Mat;import org.opencv.core.Core;import org.opencv.core.Size;import org.opencv.core.MatOfInt;import org.opencv.imgcodecs.Imgcodecs;import org.opencv.imgproc.Imgproc;import origami.Origami;public class HelloCv {    public static void main(String[] args) throws Exception {        System.loadLibrary(Core.NATIVE_LIBRARY_NAME);        Mat mat = Imgcodecs.imread("C:/HWKJ/ZRQ/OpenCv/matrixcv/images/test.jpg");        System.out.println(mat);        Mat submat = mat.submat(200, 400, 200, 550);        //System.out.println(submat);        //Imgcodecs.imwrite("./images/output.png",submat);        Imgproc.blur(submat,submat,new Size(25.0,25.0));        System.out.println("after:"+mat);        Imgcodecs.imwrite("./images/blurtest.png",mat);    }}

如何使用OpenCV与JVM实现矩阵处理图像

子矩阵生成矩阵

setTo和copyTo是OpenCv中两个非常重要的函数。

setTo可以将一个矩阵中的所有像素设置为指定的颜色

copyTo可以将一个已有的矩阵复制到另一个矩阵之中。

第一个颜色值代表蓝色的深度,第二个值代表绿色的深度,最后一个值代表红色的深度。

//获取红绿蓝Scalar Red = new Scalar(0,0,255);Scalar Green = new Scalar(0,255,0);Scalar Blue = new Scalar(255,0,0);

我们把这些颜色当作RGB的补充色。因此把其他通道设置为最大值255,主通道设置为0。蓝绿色是红色的补充色,所以红色值通道被设为0,而另外两个通道为255;

定义蓝绿色、品红色和黄色

Scalar cyan = new Scalar(255,255,0);Scalar  magena= new Scalar(255,0,255);Scalar yellow = new Scalar(0,255,255);

下面我们使用setTo将子矩阵设置为给定的Scalar颜色

    private void setColors(Mat mat ,boolean comp,int row){      for (int i = 0; i <3 ; i++) {          Mat sub = mat.submat(row*100,row*100+100,i*100,i*100+100);          if(comp){             //RGB             if (i==0){                 sub.setTo(Red);             }if (i==1){                  sub.setTo(Green);              }if (i==2){                  sub.setTo(Blue);              }          }else {              //cmy              if (i==0){                  sub.setTo(cyan);              }if (i==1){                  sub.setTo(magena);              }if (i==2){                  sub.setTo(yellow);              }          }      }  }

接下来,我们创建一个包含三个颜色通道矩阵,并且填充它的第一行和第二行

完整代码:

import org.opencv.core.CvType;import org.opencv.core.Scalar;import org.opencv.core.Mat;import org.opencv.core.Rect;import org.opencv.core.Range;import org.opencv.core.Core;import org.opencv.core.Size;import org.opencv.core.MatOfInt;import org.opencv.imgcodecs.Imgcodecs;import org.opencv.imgproc.Imgproc;import origami.Origami;public class HelloCv1 {public static  Scalar Red = new Scalar(0,0,255);public static   Scalar Green = new Scalar(0,255,0);public static   Scalar Blue = new Scalar(255,0,0);public static   Scalar cyan = new Scalar(255,255,0);public static   Scalar  magena= new Scalar(255,0,255);public static   Scalar yellow = new Scalar(0,255,255);    public static void main(String[] args) throws Exception {        System.loadLibrary(Core.NATIVE_LIBRARY_NAME);        Mat mat = new Mat(200,300,CvType.CV_8UC3);        setColors(mat,false,1);        setColors(mat,true,0);        Imgcodecs.imwrite("./images/rgbcmy.png",mat);    }    static void setColors(Mat mat ,boolean comp,int row){      for (int i = 0; i <3 ; i++) {          Mat submat = mat.submat(row*100,row*100+100,i*100,i*100+100);          if(comp){             //RGB             if (i==0){               submat.setTo(Red);             }if (i==1){               submat.setTo(Green);              }if (i==2){                submat.setTo(Blue);              }          }else {              //cmy              if (i==0){                submat.setTo(cyan);              }if (i==1){                submat.setTo(magena);              }if (i==2){                submat.setTo(yellow);              }          }      }  }}

如何使用OpenCV与JVM实现矩阵处理图像

从图片子矩阵生成矩阵

首先创建一个大小为200x200的矩阵和子矩阵:一个是主矩阵的上部,一个是主矩阵的下部

int width = 200,height = 200;Mat mat1 = new Mat(height,width,CvType.CV_8UC3);Mat top = mat.submat(0,height/2,0,width);Mat bottom = mat.submat(height/2,height,0,width);

然后加载一个图片以创建另一个小矩阵,并把它的大小调整为上部(或下部)的子矩阵大小。这里会引入Imgproc类中的resize函数。

完整代码:

import org.opencv.core.CvType;import org.opencv.core.Scalar;import org.opencv.core.Mat;import org.opencv.core.Rect;import org.opencv.core.Range;import org.opencv.core.Core;import org.opencv.core.Size;import org.opencv.core.MatOfInt;import org.opencv.imgcodecs.Imgcodecs;import org.opencv.imgproc.Imgproc;import origami.Origami;public class HelloCv1 {public static  Scalar Red = new Scalar(0,0,255);public static   Scalar Green = new Scalar(0,255,0);public static   Scalar Blue = new Scalar(255,0,0);public static   Scalar cyan = new Scalar(255,255,0);public static   Scalar  magena= new Scalar(255,0,255);public static   Scalar yellow = new Scalar(0,255,255);    public static void main(String[] args) throws Exception {        System.loadLibrary(Core.NATIVE_LIBRARY_NAME);        int width = 200,height = 300;        Mat mat1 = new Mat(height,width,CvType.CV_8UC3);        Mat top = mat1.submat(0,height/2,0,width);        Mat bottom = mat1.submat(height/2,height,0,width);        Mat small = Imgcodecs.imread("./images/test.jpg");        Imgproc.resize(small,small,top.size());        small.copyTo(top);        small.copyTo(bottom);        Imgcodecs.imwrite("./images/matofpictures.png",mat1);    }

注意:设置大小的步骤很关键。复制能够成功,是因为小矩阵和子矩阵的大小是完全相同的,因此复制的时候没有出现任何问题

如何使用OpenCV与JVM实现矩阵处理图像

感谢各位的阅读!关于“如何使用OpenCV与JVM实现矩阵处理图像”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

--结束END--

本文标题: 如何使用OpenCV与JVM实现矩阵处理图像

本文链接: https://lsjlt.com/news/307000.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何使用OpenCV与JVM实现矩阵处理图像
    这篇文章给大家分享的是有关如何使用OpenCV与JVM实现矩阵处理图像的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。submat(int rowStart, int rowEnd, int colStart, i...
    99+
    2023-06-26
  • 基于OpenCV与JVM实现矩阵处理图像
    目录图片裁剪图片模糊处理子矩阵生成矩阵从图片子矩阵生成矩阵submat(int rowStart, int rowEnd, int colStart, int colEnd) 函数的...
    99+
    2024-04-02
  • 基于OpenCv与JVM实现加载保存图像功能(JAVA 图像处理)
    目录加载图片保存图片加载图片 openCv有一个名imread的简单函数,用于从文件中读取图像 imread 函数位于Imgcodecs类的同名包中。 加载图片代码 import ...
    99+
    2024-04-02
  • Opencv图像处理中如何使用mask
    这篇文章将为大家详细讲解有关Opencv图像处理中如何使用mask,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。图像基本运算图像的基本运算有很多种,比如两幅图像可以相加、相减、相乘、相除、位运算、平方根、...
    99+
    2023-06-14
  • 基于OpenCv与JVM如何实现加载保存图像功能
    今天给大家介绍一下基于OpenCv与JVM如何实现加载保存图像功能。,文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。加载图片openCv有一个名imread的简...
    99+
    2023-06-26
  • Python+OpenCV如何实现在图像上绘制矩形
    小编给大家分享一下Python+OpenCV如何实现在图像上绘制矩形,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!代码import copyimport cv2import numpy&nbs...
    99+
    2023-06-29
  • 如何使用OpenCV实现图像增强
    本篇内容介绍了“如何使用OpenCV实现图像增强”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!本期将介绍如何通过图像处理从低分辨率/模糊/低...
    99+
    2023-06-20
  • 如何在Python中使用OpenCV实现图像平滑处理操作
    这期内容当中小编将会给大家带来有关如何在Python中使用OpenCV实现图像平滑处理操作,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。什么是图像平滑处理在尽量保留图像原有信息的情况下,过滤掉图像内部的噪...
    99+
    2023-06-15
  • 如何用OpenCV reshape函数实现矩阵元素序列化
    本篇内容主要讲解“如何用OpenCV reshape函数实现矩阵元素序列化”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何用OpenCV reshape函数实现矩阵元素序列...
    99+
    2023-06-21
  • OpenCV+Qt实现图像处理操作
    本文实例为大家分享了OpenCV+Qt实现图像处理操作的具体代码,供大家参考,具体内容如下 一、目标 Qt界面实现 雪花屏 高斯模糊 中值滤波 毛玻璃 灰度化 XY方向模糊 双边模糊...
    99+
    2022-11-13
    OpenCV Qt 图像处理
  • C#如何实现opencv截取旋转矩形区域图像
    本篇内容主要讲解“C#如何实现opencv截取旋转矩形区域图像”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#如何实现opencv截取旋转矩形区域图像”吧!前言:最近在工程中需要用到截取Rot...
    99+
    2023-06-07
  • C++ opencv图像处理使用cvtColor实现颜色转换
    目录前言源码效果图代码颜色空间转换代码前言 在我们读取图像时通常会用到imread()函数,里面flags可以决定通道数,来得到我们想要的图像,比如: -1 按解码得到的方式读入图像...
    99+
    2024-04-02
  • python OpenCV图像直方图如何处理
    这篇“python OpenCV图像直方图如何处理”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“python&nb...
    99+
    2023-07-02
  • 详解如何使用OpenCV和像素处理图像灰度化
    目录数字图像处理图像读入和通道结构像素级灰度化处理不同算法之间的效果比较图像灰度化的输出和显示数字图像处理 在数字图像处理中,我们经常需要将彩色图像转换为灰度图像,以便应用各种算法。...
    99+
    2023-05-17
    OpenCV 像素图像灰度化 OpenCV 图像处理
  • OpenCV图像形态学如何处理
    这篇文章主要讲解了“OpenCV图像形态学如何处理”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“OpenCV图像形态学如何处理”吧!1.腐蚀操作从下面代码中可以看到有三幅腐蚀程度不同的图,腐...
    99+
    2023-07-05
  • C#如何使用OpenCV剪切图像中的圆形和矩形
    这篇文章主要介绍“C#如何使用OpenCV剪切图像中的圆形和矩形”,在日常操作中,相信很多人在C#如何使用OpenCV剪切图像中的圆形和矩形问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#如何使用OpenC...
    99+
    2023-06-07
  • 如何使用Python的OpenCV库处理图像和视频
    目录介绍计算机视觉OpenCV应用:安装使用 OpenCV 处理图像1. 从文件中读取图像2. 调整图像大小:3. 旋转图像4. 翻转图像:5. 重写图像6. 裁剪图像7. 绘制形状...
    99+
    2024-04-02
  • 使用numpy实现矩阵的翻转与旋转
    使用numpy实现矩阵的翻转与旋转?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。numpy.flip(m, axis=None)Reverse the orde...
    99+
    2023-06-15
  • OpenCV中图像如何实现分割与修复
    这篇文章给大家分享的是有关OpenCV中图像如何实现分割与修复的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。背景图像分割本质就是将前景目标从背景中分离出来。在当前的实际项目中,应用传统分割的并不多,大多是采用深度...
    99+
    2023-06-29
  • OpenCV图像处理之实现图像膨胀腐蚀操作
    目录一.形态学操作概念二.形态学操作-膨胀膨胀函数API接口结构元素的API函数接口三.形态学操作—腐蚀腐蚀原理腐蚀函数API接口图像处理效果一.形态学操作概念 图像形态...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作