opencv3_java 摄像头图形图像检测DetectObjectsCamera videoioVideoCapture

原创 2017年05月31日 21:29:02

摄像头图形图像检测DetectObjectsCamera videoioVideoCapture


package opencv_java_demo;

import javax.swing.*;

import java.awt.*;
import java.awt.image.BufferedImage;

import org.opencv.core.*;
import org.opencv.core.Point;
import org.opencv.videoio.VideoCapture;
import org.opencv.videoio.Videoio;
import org.opencv.objdetect.CascadeClassifier;
import org.opencv.imgproc.Imgproc;

public class DetectObjectsCamera extends JPanel {
	private static final long serialVersionUID=1L;
	
	private BufferedImage mImg;
	
	private static Mat dobj(CascadeClassifier objDetector, Mat src){
		Mat dst=src.clone();
		
		MatOfRect objDetections=new MatOfRect();
		
		objDetector.detectMultiScale(dst, objDetections);
		
		if(objDetections.toArray().length<=0){
			return src;
		}
		for(Rect rect:objDetections.toArray()){
			Imgproc.rectangle(dst, new Point(rect.x,rect.y), new Point(rect.x+rect.width,rect.y+rect.height), new Scalar(0,0,255),2);
		}
		return dst;
	}
	
	public void paintComponent(Graphics g){
		if(mImg!=null){
			g.drawImage(mImg, 0, 0, mImg.getWidth(),mImg.getHeight(),this);
		}
	}
	
	public static void main(String[] args) {
		try{
			System.loadLibrary(Core.NATIVE_LIBRARY_NAME);
			
			CascadeClassifier objDetector=new CascadeClassifier("data/lbpcascades/lbpcascade_frontalface.xml");
			
			Mat capImg=new Mat();
			VideoCapture capture=new VideoCapture(0);
			int height =(int)capture.get(Videoio.CV_CAP_PROP_FRAME_HEIGHT);
			int width =(int)capture.get(Videoio.CV_CAP_PROP_FRAME_WIDTH);
			if(height==0||width==0){
				throw new Exception("camera not found");
			}
			
			JFrame frame=new JFrame("camera");
			frame.setDefaultCloseOperation(WindowConstants.DISPOSE_ON_CLOSE);
			DetectObjectsCamera panel=new DetectObjectsCamera();
			frame.setContentPane(panel);
			frame.setVisible(true);
			frame.setSize(width+frame.getInsets().left+frame.getInsets().right, height+frame.getInsets().top+frame.getInsets().bottom);
			
			MatToBufferedImage matToBi=new MatToBufferedImage();
			
			Mat dst=new Mat();
			while(frame.isShowing()){
				capture.read(capImg);
				dst=dobj(objDetector,capImg);
				panel.mImg=matToBi.mat2BI(dst);
				panel.repaint();
			}
			capture.release();
		}catch(Exception e){
			System.out.println("例外"+e);
		}finally{
			System.out.println("--done--");
		}
	}
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

【Java Opencv系列】4.3读取摄像头并显示

4.3读取摄像头并显示 本节内容代码下载链接:http://download.csdn.net/detail/u012343179/9797850 在testOpencv项目的imageIO包...

使用JavaCV/OpenCV抓取并存储摄像头图像

本程序通过JFrame实时显示本机摄像头图像,并将图像存储到一个缓冲区,当用户用鼠标点击JFrame中任何区域时,显示抓取图像的简单动画,同时保存缓冲区的图像到磁盘文件中。点击JFrame关闭按钮可以...
  • ljsspace
  • ljsspace
  • 2011年08月19日 16:11
  • 22260

javacv开发详解之1:调用本机摄像头视频(建议使用javaCV1.3版本)

javacv开发包是用于支持java多媒体开发的一套开发包,可以适用于本地多媒体(音视频)调用以及音视频,图片等文件后期操作(图片修改,音视频解码剪辑等等功能),这里我只使用最简单的本地摄像头调用来演...
  • eguid_1
  • eguid_1
  • 2016年06月13日 17:54
  • 19365

opencv3_java 启动摄像头 VideoCapture Videoio

启动摄像头 VideoCapture Videoio package opencv_java_demo; import javax.swing.JFrame; import javax.s...

OpenCV 获取摄像头并显示摄像头视频

OpenCV 获取摄像头,新建窗口显示摄像头视频 结合Leaning OpenCV 第二个例子 显示一个视屏文件  写了一下 获取摄像头的代码为并且创建窗口显示的代码为:#include "stdaf...
  • Augusdi
  • Augusdi
  • 2013年04月05日 23:25
  • 81804

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

基于OpenCV读取摄像头进行人脸检测和人脸识别

前段时间使用OpenCV的库函数实现了人脸检测和人脸识别,笔者的实验环境为VS2010+OpenCV2.4.4,OpenCV的环境配置网上有很多,不再赘述。检测的代码网上很多,记不清楚从哪儿copy的...

javacpp-opencv图像处理3:使用opencv原生方法遍历摄像头设备及调用(增加实时帧率计算方法)

鉴于很多同学反馈目前javacv采集摄像头存在几点问题 1、javacv采集摄像头帧率很低 2、javacv中的摄像头采集依赖opencv的capture采集器,获取的Mat没有及时释放,容易内存溢出...
  • eguid_1
  • eguid_1
  • 2017年02月27日 11:49
  • 2266

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

OpenCV 数字验证码识别

更新后代码下载链接在此!!!点我下载 本文针对OpenCv入门人士,因为我也不是专门做图像的,只是为了完成一次模式识别的小作业。主要完成的功能就是自动识别图片中的数字,图片包括正常图片,有划痕图像和...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:opencv3_java 摄像头图形图像检测DetectObjectsCamera videoioVideoCapture
举报原因:
原因补充:

(最多只允许输入30个字)