常见的窗体通常是各种方形的对话框,但有时也需要使用非方形的窗体,如原型、椭圆形、甚至于是不规则形状的对话框。

利用​​setMask()​​函数为窗体设置遮罩,实现不规则窗体。设置遮罩后的窗体尺寸仍然是原窗体大小,只是被遮罩的地方不可见。

下面通过一个实例来介绍它的使用

一、运行结果

学习QT之不规则窗体_#include

二、具体代码

​shapewidget.h​

#ifndef SHAPEWIDGET_H
#define SHAPEWIDGET_H

#include <QWidget>

class ShapeWidget : public QWidget
{
Q_OBJECT

public:
ShapeWidget(QWidget *parent = 0);
~ShapeWidget();

protected:
void mousePressEvent(QMouseEvent *);
void mouseMoveEvent(QMouseEvent *);
void paintEvent(QPaintEvent *);


private:
QPoint dragPosition;
};

#endif // SHAPEWIDGET_H

​shapewidget.cpp​

#include "shapewidget.h"
#include <QMouseEvent>
#include <QPainter>
#include <QPixmap>
#include <QBitmap>

ShapeWidget::ShapeWidget(QWidget *parent)
: QWidget(parent)
{
QPixmap pix;
pix.load("321.png",0,Qt::AvoidDither | Qt::ThresholdDither | Qt::ThresholdAlphaDither); //注(1)
resize(pix.size()); //注(2)
setMask(QBitmap(pix.mask())); //注(3)
}

ShapeWidget::~ShapeWidget()
{

}

void ShapeWidget::mousePressEvent(QMouseEvent *event)
{
if(event->button() == Qt::LeftButton)
{
dragPosition = event->globalPos()-frameGeometry().topLeft();
event->accept();
}
if(event->button() == Qt::RightButton)
{
close();
}
}

void ShapeWidget::mouseMoveEvent(QMouseEvent *event)
{
if(event->buttons() & Qt::LeftButton)
{
move(event->globalPos()-dragPosition);
event->accept();
}
}

void ShapeWidget::paintEvent(QPaintEvent *event) //注(4)
{
QPainter painter(this);
painter.drawPixmap(0,0,QPixmap("321.png"));
}

注(1):调用​​QPixmap​​​的​​load()​​​函数为​​QPixmap​​​对象填入图像值;​​load()​​函数的原型如下:

bool QPixmap::load(const QString & fileName,const char * format = 0,Qt::ImageConversionFlags flags = Qt::Auto)

其中参数fileName为图片文件名;参数format表示读取图片文件采用的格式,此处为0,表示采用默认的格式。参数flags表示读取图片的方式,由Qt::ImageConversionFlags定义,此处设置的标识为避免图片抖动方式。

注(2):重设主窗体的尺寸为所读取的图片的大小。

注(3):为调用它的控件增加一个遮罩,遮住所选区域以外的部分使其看起来是透明的,它的参数可为一个​​QBitmap​​​对象或一个​​QRegion​​​对象,此处调用​​QPixmap​​​的​​mask()​​​函数用于获取图片自身的遮罩,为一个​​QBixmap​​,实例中使用的是PNG格式的图片,它的透明部分实际上是一个遮罩。

注(4):重绘函数​​painterEvent()​​主要完成在窗体上绘制图片的工作。