Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1308152
  • 博文数量: 164
  • 博客积分: 2993
  • 博客等级: 少校
  • 技术积分: 1718
  • 用 户 组: 普通用户
  • 注册时间: 2011-06-24 11:42
文章分类

全部博文(164)

文章存档

2014年(1)

2013年(36)

2012年(90)

2011年(37)

分类: Python/Ruby

2012-02-24 16:37:01

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

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

//main.cpp int main(int argc, char *argv[]){ QApplication::setStyle("cleanlooks"); QApplication a(argc, argv); login w; w.setWindowTitle("ClientLogin"); w.setWindowOpacity(1); w.setWindowFlags(Qt::FramelessWindowHint); w.setAttribute(Qt::WA_TranslucentBackground); w.show(); w.move(200,100); return a.exec();}



  关键的语句,就是其中的

  1. w.setWindowOpacity(1);      
  2. w.setWindowFlags(Qt::FramelessWindowHint);      
  3. w.setAttribute(Qt::WA_TranslucentBackground);  

w.setWindowOpacity(1); w.setWindowFlags(Qt::FramelessWindowHint); w.setAttribute(Qt::WA_TranslucentBackground);


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

       对窗体无边框的设置要写在main里面,这样所有派生的子窗口,QDialog,QWidget都可继承,  很好规划和管理,方便统一美化设计。以工程中一个聊天窗口为例,先用PS制作一个窗体的背景图片,注意存为png格式,这是透明的关键。不会使PS,可以找些PNG资源图片。   我的PNG透明背景图为:

 

 

 

将它添加到你的资源包中,然后设置为窗体的背景。        下图是我的工程,其中的场景设置其实也是更换组建的背景图片喽~~  
     这个你就可以预览到透明的无边框窗体了,但是还有一个重要的问题,窗口竟然无法移动。 这也是无边框导致的……具体原因我不细说,搜一下很清晰,我只说解决方案。 在每个子窗口中,都添加:
  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. }  
  9. void yourwindow::changeEvent(QEvent *e){     
  10.  QMainWindow::changeEvent(e);      
  11. switch (e->type()) {    
  12.   case QEvent::LanguageChange:        ui->retranslateUi(this);        
  13.   break;    
  14.   default:       
  15.    break;      
  16.   }  
  17. }  
void yourwindow::mousePressEvent(QMouseEvent *event){ this->windowPos = this->pos(); this->mousePos = event->globalPos(); this->dPos = mousePos - windowPos; } void yourwindow::mouseMoveEvent(QMouseEvent *event){ this->move(event->globalPos() - this->dPos);} void yourwindow::changeEvent(QEvent *e){ QMainWindow::changeEvent(e); switch (e->type()) { case QEvent::LanguageChange: ui->retranslateUi(this); break; default: break; }}
  这样就大功告成了,运行一下看看效果,绿森林是俺滴桌面,可以忽略之。  
 欢迎交流

阅读(17101) | 评论(1) | 转发(2) |
给主人留下些什么吧!~~

Jan5_Reyn2014-08-18 12:52:43

这样设置之后没有办法拉伸窗口,请问怎么实现?