Qt 之自定义界面(右下角冒泡)

简述

网页右下角上经常会出现一些提示性的信息,桌面软件中也比较常见,类似360新闻、QQ消息提示一样!

这种功能用动画实现起来很简单,这节我们暂时使用定时器来实现,后面章节会对动画框架进行详细讲解。

下面我们来实现一个右下角冒泡的功能。

| 版权声明:一去、二三里,未经博主允许不得转载。

效果

这里写图片描述

实现原理

  • 显示
    定时器启动,右下角缓慢弹出,逐渐改变位置

  • 驻留
    让界面停留一定的时间,时间过后自动关闭。

  • 退出
    可以直接点击关闭退出,也可以采用改变透明度的形式模糊退出。

连接信号与槽

m_pShowTimer = new QTimer(this);
m_pStayTimer = new QTimer(this);
m_pCloseTimer = new QTimer(this);

connect(m_pShowTimer, SIGNAL(timeout()), this, SLOT(onMove()));
connect(m_pStayTimer, SIGNAL(timeout()), this, SLOT(onStay()));
connect(m_pCloseTimer, SIGNAL(timeout()), this, SLOT(onClose()));

实现

界面现实的时候调用showMessage(),然后启动定时器开始显示、驻留、关闭。

// 显示
void MainWindow::showMessage()
{
    QRect rect = QApplication::desktop()->availableGeometry();
    m_point.setX(rect.width() - width());
    m_point.setY(rect.height() - height());
    move(m_point.x(), m_point.y());
    m_pShowTimer->start(5);
}

// 移动
void MainWindow::onMove()
{
    m_nDesktopHeight--;
    move(m_point.x(), m_nDesktopHeight);
    if (m_nDesktopHeight <= m_point.y())
    {
        m_pShowTimer->stop();
        m_pStayTimer->start(5000);
    }
}

// 驻留
void MainWindow::onStay()
{
    m_pStayTimer->stop();
    m_pCloseTimer->start(100);
}

// 关闭
void MainWindow::onClose()
{
    m_dTransparent -= 0.1;
    if (m_dTransparent <= 0.0)
    {
        m_pCloseTimer->stop();
        close();
    }
    else
    {
        setWindowOpacity(m_dTransparent);
    }
}
您可以使用Qt中的QDialog和QPainter来创建自定义右下角气泡对话框。以下是一个简单的实现: 1. 创建一个继承自QDialog的类,例如MyDialog。 2. 在MyDialog类中添加一个成员函数paintEvent(QPaintEvent *event),该函数用于绘制气泡对话框。 3. 在paintEvent函数中使用QPainter来绘制气泡对话框的形状和内容,例如使用drawRoundedRect绘制一个圆角矩形作为气泡框体,使用drawText绘制文本内容。 4. 在MyDialog类中添加一个成员函数showMessage(QString message),该函数用于显示气泡对话框并设置文本内容。 5. 在showMessage函数中使用move函数将气泡对话框定位到屏幕右下角,并使用show函数显示对话框。 下面是一个简单的实现示例: ```c++ #include <QDialog> #include <QPainter> #include <QTimer> class MyDialog : public QDialog { Q_OBJECT public: MyDialog(QWidget *parent = nullptr) : QDialog(parent) { setWindowFlags(Qt::FramelessWindowHint | Qt::Tool | Qt::WindowStaysOnTopHint); setAttribute(Qt::WA_TranslucentBackground); QTimer::singleShot(5000, this, &MyDialog::deleteLater); } void showMessage(QString message) { m_message = message; show(); move(qApp->desktop()->availableGeometry().bottomRight() - frameGeometry().bottomRight()); } protected: void paintEvent(QPaintEvent *event) override { QPainter painter(this); painter.setRenderHint(QPainter::Antialiasing); // 绘制气泡框体 QRect rect(0, 0, width(), height()); painter.setPen(Qt::NoPen); painter.setBrush(QColor("#2C3E50")); painter.drawRoundedRect(rect, 10, 10); // 绘制文本内容 painter.setPen(QColor("#FFFFFF")); painter.drawText(rect.adjusted(10, 10, -10, -10), Qt::AlignLeft | Qt::AlignTop, m_message); } private: QString m_message; }; ``` 您可以在需要显示气泡对话框的地方调用MyDialog的showMessage函数,例如: ```c++ MyDialog dialog; dialog.showMessage("Hello, world!"); ``` 这将显示一个包含文本“Hello, world!”的右下角气泡对话框。
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一去丶二三里

有收获,再打赏!

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

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

打赏作者

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

抵扣说明:

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

余额充值