Qt 之窗口动画(下坠、抖动、透明度)

本文介绍了如何使用Qt实现窗口的下坠、抖动和透明度动画效果。通过调整geometry、pos和windowOpacity属性,创建出丰富的交互体验。示例代码详细展示了动画的实现过程,包括计算动画的起始和结束位置,以及设置透明度变化。文章最后还提供了Qt动画框架的相关参考资料。
摘要由CSDN通过智能技术生成

作者: 一去、二三里
个人微信号: iwaleon
微信公众号: 高效程序员

前面几节中我们介绍了关于动画的基本使用,有属性动画、串行动画组、并行动画组。这节我们来实现一些特效,让交互更顺畅。

示例

下面,我们以geometry、pos、windowOpacity属性为例,来实现窗体的下坠、抖动、透明度效果。

效果

这里写图片描述

源码

下坠效果:

通过计算桌面的宽度、高度,来设置动画的起始值和结束值。

void MainWindow::onDropWindow()
{
    QPropertyAnimation *pAnimation = new QPropertyAnimation(this, "geometry");

    QDesktopWidget *pDesktopWidget =
Qt 中,可以使用 QPropertyAnimation 类来实现子窗口透明度动画效果。具体步骤如下: 1. 在子窗口类中添加一个成员变量,用于保存透明度的值。 2. 在构造函数中设置子窗口属性,使其具有窗口透明度,代码如下: ``` setAttribute(Qt::WA_TranslucentBackground); setWindowFlags(Qt::FramelessWindowHint | Qt::Tool); ``` 3. 在子窗口类中添加一个方法,用于设置子窗口透明度,代码如下: ``` void setOpacity(qreal opacity) { m_opacity = opacity; setWindowOpacity(opacity); } ``` 4. 使用 QPropertyAnimation 类创建一个动画对象,将子窗口透明度作为动画属性,代码如下: ``` QPropertyAnimation *animation = new QPropertyAnimation(this, "opacity"); animation->setDuration(1000); animation->setStartValue(0.0); animation->setEndValue(1.0); animation->start(); ``` 5. 启动动画。 完整代码示例: ``` #include <QDialog> #include <QPropertyAnimation> class MyDialog : public QDialog { public: MyDialog(QWidget *parent = 0) : QDialog(parent) , m_opacity(1.0) { setAttribute(Qt::WA_TranslucentBackground); setWindowFlags(Qt::FramelessWindowHint | Qt::Tool); } void setOpacity(qreal opacity) { m_opacity = opacity; setWindowOpacity(opacity); } private: qreal m_opacity; }; int main(int argc, char *argv[]) { QApplication app(argc, argv); MyDialog dialog; dialog.show(); QPropertyAnimation *animation = new QPropertyAnimation(&dialog, "opacity"); animation->setDuration(1000); animation->setStartValue(0.0); animation->setEndValue(1.0); animation->start(); return app.exec(); } ``` 以上代码演示了如何创建一个透明度动画的子窗口,并在启动时开始动画效果
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一去丶二三里

有收获,再打赏!

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

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

打赏作者

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

抵扣说明:

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

余额充值