Qt5摄像头

在pro中加入两个qmake:    QT += multimedia         QT += multimediawidgets

 本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

头文件

#include <QCamera>  //导入摄像头类

#include <QCameraInfo>  //摄像头信息类

#include <QCameraViewfinder>  //取景器类

#include <QCameraImageCapture>  //捕获类

#include <QCameraViewfinderSettings>  //摄像头设置类
  QList<QCameraInfo> list;
    list = QCameraInfo::availableCameras(); //返回摄像头信息列表
    qDebug()<<list.count();//返回摄像头数目
    qDebug()<<list.size();//返回摄像头数目
    QString name=list.at(0).deviceName();//获取设备名称
    //0表示第一个
    qDebug()<<name;
    if(name=="@device:pnp:\\\\?\\usb#vid_09da&pid_2691&mi_00#8&280dfc5d&0&0000#{65e8773d-8f56-11d0-a3b9-00a0c9223196}\\global"){
        qDebug()<<"存在此摄像头";
        camera=new QCamera(list.at(0));  //调用指定摄像头
        //如果不指定设备,将使用默认摄像头
    }


    QString desc=list.at(0).description();  //返回描述信息
    //"A4tech FHD 1080P PC Camera"
    qDebug()<<desc;
    QString defa=QCameraInfo::defaultCamera().description();//查看系统默认摄像头
    //"A4tech FHD 1080P PC Camera"
    qDebug()<<defa;

    qDebug()<<"物理位置:"<<list.at(0).position();
    //QCamera::UnspecifiedPosition=0    位置未指定或未知
    //QCamera::BackFace=1   摄像头位于系统硬件的背面。例如,在移动设备上,这意味着它位于屏幕的另一侧
    //QCamera::FrontFace=2  摄像头位于系统硬件的正面。例如,在移动设备上,这意味着它与屏幕位于同一侧

    camera->setCaptureMode(QCamera::CaptureStillImage);//设置捕获模式
    /*
    QCamera::CaptureStillImage=0x01   捕捉静止帧
    QCamera::CaptureViewfinder=0      仅配置为显示取景器
    QCamera::CaptureVideo=0x02        配置为视频捕获
*/

    int cm=camera->captureMode(); //返回当前捕获模式
    qDebug()<<"当前捕获模式"<<cm;
    //1

    bool bl=camera->isCaptureModeSupported(QCamera::CaptureStillImage);//是否支持指定的模式
    qDebug()<<bl;

实例一

win.h

#ifndef WIN_H
#define WIN_H

#include <QWidget>
#include <QMainWindow>
#include <QCamera>
#include <QCameraViewfinder>
#include <QCameraImageCapture>
#include <QPushButton>
#include <QLabel>

class win : public QWidget
{
    Q_OBJECT

public:
    win(QWidget *parent = nullptr);
    ~win();

private:
    QCamera *camera; //摄像头对象
    QCameraViewfinder *viewfinder;//取景器
    QCameraImageCapture *imageCapture;//捕获对象

    QPushButton* buttonCapture;
    QLabel* ImageCapture;

private slots:
    void captureImage();
    void displayImage(int,QImage);


};
#endif // WIN_H
#include "win.h"

win::win(QWidget *parent)
    : QWidget(parent)
{
    buttonCapture=new QPushButton("捕获",this);
    buttonCapture->move(700,400);

    ImageCapture=new QLabel("显示图片",this);
    ImageCapture->resize(320,240);
    ImageCapture->move(700,0);

    camera=new QCamera(this);
    viewfinder=new QCameraViewfinder(this);//创建取景器
    //取景器用来预览

    viewfinder->resize(640,480);
    viewfinder->move(0,0);
    //这个取景器的0点不是窗口的0点  ??

    imageCapture=new QCameraImageCapture(camera);//捕获对象

    camera->setViewfinder(viewfinder);//设置取景器
    //start()开启摄像头后,取景器会自动从摄像头读取图片,但imageCapture没有捕获
    camera->start();
    //ui->ImageCapture->setScaledContents(true);//图片随着标签大小而变化
    connect(imageCapture, SIGNAL(imageCaptured(int,QImage)), this, SLOT(displayImage(int,QImage)));
    //imageCapture捕获到新图时,会发出imageCaptured(int,QImage)信号
    //int id 第几次捕获;QImage捕获的图像

    connect(buttonCapture, SIGNAL(clicked()), this, SLOT(captureImage()));



}

win::~win()
{
}

void win::captureImage()
{
    imageCapture->capture();//捕获图片
    //imageCapture捕获到新图时,会发出imageCaptured(int,QImage)信号
}

void win::displayImage(int id, QImage image)
{
    qDebug()<<id;
    QSize s=ImageCapture->size();//返回显示框大小
    qDebug()<<s;
    image=image.scaled(s);//把图像缩放到显示框大小
    ImageCapture->setPixmap(QPixmap::fromImage(image));
}

判断是否被占用

//检测摄像头是否被占用
        QCamera *m_pCamera = new QCamera(this);
        QCameraViewfinder *m_pViewfinder = new QCameraViewfinder(this);  //取景器
        QCameraImageCapture *m_pImageCapture = new QCameraImageCapture(m_pCamera);//捕获对象
        m_pImageCapture->setCaptureDestination(QCameraImageCapture::CaptureToFile);//设置捕获为文件或者缓冲区,默认为文件
        m_pCamera->setCaptureMode(QCamera::CaptureStillImage);//设置捕获模式
        m_pCamera->setViewfinder(m_pViewfinder);//设置取景器
        m_pCamera->start();
        if (!m_pImageCapture->isReadyForCapture())  //摄像头是否准备好捕获了
        {
            qDebug() << "摄像头已被其他应用程序占用";
            QMessageBox box(QMessageBox::Question, tr("提示"), tr("摄像头打开失败。"));
            box.addButton(tr("确 定"), QMessageBox::YesRole);
            box.exec();
        }
        m_pCamera->stop();
        delete m_pCamera;
        delete m_pViewfinder;
        delete m_pImageCapture;

QCameraInfo

QList<QCameraInfo> list;
    list = QCameraInfo::availableCameras(); //返回摄像头信息列表
    qDebug()<<list.isEmpty();  //是否为空,返回true说明没有摄像头,返回false有摄像头
    qDebug()<<list[0].isNull();  //如果此QCameraInfo为null或无效,则返回true
    qDebug()<<"物理位置:"<<list.at(0).position();
    //QCamera::UnspecifiedPosition=0    位置未指定或未知
    //QCamera::BackFace=1   摄像头位于系统硬件的背面。例如,在移动设备上,这意味着它位于屏幕的另一侧
    //QCamera::FrontFace=2  摄像头位于系统硬件的正面。例如,在移动设备上,这意味着它与屏幕位于同一侧

   // list[0] ==list[1]; 如果两个QCameraInfo相同,则返回true
   // list[0] !=list[1]; 如果两个QCameraInfo不同,则返回true

    QString desc=list.at(0).description();  //返回描述信息
    QString defa=QCameraInfo::defaultCamera().description();//查看系统默认摄像头的描述信息
    QString name=list.at(0).deviceName();//获取设备名称

分辨率、帧率 

查询和设置摄像头分辨率时,需要在摄像头启动后调用,

即在调用QCamera::start()后,

可以使用QCamera::stateChanged(QCamera:State state)信号,

如果收到摄像头状态为QCamera::ActiveState后,再调用上述API

camera=new QCamera(this);
    viewfinder=new QCameraViewfinder(this);


    viewfinder->resize(640,480);
    viewfinder->move(0,0);
    camera->setViewfinder(viewfinder);
    camera->start();
    QList<QCameraViewfinderSettings > ViewSets = camera->supportedViewfinderSettings();//获取摄像头支持的分辨率、帧率等参数
    qDebug() << ViewSets.length();  //返回分辨率支持的总数
    //14

    foreach (QCameraViewfinderSettings ViewSet, ViewSets) {
            qDebug() << i++ <<"最大帧速率=" << ViewSet.maximumFrameRate() << "最小帧速率="<< ViewSet.minimumFrameRate() << "分辨率:"<<ViewSet.resolution()<<\
                        "像素格式="<<ViewSet.pixelFormat()<<"像素纵横比="<<ViewSet.pixelAspectRatio();
        }
    /*
列表按优先顺序排列;首选设置优先
0 最大帧速率= 30 最小帧速率= 30 分辨率: QSize(1920, 1080) 像素格式= Format_Jpeg 像素纵横比= QSize(1, 1)
1 最大帧速率= 30 最小帧速率= 30 分辨率: QSize(1280, 720) 像素格式= Format_Jpeg 像素纵横比= QSize(1, 1)
2 最大帧速率= 30 最小帧速率= 30 分辨率: QSize(1024, 768) 像素格式= Format_Jpeg 像素纵横比= QSize(1, 1)
3 最大帧速率= 30 最小帧速率= 30 分辨率: QSize(800, 600) 像素格式= Format_Jpeg 像素纵横比= QSize(1, 1)
4 最大帧速率= 30 最小帧速率= 30 分辨率: QSize(640, 480) 像素格式= Format_Jpeg 像素纵横比= QSize(1, 1)
5 最大帧速率= 30 最小帧速率= 30 分辨率: QSize(352, 288) 像素格式= Format_Jpeg 像素纵横比= QSize(1, 1)
6 最大帧速率= 30 最小帧速率= 30 分辨率: QSize(320, 240) 像素格式= Format_Jpeg 像素纵横比= QSize(1, 1)
7 最大帧速率= 30 最小帧速率= 30 分辨率: QSize(640, 480) 像素格式= Format_YUYV 像素纵横比= QSize(1, 1)
8 最大帧速率= 5 最小帧速率= 5 分辨率: QSize(1920, 1080) 像素格式= Format_YUYV 像素纵横比= QSize(1, 1)
9 最大帧速率= 10 最小帧速率= 10 分辨率: QSize(1280, 720) 像素格式= Format_YUYV 像素纵横比= QSize(1, 1)
10 最大帧速率= 10 最小帧速率= 10 分辨率: QSize(1024, 768) 像素格式= Format_YUYV 像素纵横比= QSize(1, 1)
11 最大帧速率= 30 最小帧速率= 30 分辨率: QSize(800, 600) 像素格式= Format_YUYV 像素纵横比= QSize(1, 1)
12 最大帧速率= 30 最小帧速率= 30 分辨率: QSize(352, 288) 像素格式= Format_YUYV 像素纵横比= QSize(1, 1)
13 最大帧速率= 30 最小帧速率= 30 分辨率: QSize(320, 240) 像素格式= Format_YUYV 像素纵横比= QSize(1, 1)
*/

camera->setViewfinderSettings(ViewSets[1]);//设置摄像头参数

qreal maxrate=ViewSets[0].maximumFrameRate();//返回最大帧速率
qreal minrate=ViewSets[0].minimumFrameRate();//返回最小帧速率
qDebug() <<maxrate<<",     "<<minrate;
ViewSets[1].setMaximumFrameRate(20);//设置最大帧速率

相机状态

camera=new QCamera(this);
    viewfinder=new QCameraViewfinder(this);
    viewfinder->resize(640,480);
    viewfinder->move(0,0);
    camera->setViewfinder(viewfinder);
    camera->start();

    int n=camera->status(); //返回相机当前状态
    /*
QCamera::ActiveStatus=8  摄像机已经启动,可以生成数据。取景器在活动状态下显示视频帧。
         说明:根据后端的不同,在ActiveState中更改某些相机设置(如捕获模式、编解码器或分辨率)
         可能会导致在应用设置时将相机状态更改为LoadedStatus和StartingStatus,并在相机准备
         就绪时将相机状态更改为ActiveStatus
QCamera::StartingStatus=6  状态正在转换为QCamera::ActiveState,相机正在启动。相机服务尚未准备好拍摄
QCamera::StoppingStatus=7  状态从QCamera::ActiveState转换为QCamera::LoadedState或QCamera::UnloadedState,相机正在停止
QCamera::StandbyStatus=5   相机处于省电待机模式。相机在QCamera::LoadedState状态下静止一段时间后可能会进入待机模式
QCamera::StandbyStatus=4   摄像机已加载并准备好进行配置。此状态表示相机设备已打开,可以查询支持的图像和视频捕获设置,如分辨率、帧速率和编解码器
QCamera::StandbyStatus=3   状态从QCamera::LoadedState或QCamera::ActiveState转换为QCamera::UnloadedState,相机设备正在卸载
QCamera::StandbyStatus=2   状态从QCamera::UnloadedState转换为QCamera::LoadedState或QCamera::ActiveState,相机设备加载
QCamera::StandbyStatus=1  相机未加载时的初始相机状态
QCamera::StandbyStatus=0  相机或相机后端不可用

*/



    qDebug()<<n;

本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值