效果图
要实现托盘效果,需要用到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"));
}
}