当前位置: 首页 > news >正文

Qt 实现不规则的部件或者窗口

1、实现不规则的部件
1.1 工程目录
在这里插入图片描述
1.2 界面实现
在这里插入图片描述
1.3 widget.cpp

#include "widget.h"
#include <QPixmap>
#include <QBitmap>
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);ui->label->setFixedSize(105,74);// dog.png 图片的宽高QPixmap pixmap(":/images/dog.png");// dog.png 一定是没有背景(背景透明)的图片ui->label->setPixmap(pixmap);ui->label->setMask(pixmap.mask());// 为 label 部件设置遮罩
}Widget::~Widget()
{delete ui;
}

1.4 图片一定是没有背景(背景透明)的图片,如下图
请添加图片描述

1.5 运行效果:标签部件显示成了图片的形状
在这里插入图片描述
2、实现不规则的窗口
2.1 工程目录
在这里插入图片描述
2.2 界面实现
在这里插入图片描述

2.3 widget.h

#ifndef WIDGET_H
#define WIDGET_H#include <QWidget>QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACEclass Widget : public QWidget
{Q_OBJECTpublic:Widget(QWidget *parent = nullptr);~Widget();private:Ui::Widget *ui;
protected:/*** @brief 在 widget 上绘制图片*/void paintEvent(QPaintEvent *event) override;/*** @brief 点击 widget 关闭窗口*/void mousePressEvent(QMouseEvent *event) override;
};
#endif // WIDGET_H

2.4 widget.cpp

#include "widget.h"
#include "ui_widget.h"
#include <QPixmap>
#include <QBitmap>
#include <QPainter>Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);QPixmap pixmap(":/images/dog.png");/**因为 QWidget 不能像 QLabel 那样直接给部件添加图片,所以要使用 paintEvent 方法在 QWidget 上绘制**/this->resize(pixmap.size());// 设置窗口大小为图片大小this->setMask(pixmap.mask());// 为窗口设置遮罩
}Widget::~Widget()
{delete ui;
}/*** @brief 在 widget 上绘制图片*/
void Widget::paintEvent(QPaintEvent *event)
{QPainter painter(this);painter.drawPixmap(0,0,QPixmap(":/images/dog.png"));
}/*** @brief 点击 widget 关闭窗口*/
void Widget::mousePressEvent(QMouseEvent *event)
{this->close();
}

2.5 运行效果:widget窗口显示成了图片的形状
在这里插入图片描述


http://www.mrgr.cn/news/17145.html

相关文章:

  • 探索Python数据持久化的秘密:ZODB库的神奇之旅
  • 金融风控领域的15大顶级学术期刊
  • 【Rust练习】11.struct
  • 可能是支持属性最多的类似验证码的输入控件了。一个超好用的验证码,卡号,车牌号,IP地址-输入控件 - 掘金
  • 基于C语言开发一个职工管理系统
  • C++学习笔记----6、内存管理(一)---- 使用动态内存(1)
  • 中英翻译,就看这五款工具!
  • 使用 nuxi clean 命令清理 Nuxt 项目
  • PCB设计中” 铺铜的方式“导致电焊机设计失败
  • 基于yolov8的102种昆虫检测系统python源码+onnx模型+评估指标曲线+精美GUI界面
  • 探索TinyDB:轻量级数据库的优雅之旅
  • 滚动视图ScrollView
  • AI Acronyms
  • 异步编程详解
  • 数组结构第一周做题总结_基础练习
  • JS学习笔记
  • 【AIGC】MimicMotion:姿态引导的高质量人体运动视频生成技术
  • 【LLM】文生视频相关开源数据集(VidGen、Panda、Cogvideox等)
  • FCIS+mxnet的大坑(终于ok了)
  • ★ 算法OJ题 ★ 力扣 LCR179 - 和为 s 的两个数字