Qt 无边框、透明、可移动、的个性窗体案例详解

原文地址:http://blog.csdn.net/yiyaaixuexi/article/details/6362865

很多朋友都问透明的效果怎么做,为什么自己做的无边框窗体不可移动,一个个回答的很累,干脆写出来分享下好了.

[cpp] view plain copy print ?
  1. int main(int argc, char *argv[]){  
  2.   
  3.    QApplication::setStyle("cleanlooks");  
  4.   
  5.    QApplication a(argc, argv);  
  6.    login w;  
  7.    w.setWindowTitle("ClientLogin");  
  8.   
  9.   
  10.    w.setWindowOpacity(1);  
  11.    w.setWindowFlags(Qt::FramelessWindowHint);  
  12.    w.setAttribute(Qt::WA_TranslucentBackground);  
  13.    w.show();  
  14.    w.move(200,100);  
  15.    return a.exec();  


关键的语句,就是其中的:

[cpp] view plain copy print ?
  1. w.setWindowOpacity(1);      
  2. w.setWindowFlags(Qt::FramelessWindowHint);      
  3. w.setAttribute(Qt::WA_TranslucentBackground);  

这些语句,不知道什么意思就摁下F1,或者直接查阅帮助文档……

对窗体无边框的设置要写在main里面,这样所有派生的子窗口,QDialog,QWidget都可继承,  很好规划和管理,方便统一美化设计。

以工程中一个聊天窗口为例,先用PS制作一个窗体的背景图片,注意存为png格式,这是透明的关键。不会使PS,可以找些PNG资源图片。   我的PNG透明背景图为:

 

 Qt 无边框、透明、可移动、的个性窗体案例详解_第1张图片

将它添加到你的资源包中,然后设置为窗体的背景。     

下图是我的工程,其中的场景设置其实也是更换组建的背景图片喽~~   Qt 无边框、透明、可移动、的个性窗体案例详解_第2张图片

     

这个你就可以预览到透明的无边框窗体了,但是还有一个重要的问题,窗口竟然无法移动。
这也是无边框导致的……具体原因我不细说,搜一下很清晰,我只说解决方案。
在每个子窗口中,都添加:

[cpp] view plain copy print ?
  1. void yourwindow::mousePressEvent(QMouseEvent *event){                                                                                                          
  2.         this->windowPos = this->pos();   
  3.         this->mousePos = event->globalPos();  
  4.         this->dPos = mousePos - windowPos;  
  5. }  
  6. void yourwindow::mouseMoveEvent(QMouseEvent *event){   
  7.         this->move(event->globalPos() - this->dPos);  
  8. }  


这样就大功告成了,运行一下看看效果,绿森林是俺滴桌面,可以忽略之。

 

Qt 无边框、透明、可移动、的个性窗体案例详解_第3张图片

你可能感兴趣的:(GUI,qt)