学习QT之不规则窗体
原创
©著作权归作者所有:来自51CTO博客作者贝勒里恩的原创作品,请联系作者获取转载授权,否则将追究法律责任
常见的窗体通常是各种方形的对话框,但有时也需要使用非方形的窗体,如原型、椭圆形、甚至于是不规则形状的对话框。
利用setMask()
函数为窗体设置遮罩,实现不规则窗体。设置遮罩后的窗体尺寸仍然是原窗体大小,只是被遮罩的地方不可见。
下面通过一个实例来介绍它的使用:
一、运行结果
二、具体代码
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()
主要完成在窗体上绘制图片的工作。