Qt调用摄像头(截取并保存图片)

http://blog.youkuaiyun.com/liang19890820/article/details/12782531 

Qt如何调用系统摄像设备进行显示、截图、录制?

    QCamera:系统摄像设备(摄像头)
    QCameraViewfinder:摄像取景器部件
    QCameraImageCapture:截图部件

capture按钮:用于截图(截图后在右上角显示)
save按钮:用于保存截取后的图片(此处测试路径为:F:\a.jpg)
exit按钮:退出界面

效果如下:



代码如下:

#include "test_capture.h"
Dialog::Dialog(QWidget *parent) :
QDialog(parent)
{
this->resize(600, 400);

camera = new QCamera();
view_finder = new QCameraViewfinder();
camera_image_capture = new QCameraImageCapture(camera);
capture_button = new QPushButton();
save_button = new QPushButton();
exit_button = new QPushButton(); 
display_label = new QLabel();

QHBoxLayout *main_layout = new QHBoxLayout();
QVBoxLayout *v_layout = new QVBoxLayout();

display_label->setFixedSize(150, 150);
display_label->setScaledContents(true);

v_layout->addWidget(display_label);
v_layout->addStretch();
v_layout->addWidget(capture_button);
v_layout->addWidget(save_button);
v_layout->addWidget(exit_button);

main_layout->addWidget(view_finder);
main_layout->addLayout(v_layout);

connect(capture_button, &QPushButton::clicked, this, &Dialog::captureImage);
connect(save_button, &QPushButton::clicked, this, &Dialog::saveImage);
connect(exit_button, &QPushButton::clicked, this, &Dialog::close);
connect(camera_image_capture, &QCameraImageCapture::imageCaptured, this, &Dialog::displayImage);

camera_image_capture->setCaptureDestination(QCameraImageCapture::CaptureToFile);
camera->setCaptureMode(QCamera::CaptureStillImage);
camera->setViewfinder(view_finder);
camera->start(); //启动摄像头

this->setLayout(main_layout);
this->translateLanguage();
}

Dialog::~Dialog()
{

}

void Dialog::translateLanguage()
{
this->setWindowTitle("testCapture");
capture_button->setText(tr("capture"));
save_button->setText(tr("save"));
exit_button->setText(tr("exit"));
}

void Dialog::displayImage(int id, QImage image)
{
display_label->setPixmap(QPixmap::fromImage(image));  
}

void Dialog::captureImage()
{
//截图
camera_image_capture->capture();  
}

void Dialog::saveImage()
{
const QPixmap *pixmap = display_label->pixmap();
if(pixmap)
{
pixmap->save("F:\\a.jpg");
}
}
Qt 6中,你可以使用QML(Qt Meta Language)和相关的多媒体库来实现在控件上显示摄像头的内容。以下是基本步骤: 1. **设置环境**: 确保已安装了Qt 6及其相应的平台支持(如Qt Quick Controls 2 for QtQuick 2或者Qt Quick Controls 3 for QtQuick 3)。如果你使用的是Qt Creator,可以在项目配置中选择正确的Qt版本。 2. **导入所需模块**: 在`.qml`文件中,导入`QtMultimedia`和`QtQuick.Controls`模块,它们分别处理多媒体操作和界面控制。 ```qml import QtMultimedia 5.15 import QtQuick 2.0 ``` 3. **创建VideoCapture对象**: 使用`QtMultimedia`中的`VideoCapture`类获取摄像头设备的数据流。 ```qml VideoCapture capture { id: cameraCapture deviceName: "default" // 或者指定具体的设备ID // deviceName: "/dev/video0" (Linux) // deviceName: "video1" (Windows) active: true } ``` 4. **处理视频数据**: 通过`Component.onCompleted`回调,当摄像头连接成功后,开始接收处理视频帧。 ```qml Component.onCompleted: { if (cameraCapture.state == VideoCapture.State.Running) { previewSource = CameraPreview(source: cameraCapture) } else { console.error("Failed to start the camera.") } } ``` 5. **显示视频预览**: 创建一个`CameraPreview`组件,它可以渲染摄像头实时画面到控件上,比如`Image`或`Rectangle`组件。 ```qml CameraPreview { id: previewSource anchors.fill: parent source: cameraCapture } Image { id: displayImage anchors.centerIn: parent source: previewSource } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值