Qt在做界面(分QWindow 和QWidget两类)时,不仅仅有windows窗体风格,还有无标题的widget(去掉了标题栏和侧边滚动条栏).
下面是我通过继承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();//恢复鼠标指针
}
这样运行程序后就只显示出一条龙了....