OpenCV Java imshow()的实现

喜欢用OpenCV和Java的人往往会使用官网提供的OpenCV的包,OpenCV除了用于图像处理,本身也是一个优秀的数学库。而且对于Java而言,配置方便,编写容易,可扩展性也强。Java效率虽然低,但是核心计算部分仍然是C写的。
然而对于初学者来说,一个非常重要的函数——imshow(Mat m, string window)在Java中被阉割掉了,这使我们观察图像输出时只能通过imwrite()保存为图片后再查看,用起来非常不爽。因此,我动手自己实现了一个java类,实现了该函数以及waitKey(int time)两个函数,主要使用了java的swing框架,以及obj的wait()和notify()函数实现waitKey(int time)。其中,

函数名 参数 功能
ImageGui(Mat m, String window) 要显示的图像和窗口名 构造
ig.imshow() 显示图片
ig.waitKey(int time); 需要暂停的毫秒数 参数为0则阻塞线程且等待用户输入,不为0则等待指定毫秒数后继续运行,并返回键盘输入值

实现效果如下。
这里写图片描述
是不是和C++中的imshow()一样好用呢?
下面是源码。
1. ImageGui.java

package com.meng.highgui;

import java.awt.Graphics;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.awt.event.KeyListener;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;

import javax.imageio
运动跟踪是计算机视觉领域中的一个重要应用,可以用于视频监控、运动分析、行为识别等领域。Java 作为一种常用的编程语言,也可以使用 OpenCV 库来实现运动跟踪。 下面是一个简单的 Java OpenCV 运动跟踪示例: 首先,需要导入 OpenCV 库: ```java import org.opencv.core.Core; import org.opencv.core.Mat; import org.opencv.core.Point; import org.opencv.core.Rect; import org.opencv.core.Scalar; import org.opencv.core.Size; import org.opencv.highgui.HighGui; import org.opencv.video.BackgroundSubtractorMOG2; import org.opencv.videoio.VideoCapture; ``` 然后,获取视频输入源: ```java VideoCapture cap = new VideoCapture("video.mp4"); ``` 接着,创建一个 BackgroundSubtractorMOG2 对象,用于背景建模和前景检测: ```java BackgroundSubtractorMOG2 mog = Video.createBackgroundSubtractorMOG2(); ``` 之后,循环读取每一帧图像,进行前景检测: ```java Mat frame = new Mat(); Mat fgMask = new Mat(); Rect rect = new Rect(); while (cap.read(frame)) { mog.apply(frame, fgMask); Core.rectangle(frame, new Point(rect.x, rect.y), new Point(rect.x + rect.width, rect.y + rect.height), new Scalar(255, 0, 0), 2); HighGui.imshow("Motion Detection", frame); HighGui.waitKey(30); } ``` 在每一帧图像中,通过 apply 方法对前景进行检测,然后通过 rectangle 方法在图像中绘制前景框。 最后,使用 imshow 方法显示运动跟踪结果,通过 waitKey 方法等待用户输入,直到用户关闭窗口。 完整代码如下: ```java import org.opencv.core.Core; import org.opencv.core.Mat; import org.opencv.core.Point; import org.opencv.core.Rect; import org.opencv.core.Scalar; import org.opencv.core.Size; import org.opencv.highgui.HighGui; import org.opencv.video.BackgroundSubtractorMOG2; import org.opencv.video.Video; import org.opencv.videoio.VideoCapture; public class MotionDetection { public static void main(String[] args) { System.loadLibrary(Core.NATIVE_LIBRARY_NAME); VideoCapture cap = new VideoCapture("video.mp4"); BackgroundSubtractorMOG2 mog = Video.createBackgroundSubtractorMOG2(); Mat frame = new Mat(); Mat fgMask = new Mat(); Rect rect = new Rect(); while (cap.read(frame)) { mog.apply(frame, fgMask); Core.rectangle(frame, new Point(rect.x, rect.y), new Point(rect.x + rect.width, rect.y + rect.height), new Scalar(255, 0, 0), 2); HighGui.imshow("Motion Detection", frame); HighGui.waitKey(30); } cap.release(); HighGui.destroyAllWindows(); } } ``` 注意:在使用 OpenCV 库时,需要将 opencv 的动态链接库文件添加到路径中。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值