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--");
		}
	}
}


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

相关文章推荐

opencv3_java 提取图像的RGB三原色分割图像Split Core.split

提取图像的RGB三原色分割图像Split Core.split package opencv_java_demo; import java.util.List; import org.open...

OpenCV学习(三)使用mask添加水印

上一篇学习了ROI的用法,本节接着上一篇,继续添加水印,但是要去掉讨厌的水印的背景。 关于添加水印,网上有一篇讲的很清楚: http://www.cnblogs.com/mfryf/archi...

精选:深入理解 Docker 内部原理及网络配置

网络绝对是任何系统的核心,对于容器而言也是如此。Docker 作为目前最火的轻量级容器技术,有很多令人称道的功能,如 Docker 的镜像管理。然而,Docker的网络一直以来都比较薄弱,所以我们有必要深入了解Docker的网络知识,以满足更高的网络需求。

opencv3_java 添加mask掩码 AddMask

添加mask掩码 AddMask package opencv_java_demo; import org.opencv.core.*; import org.opencv.imgcode...

我的OpenCV学习笔记(四):给图像加上水印效果

当两幅图像尺寸相同时,给图像加上水印效果其实很简单,就是简单的将一幅图像加到另一幅图像上(两幅图像乘以一定的系数就可以控制相加的效果): #include #include using name...

opencv3_java 图像上加水印TextOnImg Rect

图像上加水印Trimming Rect package opencv_java_demo; import org.opencv.core.*; import org.opencv.imgcode...

Opencv实现盲水印技术(三)——傅里叶变换算法及盲水印实现

本文将简单介绍对傅里叶变换的理解,以及使用opencv实现盲水印。

opencv3_java akaze的特征提取与图像匹配 akaze

akaze的特征提取与图像匹配 akaze package opencv_java_demo; import org.opencv.core.*; import org.opencv.im...

opencv3_java 图像的Scalar标量合成 AddScalar

图像的Scalar标量合成 AddScalar package opencv_java_demo; import org.opencv.core.*; import org.opencv....
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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