QWidget的ui界面绘制成图片

文章目录

源文件

复制代码
#include "widget.h"
#include "ui_widget.h"


#include <QPixmap>
#include <QDir>

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);


    // 构造一个给定大小的像素图。
    QPixmap pixmap(this->size());

    // 将目标this窗口界面绘制到源目标图片里面
    this->render(&pixmap);

    QSize newSize(800,600);
    // 调整图片大小 保持纵横比
    pixmap = pixmap.scaled(newSize,Qt::KeepAspectRatio);

    QDir dir;
    dir.cdUp();
    QString path = dir.currentPath();

    // 保存图片
    QString filemname  = path + "img.png";
    pixmap.save(filemname);


}

Widget::~Widget()
{
    delete ui;
}

源码解释

这段代码是一个包含"widget.h"和"ui_widget.h"头文件的C++程序。

接下来,它引入了两个Qt库的头文件:QPixmap和QDir。

Widget类是一个继承自QWidget的自定义窗口部件。构造函数使用提供的父对象指针创建Widget对象,并通过调用ui的setupUi函数来设置窗口的用户界面。

接下来,代码创建了一个Pixmap对象pixmap,其大小与当前窗口的大小相同。

然后,代码通过调用render函数,将当前窗口界面绘制到pixmap中,实现截屏的效果。

接下来,代码创建了一个新的大小为800x600的QSize对象newSize。

然后,通过调用scaled函数,将pixmap对象调整为newSize大小,并保持图片的纵横比。

然后,代码创建了一个QDir对象dir,并调用cdUp函数将当前目录切换到上一级目录。

接下来,代码获取当前目录的路径,并将其赋给QString类型的变量path。

然后,通过将path和"img.png"连接起来,创建了一个QString类型的文件名变量filemname。

最后,代码调用pixmap对象的save函数,将图片保存到filemname指定的路径中。

析构函数中,代码通过delete操作符释放ui指针指向的内存,防止内存泄漏。

效果


修复图片清晰度

当绘制出来的图片模糊时,你可以尝试以下方法来改善图片质量:

  1. 增加像素密度:
cpp 复制代码
QPixmap pixmap(this->size() * 2); // 使用当前窗口大小的两倍像素密度
this->render(&pixmap);
pixmap = pixmap.scaled(this->size(), Qt::KeepAspectRatio, Qt::SmoothTransformation);

通过创建一个像素密度更高的Pixmap对象,然后进行缩放,可以增加图片的清晰度。

  1. 使用更高质量的缩放算法:
cpp 复制代码
pixmap = pixmap.scaled(newSize, Qt::KeepAspectRatio, Qt::SmoothTransformation);

将scaled函数的第三个参数设置为Qt::SmoothTransformation,可以使用更平滑的缩放算法。

  1. 调整绘制参数:
cpp 复制代码
QPainter painter(&pixmap);
painter.setRenderHints(QPainter::Antialiasing | QPainter::SmoothPixmapTransform);
this->render(&painter);

在绘制过程中,使用setRenderHints函数设置抗锯齿选项和平滑的Pixmap转换,可以减少图像的锯齿感和模糊度。

  1. 使用OpenCV进行图像处理:可以使用OpenCV库进行更高级的图像处理操作,例如图像增强和滤波。以下是使用OpenCV进行图像平滑处理的示例:
cpp 复制代码
#include <opencv2/opencv.hpp>

QImage image = pixmap.toImage();

cv::Mat cvImage(image.height(), image.width(), CV_8UC4, image.bits(), image.bytesPerLine());
cv::Mat cvImageSmooth;

cv::GaussianBlur(cvImage, cvImageSmooth, cv::Size(5, 5), 0);

QImage smoothImage(cvImageSmooth.data, cvImageSmooth.cols, cvImageSmooth.rows, cvImageSmooth.step, QImage::Format_ARGB32);
QPixmap smoothedPixmap = QPixmap::fromImage(smoothImage);

以上示例使用OpenCV的GaussianBlur函数对图像进行高斯平滑处理,然后将结果转换回QPixmap对象。

这些是一些常用的方法来改善绘制出的图片的模糊度。你可以根据具体情况选择适合的方法来提高图片质量。

相关推荐
钱彬 (Qian Bin)20 小时前
项目实践17—全球证件智能识别系统(开发基于LabelMe标注的可视化审核接口)
qt·fastapi·全球证件识别
尤老师FPGA1 天前
使用ZYNQ芯片和LVGL框架实现用户高刷新UI设计系列教程(第四十五讲)
android·java·ui
look ahead to1 天前
关于PYQT qt designer的网格布局 单控件占多行的处理
开发语言·qt·pyqt
Lution Young1 天前
Qt隐式共享产生的问题
开发语言·qt
少控科技1 天前
QT进阶日记009
开发语言·qt
CodeCraft Studio1 天前
从框架到体验:Qt + Qtitan 构建制造业嵌入式UI整体解决方案
开发语言·qt·ui·gui·嵌入式开发·hmi·制造业嵌入式ui
AI_零食1 天前
鸿蒙的flutter框架表达:生命律动系统
学习·flutter·ui·华为·harmonyos·鸿蒙
深蓝海拓1 天前
PyQt5/PySide6的moveToThread:移动到线程
笔记·python·qt·学习·pyqt
AI_零食1 天前
鸿蒙跨端框架 Flutter 学习 Day 6:Future 在 UI 渲染中的心跳逻辑
学习·flutter·ui·华为·harmonyos·鸿蒙
少控科技1 天前
QT高阶日记007
开发语言·qt