Qt绘制不规则窗体
Qt在做界面(分QWindow 和QWidget两类)时,不仅仅有windows窗体风格,还有无标题的窗体(实则 去掉了标题栏和侧边滚动条栏).
下面是我通过继承QWidget基类,做了一个龙图形的不规则窗体,支持 鼠标左键拖动 和 右键关闭程序 效果如下:
实际上窗体中只是画了一个背景透明的图片 /image/dragon.gif 利用Qt的setMask()函数做出遮罩效果。
主要代码如下widget.cpp
首先是头文件:
#include "widget.h" #include "ui_widget.h" #include <QPixmap> #include <QBitmap> #include <QPainter> #include <QMouseEvent>
接着是构造函数:
Widget::Widget(QWidget *parent) : QWidget(parent), ui(new Ui::Widget) { ui->setupUi(this); QPixmap pix; //加载图片 pix.load(":/image/dragon.gif"); //设置窗口大小为图片大小 resize(pix.size()); //窗口设置遮罩 setMask(pix.mask()); } Widget::~Widget() { delete ui; }
画图:
void Widget::paintEvent(QPaintEvent *) { QPainter painter(this); //从窗口左上角开始绘制图片 painter.drawPixmap(0,0,QPixmap(":/image/dragon.gif")); }
鼠标按下事件:
void Widget::mousePressEvent(QMouseEvent *event) { if(event->button()== Qt::LeftButton) { // QPoint temp; offset=event->globalPos()-pos(); //move(temp); } //关闭窗口 else if(event->button()==Qt::RightButton) { close(); } }
鼠标移动事件:
void Widget::mouseMoveEvent(QMouseEvent *event) { if(event->buttons()&Qt::LeftButton) { QPoint temp;//移动距离 //光标形状 QCursor cursor; cursor.setShape(Qt::OpenHandCursor); setCursor(cursor); temp=event->globalPos()-offset; move(temp);//指针位置和窗口位置的差值 } }
鼠标释放事件:
void Widget::mouseReleaseEvent(QMouseEvent *event) { if(!event->buttons()) { QCursor cursor; cursor.setShape(Qt::ArrowCursor); setCursor(cursor); } //QApplication::restoreOverrideCursor();//恢复鼠标指针 }
整个过程就此结束,还是比较简单的。。