QT widget设置QT::FramelessWindowHint和Qt::WA_TranslucentBackground,会出现一个bug:在最小化还原时界面停止刷新
Widget with
QT::FramelessWindowHint and Qt::WA_TranslucentBackground stops paintting after minimize/restore
第一种方法
该bug在qt 5.1.1中修复, bugreport链接
https://bugreports.qt-project.org/browse/QTBUG-17548
之前的版本的话, 可以试下下面的方法, 基本可用, 但在setwindowflag后, 任务栏图标会滑动一下, 某些电脑可能还会略微闪烁
void TestDlg::changeEvent( QEvent* e )
{
if( e->type() == QEvent::WindowStateChange)
{
if(this->windowState() & Qt::WindowMinimized )
{
//
}
else
{
setWindowFlags(Qt::Window);//set normal window flag
setWindowFlags(Qt::Window | Qt::FramelessWindowHint | Qt::WindowMinimizeButtonHint);//and return to your old flags
this->showNormal();
}
}
}
第二种方法
void TestDlg::changeEvent( QEvent* e )
{
if( e->type() == QEvent::WindowStateChange)
{
if(this->windowState() & Qt::WindowMinimized )
{
repaint();
}
}
}
网上找到的这种方法,可能会引起一些问题,第一种方法会引起任务栏图标闪烁;
第二种方法可能会引起界面不响应任何鼠标事件(推测可能是repaint被持续循环执行了。。。)
以下是另一种方法:
在窗体还原的时候在做刷新处理,为了防止第二种方法的问题,可以考虑使用singleShot 来使窗口刷新。
......设置一个信号槽,进行信号处理。
QObject::connect(this, SIGNAL(sendWindowRestore()), this, SLOT(slotRestoreMainWindow()));
bool MyWidget::winEvent(MSG * _message, long * _result)
{
if (_message->message == WM_SYSCOMMAND)
{
if ((int)_message->wParam == SC_RESTORE)
{
emit sendWindowRestore();
}
}
return QWidget::winEvent(_message, _result);
}
void MyWidget::slotRestoreMainWindow()
{
QTimer::singleShot(0, this, SLOT(slotRestoreWindowTimeOut()));
}
void MyWidget::slotRestoreWindowTimeOut()
{
repaint();
}