国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - VS2017+Qt5+Opencv3.4調用攝像頭拍照并存儲

VS2017+Qt5+Opencv3.4調用攝像頭拍照并存儲

2021-11-09 14:42zuoyou_yi C/C++

本文主要介紹了VS2017+Qt5+Opencv3.4調用攝像頭拍照并存儲,實現了視頻,拍照,保存這三個功能。具有一定的參考價值,感興趣的小伙伴們可以參考一下

1. Qt的ui界面,找著畫就好

VS2017+Qt5+Opencv3.4調用攝像頭拍照并存儲

VS2017+Qt5+Opencv3.4調用攝像頭拍照并存儲

2.頭文件直接貼出,之后有時間慢慢解釋吧

#pragma once
 
#include <QtWidgets/QWidget>
#include "ui_camaraGet.h"
 
#ifndef CAMARAGET_H
#define CAMARAGET_H
 
#include <opencv2corecore.hpp>
#include <QWidget>
#include <QImage>
#include <QTimer>     // 設置采集數據的間隔時間
 
 
#include <QGraphicsScene>  
#include <QGraphicsView>  
 
#include <highgui/highgui_c.h>  //包含opencv庫頭文件
 
#include <opencv2imgprocimgproc.hpp>
#include <opencv2corecore.hpp>
#include <opencv2highguihighgui.hpp>  //opencv申明
 
#include <opencv/cv.hpp>
using namespace cv;
 
namespace Ui {
	class camaraGet;
}
 
class camaraGet : public QWidget
{
	Q_OBJECT
 
public:
	explicit camaraGet(QWidget *parent = 0);
	~camaraGet();
 
private slots:
	void openCamara();      // 打開攝像頭
	void getFrame();       // 讀取當前幀信息
	void closeCamara();     // 關閉攝像頭。
	void takingPictures();  // 拍照
 
private:
	Ui::camaraGet ui;
	QTimer    *timer;
	QImage    *imag;
	CvCapture *cam;// 視頻獲取結構, 用來作為視頻獲取函數的一個參數
	IplImage  *frame;
	VideoCapture capture1;
	Mat showimage;
	QImage Mat2Qimage(Mat cvImg);
 
//	camaraGet(QWidget * parent);
	//申請IplImage類型指針,就是申請內存空間來存放每一幀圖像
};
 
#endif // CAMARAGET_H

3.源文件

#pragma once
 
#include <QtWidgets/QWidget>
#include "ui_camaraGet.h"
 
#ifndef CAMARAGET_H
#define CAMARAGET_H
 
#include <opencv2corecore.hpp>
#include <QWidget>
#include <QImage>
#include <QTimer>     // 設置采集數據的間隔時間
#include "camaraGet.h"
#include<stdlib.h>
#include<random>
using namespace cv;
using namespace std;
 
 
 
 
 
camaraGet::camaraGet(QWidget *parent):
	QWidget(parent)
{
    ui.setupUi(this);
	connect(ui.pushButton, SIGNAL(clicked()), this, SLOT(openCamara()));
	connect(ui.pushButton_2, SIGNAL(clicked()), this, SLOT(takingPictures()));
	connect(ui.pushButton_3, SIGNAL(clicked()), this, SLOT(closeCamara()));
	setWindowTitle(tr("Main Window"));
 
	timer = new QTimer(this);
	imag = new QImage();
	connect(timer, SIGNAL(timeout()), this, SLOT(getFrame()));//超時就讀取當前攝像頭信息
}
camaraGet::~camaraGet()
{
 
}
 
void camaraGet::openCamara()
{
	capture1.open(1);                                            //打開攝像頭,從攝像頭中獲取視頻
	timer->start(10);
	
}
 
void camaraGet::getFrame() {
	capture1 >> showimage;
	QImage imag = Mat2Qimage(showimage);
 
	ui.label_2->setScaledContents(true);
	ui.label_2->setPixmap(QPixmap::fromImage(imag));
}
 
void camaraGet::closeCamara()
{
	timer->stop();
	ui.label->clear();
	capture1.release();
}
 
string strRand(int length) {			// length: 產生字符串的長度
	char tmp;							// tmp: 暫存一個隨機數
	string buffer;						// buffer: 保存返回值
 
	
	random_device rd;					// 產生一個 std::random_device 對象 rd
	default_random_engine random(rd());	// 用 rd 初始化一個隨機數發生器 random
 
	for (int i = 0; i < length; i++) {
		tmp = random() % 36;	
		if (tmp < 10) {			
			tmp += "0";
		}
		else {				
			tmp -= 10;
			tmp += "A";
		}
		buffer += tmp;
	}
	return buffer;
}
 
 
void camaraGet::takingPictures()
{
	capture1.open(1);
	capture1 >> showimage;
	QImage img = Mat2Qimage(showimage);
	ui.label->setScaledContents(true);
	ui.label->setPixmap(QPixmap::fromImage(img));
 
	string writePath = "../tempPhoto/";
	string name;
	int i = 0;
	name = writePath + strRand(4) + ".jpg";
	imwrite(name, showimage);
	i++;
 
}
 
 
QImage camaraGet::Mat2Qimage(Mat cvImg)
{
	// 8-bits unsigned, NO. OF CHANNELS = 1
	if (cvImg.type() == CV_8UC1)
	{
		QImage image(cvImg.cols, cvImg.rows, QImage::Format_Indexed8);
		// Set the color table (used to translate colour indexes to qRgb values)
		image.setColorCount(256);
		for (int i = 0; i < 256; i++)
		{
			image.setColor(i, qRgb(i, i, i));
		}
		// Copy input Mat
		uchar *pSrc = cvImg.data;
		for (int row = 0; row < cvImg.rows; row++)
		{
			uchar *pDest = image.scanLine(row);
			memcpy(pDest, pSrc, cvImg.cols);
			pSrc += cvImg.step;
		}
		return image;
	}
	// 8-bits unsigned, NO. OF CHANNELS = 3
	else if (cvImg.type() == CV_8UC3)
	{
		// Copy input Mat
		const uchar *pSrc = (const uchar*)cvImg.data;
		// Create QImage with same dimensions as input Mat
		QImage image(pSrc, cvImg.cols, cvImg.rows, cvImg.step, QImage::Format_RGB888);
		return image.rgbSwapped();
	}
	else if (cvImg.type() == CV_8UC4)
	{
//		qDebug() << "CV_8UC4";
		// Copy input Mat
		const uchar *pSrc = (const uchar*)cvImg.data;
		// Create QImage with same dimensions as input Mat
		QImage image(pSrc, cvImg.cols, cvImg.rows, cvImg.step, QImage::Format_ARGB32);
		return image.copy();
	}
	else
	{
//		qDebug() << "ERROR: Mat could not be converted to QImage.";
		return QImage();
	}
}
 
 
#include <QGraphicsScene>  
#include <QGraphicsView>  
 
#include <highgui/highgui_c.h>  //包含opencv庫頭文件
 
#include <opencv2imgprocimgproc.hpp>
#include <opencv2corecore.hpp>
#include <opencv2highguihighgui.hpp>  //opencv申明
 
#include <opencv/cv.hpp>
using namespace cv;
 
namespace Ui {
	class camaraGet;
}
 
class camaraGet : public QWidget
{
	Q_OBJECT
 
public:
	explicit camaraGet(QWidget *parent = 0);
	~camaraGet();
 
private slots:
	void openCamara();      // 打開攝像頭
	void getFrame();       // 讀取當前幀信息
	void closeCamara();     // 關閉攝像頭。
	void takingPictures();  // 拍照
 
private:
	Ui::camaraGet ui;
	QTimer    *timer;
	QImage    *imag;
	CvCapture *cam;// 視頻獲取結構, 用來作為視頻獲取函數的一個參數
	IplImage  *frame;
	VideoCapture capture1;
	Mat showimage;
	QImage Mat2Qimage(Mat cvImg);
 
//	camaraGet(QWidget * parent);
	//申請IplImage類型指針,就是申請內存空間來存放每一幀圖像
};
 
#endif // CAMARAGET_H

4.運行效果

VS2017+Qt5+Opencv3.4調用攝像頭拍照并存儲

完整項目下載:QtWidgetsApplication2.rar

到此這篇關于VS2017+Qt5+Opencv3.4調用攝像頭拍照并存儲的文章就介紹到這了,更多相關Qt5 Opencv3.4拍照并存儲內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/zuoyou_yi/article/details/117338900

延伸 · 閱讀

精彩推薦
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
主站蜘蛛池模板: 国产精品国产三级国产aⅴ中文 | 久久精品香蕉 | 国产视频二区 | 中文字幕亚洲欧美日韩在线不卡 | 一区中文字幕 | 综合久久网 | 欧美精品一区二区三区蜜桃视频 | 日韩在线播放一区二区 | 国产成人精品久久 | 一区二区三区国产 | 国产综合久久 | 中文精品一区二区 | 黄色国产片 | 精品久久av| 国产 日韩 欧美 在线 | 91精品国产91久久久久久 | 久久99国产精品久久99果冻传媒 | 视频一区中文字幕 | 丁香综合| 欧洲一级毛片 | 香蕉视频三级 | 日韩欧美国产精品 | 国产精品久久久久久久久久久天堂 | 夫妻午夜影院 | 精品一二三区 | 综合五月| 国产精品99久久免费观看 | 99精品久久 | 国产乱码精品一品二品 | 一区二区福利 | 黄色免费网站 | 日韩欧美国产一区二区 | 国产精品久久久久久久美男 | 日本特黄特色aaa大片免费 | 中文字幕在线视频观看 | 成人午夜在线 | 国产精品69毛片高清亚洲 | 欧美久久久久久久久久久久久久 | 日韩在线 | 久久com | 中文字幕不卡 |