Qt不规则异形窗体实现

采用主窗体透明方式实现

具体实现思路:
首先去掉窗体的标题头,设置主窗体为透明属性,然后需要套一个窗体来显示异形图片即可.
关键代码

	this->setWindowFlags(Qt::FramelessWindowHint | this->windowFlags());//去掉标题头
	this->setAttribute(Qt::WA_TranslucentBackground);//主窗体透明
	_layoutMain = new QVBoxLayout;
	_layoutMain->setContentsMargins(0, 0, 0, 0);//背景完全贴合
	_widgetBackground = new QWidget;//另外套一层窗体
	_widgetBackground->setObjectName("widgetBackground");
	_layoutMain->addWidget(_widgetBackground);
    setLayout(_layoutMain);
    readStyleSheetFile("skin/style.css");//在css文件中让 _widgetBackground 来显示异形背景图片

采用 setMask 方式实现

此种实现方式 调用setMask 让主窗体和异形背景图片形状保持一致。然后再绘制异形背景图片即可。
此种方式需要注意: 需要使得主窗体的大小和 背景图片的大小保持一致,否则会出现错位问题。
关键代码

	_backgroundPixmap = QPixmap("skin/test.png");//异形背景图片
		resize(_backgroundPixmap.size());//让窗体和背景图片大小 否则出现错位问题
	this->setMask(_backgroundPixmap.mask());//让主窗体形状和异形背景图片一致。
	
void FIrregularMaskWidget::paintEvent(QPaintEvent * event)
{
	QPainter painter(this);
	painter.drawImage(QRect(0, 0, width(), height()), _backgroundPixmap.toImage());
}//绘制异形背景图片

代码

笔者 环境 windwos 7 vs2015 debug 64位
github地址:
https://github.com/1005490940/Qt/tree/master/FIrregularWidget
补充
制作悬浮窗体目前采用move 方式实现。只要计算出绝对位置即可

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Qt是一个跨平台的C++应用程序开发框架,它提供了丰富的图形界面和功能库。要实现不规则形状的进度条,可以使用Qt的绘图功能和自定义控件。 以下是一种实现不规则形状进度条的方法: 1. 创建一个自定义的QWidget子类,作为进度条的容器。 2. 在该自定义控件中重写paintEvent函数,使用Qt的绘图功能绘制进度条的背景和前景。 3. 根据进度值计算出前景的宽度,并使用绘图函数绘制前景。 4. 使用QPainterPath类创建一个不规则形状的路径,可以使用addRect、addEllipse等函数添加矩形、椭圆等形状。 5. 使用setClipPath函数将绘图区域限制在不规则形状的路径内。 6. 在paintEvent函数中绘制进度条的背景和前景。 下面是一个简单的示例代码: ```cpp #include <QtWidgets> class IrregularProgressBar : public QWidget { public: IrregularProgressBar(QWidget *parent = nullptr) : QWidget(parent), m_progress(0) { } void setProgress(int progress) { m_progress = progress; update(); } protected: void paintEvent(QPaintEvent *event) override { Q_UNUSED(event); QPainter painter(this); painter.setRenderHint(QPainter::Antialiasing); // 绘制背景 painter.fillRect(rect(), Qt::lightGray); // 绘制前景 QRectF foregroundRect(rect().x(), rect().y(), rect().width() * m_progress / 100.0, rect().height()); painter.fillRect(foregroundRect, Qt::blue); // 创建不规则形状的路径 QPainterPath path; path.addRoundedRect(rect(), 10, 10); // 设置绘图区域为不规则形状的路径 painter.setClipPath(path); // 绘制进度条的背景和前景 painter.fillRect(rect(), Qt::lightGray); painter.fillRect(foregroundRect, Qt::blue); } private: int m_progress; }; int main(int argc, char *argv[]) { QApplication app(argc, argv); IrregularProgressBar progressBar; progressBar.setProgress(50); progressBar.resize(300, 30); progressBar.show(); return app.exec(); } ``` 这个示例代码创建了一个自定义的QWidget子类IrregularProgressBar,通过重写paintEvent函数实现不规则形状的进度条。在paintEvent函数中,首先绘制了背景和前景,然后创建了一个圆角矩形的路径,并使用setClipPath函数将绘图区域限制在该路径内,最后再次绘制了背景和前景。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一路初心向前

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值