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

摄像头图形图像检测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--");
		}
	}
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值