Qt在作界面(分QWindow 和QWidget两类)时,不单单有windows窗体风格,还有无标题的窗体(实则 去掉了标题栏和侧边滚动条栏).windows
下面是我经过继承QWidget基类,作了一个龙图形的不规则窗体,支持 鼠标左键拖动 和 右键关闭程序 效果以下:ide
实际上窗体中只是画了一个背景透明的图片 /image/dragon.gif 利用Qt的setMask()函数作出遮罩效果。函数
主要代码以下widget.cppui
首先是头文件:this
#include "widget.h" #include "ui_widget.h" #include <QPixmap> #include <QBitmap> #include <QPainter> #include <QMouseEvent>
接着是构造函数:spa
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")); }
鼠标按下事件:rest
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(); } }
鼠标移动事件:code
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);//指针位置和窗口位置的差值 } }
鼠标释放事件:blog
void Widget::mouseReleaseEvent(QMouseEvent *event) { if(!event->buttons()) { QCursor cursor; cursor.setShape(Qt::ArrowCursor); setCursor(cursor); } //QApplication::restoreOverrideCursor();//恢复鼠标指针 }
整个过程就此结束,仍是比较简单的。。