百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

Qt5摄像头

bigegpt 2024-08-06 11:52 2 浏览

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

头文件

#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

QT开发交流+赀料君羊:714620761

#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;

相关推荐

Linux 系统启动完整流程

一、启动系统流程简介如上图,简述系统启动的大概流程:1:硬件引导UEFi或BIOS初始化,运行POST开机自检2:grub2引导阶段系统固件会从MBR中读取启动加载器,然后将控制权交给启动加载器GRU...

超专业解析!10分钟带你搞懂Linux中直接I/O原理

我们先看一张图:这张图大体上描述了Linux系统上,应用程序对磁盘上的文件进行读写时,从上到下经历了哪些事情。这篇文章就以这张图为基础,介绍Linux在I/O上做了哪些事情。文件系统什么是...

linux入门系列12--磁盘管理之分区、格式化与挂载

前面系列文章讲解了VI编辑器、常用命令、防火墙及网络服务管理,本篇将讲解磁盘管理相关知识。本文将会介绍大量的Linux命令,其中有一部分在“linux入门系列5--新手必会的linux命令”一文中已经...

Linux环境下如何设置多个交叉编译工具链?

常见的Linux操作系统都可以通过包管理器安装交叉编译工具链,比如Ubuntu环境下使用如下命令安装gcc交叉编译器:sudoapt-getinstallgcc-arm-linux-gnueab...

可算是有文章,把Linux零拷贝技术讲透彻了

阅读本文大概需要6.0分钟。作者:卡巴拉的树链接:https://dwz.cn/BaQWWtmh本文探讨Linux中主要的几种零拷贝技术以及零拷贝技术适用的场景。为了迅速建立起零拷贝的概念...

linux软链接的创建、删除和更新

大家都知道,有的时候,我们为了省下空间,都会使用链接的方式来进行引用操作。同样的,在系统级别也有。在Windows系列中,我们称其为快捷方式,在Linux中我们称其为链接(基本上都差不多了,其中可能...

Linux 中最容易被黑客动手脚的关键目录

在Linux系统中,黑客攻击后常会针对关键目录和文件进行修改以实现持久化、提权或隐藏恶意活动。本文介绍下黑客最常修改的目录及其手法。一、/etc目录关键文件有:/etc/passwd和/et...

linux之间传文件命令之Rsync傻瓜式教程

1.前言linux之间传文件命令用什么命令?本文介绍一种最常用,也是功能强大的文件同步和传输工具Rsync,本文提供详细傻瓜式教程。在本教程中,我们将通过实际使用案例和最常见的rsync选项的详细说...

Linux下删除目录符号链接的方法

技术背景在Linux系统中,符号链接(symlink)是一种特殊的文件,它指向另一个文件或目录。有时候,我们可能需要删除符号链接,但保留其指向的目标目录。然而,在删除符号链接时可能会遇到一些问题,例如...

阿里云国际站注册教程:aa云服务器怎么远程链接?

在全球化的今天,互联网带给我们无以计数的便利,而云服务器则是其中的重要基础设施之一。这篇文章将围绕阿里云国际站注册、aa云服务器如何远程链接,以及服务器安全防护如Ddos防火墙、网站应用防护waf防火...

Linux 5.16 网络子系统大范围升级 多个新适配器驱动加入

Linux在数据中心中占主导地位,因此每个内核升级周期的网络子系统变化仍然相当活跃。Linux5.16也不例外,周一最新与网络相关的更新加入了大量的驱动和新规范的支持。一个较新硬件的驱动是Realt...

搭建局域网文件共享服务(Samba),手机电脑都能看喜欢的影视剧

作为一名影视爱好者,为了方便地观看自己喜欢的影视作品,在家里搞一个专门用来存放电影的服务器是有必要的。蚁哥选则用一台Ubuntu系统的电脑做为服务器,共享影音文件,其他同一个局域网内的电脑或手机可以...

分享一个实用脚本—centos7系统巡检

概述这周闲得慌,就根据需求写了差不多20个脚本(部分是之前分享过的做了一些改进),今天主要分享一个给平时运维人员用的centos7系统巡检的脚本,或者排查问题检查系统情况也可以用..实用脚本#!/bi...

Linux 中创建符号链接的方法

技术背景在Linux系统里,符号链接(SymbolicLink),也被叫做软链接(SoftLink),是一种特殊的文件,它指向另一个文件或者目录。符号链接为文件和目录的管理带来了极大的便利,比...

一文掌握 Linux 符号链接

符号链接(SymbolicLink),通常被称为“软链接”,是Linux文件系统中一种强大而灵活的工具。它允许用户创建指向文件或目录的“快捷方式”,不仅简化了文件管理,还在系统配置、软件开发和日...