您现在的位置是:首页 > 技术文章网站首页技术文章

[Qt]根据图片绘制窗体

  • WangYe
  • 2021-01-31 23:59:37
  • 313 次阅读
QT根据图片来绘制窗体

效果:

图片.png

源码:

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>

namespace Ui {
class Widget;
}

class Widget : public QWidget
{
    Q_OBJECT

public:
    explicit Widget(QWidget *parent = 0);
    ~Widget();
protected:
    void mousePressEvent(QMouseEvent *event);
    void mouseMoveEvent(QMouseEvent *event);
    void paintEvent(QPaintEvent *event);

private:
    Ui::Widget *ui;
    QPoint p;
};

#endif // WIDGET_H

widget.cpp

#include "widget.h"
#include "ui_widget.h"
#include <QDebug>
#include <QMouseEvent>
#include <QPainter>

Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);
    //去窗口边框
    this->setWindowFlags(Qt::FramelessWindowHint | this->windowFlags());
    //把窗口背景设置为透明
    this->setAttribute(Qt::WA_TranslucentBackground);
    //以下属性默认为false,即mouseMoveEvent只有在按键按下时移动才能触发
    //this->setMouseTracking(true);
}

Widget::~Widget()
{
    delete ui;
}

void Widget::mousePressEvent(QMouseEvent * e)
{
    //qDebug() << "mouse Press ";
    if(e->button() == Qt::RightButton)
    {
        close();
    }
    else if(e->button() == Qt::LeftButton)
    {
        //获取相对位置
        p = e->globalPos() - this->frameGeometry().topLeft();//包括边框的矩形
        //this->geometry();//获取的是不包括边框的主工作区的矩形
    }
    QWidget::mousePressEvent(e);
}

void Widget::mouseMoveEvent(QMouseEvent *event)
{
    if(event->buttons() & Qt::LeftButton)
    {
        //move设置的是边框的左上角的位置,所以我们要将获取到的鼠标移动的位置减去相对位置,才是左上角应有的位置
        move(event->globalPos() - p);
    }
}


void Widget::paintEvent(QPaintEvent *)
{
    QPainter p(this);
    p.drawPixmap(0, 0, QPixmap(":/res/res/1.png"));    //图片资源
}

main.cpp

#include "widget.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Widget w;
    w.show();
    return a.exec();
}


文章评论 (0)



Top