Qt托盘实现QQ消息闪烁效果

效果图
在这里插入图片描述

要实现托盘效果,需要用到QSystemTrayIcon类,具体用法参考Qt官方文档
QSystemTrayIcon参考

下面来说说怎么实现类似QQ托盘来消息后闪烁效果

闪烁的机制其实是两张图片在特定的时间内相互变产生的视觉特效,将其中一张图片换成透明的图片就可以模仿QQ闪烁的特效。

控制图片相互替换实现就需要用到定时器了,一个定时器控制原本程序托盘的图片,另一个定时器控制透明图片。

具体实现代码如下

首先创建并初始化托盘类

QSystemTrayIcon m_tray;
m_tray.setIcon(QIcon(":/ToolTip/qrc/logo1.jpg"));
m_tray.show();

创建并初始化定时器

QTimer timerT;
QTimer timerNoT;
connect(&timerT, &QTimer::timeout, this, &MainWidget::sltTimerT);
connect(&timerNoT, &QTimer::timeout, this, &MainWidget::sltTimerNoT);

此处使用按钮控制闪烁和非闪烁

connect(ui.pushButton_T, &QPushButton::clicked, this, [=]() {
	timerT.start(300);
});

connect(ui.pushButton_noT, &QPushButton::clicked, this, [=]() {
	if (timerT.isActive()) timerT.stop();
	if (timerNoT.isActive()) timerNoT.stop();
	m_tray.setIcon(QIcon(":/ToolTip/qrc/logo1.jpg")); //还原托盘原本icon
});

定时器槽函数实现

void MainWidget::sltTimerT()
{
	m_tray.setIcon(QIcon(":/ToolTip/qrc/logo1.jpg"));
	timerNoT.start(300);
	if(timerT.isActive()) timerT.stop();
}

void MainWidget::sltTimerNoT()
{
	m_tray.setIcon(QIcon(":/ToolTip/qrc/logo2.jpg"));
	timerT.start(300);
	if(timerNoT.isActive()) timerNoT.stop();
}

优化版

m_timer.setInterval(300);
m_timer.setProperty(Property_timerId, true);
connect(&m_timer, &QTimer::timeout, this, &MainWidget::sltTimeout);

connect(ui.pushButton_T, &QPushButton::toggled, this, &MainWidget::sltButtonToggled);

void MainWidget::sltButtonToggled(bool check)
{
	if (check) {
		m_timer.start();
	}
	else {
		m_timer.stop();
		m_tray.setIcon(QIcon(":/ToolTip/qrc/logo1.jpg"));
	}
}

void MainWidget::sltTimeout()
{
	bool result = m_timer.property(Property_timerId).toBool();
	m_timer.setProperty(Property_timerId, !result);
	if (result) {
		m_tray.setIcon(QIcon(":/ToolTip/qrc/logo2.jpg"));
	}
	else {
		m_tray.setIcon(QIcon(":/ToolTip/qrc/logo1.jpg"));
	}
}

用QPropertyAnimation动画类的基类QVariantAnimation实现托盘闪烁

//初始化QVariantAnimation对象
m_variantAnimation = new QVariantAnimation(this);
if (m_variantAnimation) {
	m_variantAnimation->setStartValue(0);
	m_variantAnimation->setEndValue(2);
	m_variantAnimation->setLoopCount(-1);
	m_variantAnimation->setDuration(500);
	connect(m_variantAnimation, &QVariantAnimation::valueChanged, this, &MainWidget::sltVariantChanged);
}

connect(ui.pushButton_T, &QPushButton::toggled, this, &MainWidget::sltButtonToggled);

void MainWidget::sltButtonToggled(bool check)
{
	if (check) {
		if (m_variantAnimation) {
			if (QAbstractAnimation::Running != m_variantAnimation->state()) {
				m_variantAnimation->start();
			}
		}
	}
	else {
		if (m_variantAnimation) {
			if (QAbstractAnimation::Stopped != m_variantAnimation->state()) {
				m_variantAnimation->stop();
			}
		}
		m_tray.setIcon(QIcon(":/ToolTip/qrc/logo1.jpg"));
	}
}

void MainWidget::sltVariantChanged(QVariant value)
{
	auto result = value.toInt();
	qInfo() << result;
	if (0 == result) {
		m_tray.setIcon(QIcon(":/ToolTip/qrc/logo2.jpg"));
	}
	else {
		m_tray.setIcon(QIcon(":/ToolTip/qrc/logo1.jpg"));
	}
}

更多QVariantAnimation资料

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

离歌漠

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

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

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

打赏作者

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

抵扣说明:

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

余额充值