4_3_paintEvent(绘画事件)、closeEvent(关闭窗口事件)、resizeEvent(窗体大小事件)

1、绘画事件

在这里插入图片描述

2、效果

在这里插入图片描述

3、widget.cpp

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);
    index=338;
    connect(ui->btn_1,SIGNAL(clicked()),this,SLOT(doProcessBtnClicked()));
}

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

void Widget::mousePressEvent(QMouseEvent *event){

    QPoint m = event->globalPos();
    ui->textEdit->append(QString("(%1,%2)").arg(m.x()).arg(m.y()));//坐标追加到textEdit里显示
}

//绘画事件
void Widget::paintEvent(QPaintEvent *event){
    QPainter mypainter(this);
    //用图画--背景
    mypainter.drawPixmap(0,0,this->width(),this->height(),QPixmap("../GIF/1.gif"));
    QPen pen1;
    pen1.setStyle(Qt::DotLine);//虚线
    pen1.setColor(Qt::red);//笔色
    pen1.setWidth(2);//笔粗

    //用笔画
    /*
    QPointF类使用浮点精度定义平面中的点。
    QPoint类使用整数精度定义平面中的点
    */
    mypainter.setPen(pen1);
    mypainter.drawLine(QPointF(0,0),QPointF(this->width(),this->height()));//两个坐标画虚线
    mypainter.drawRect(100,100,500,500);//画矩形
    mypainter.drawEllipse(QPoint(this->width()/2,this->height()/2),100,50);//画椭圆

    QBrush mybrush;
    mybrush.setStyle(Qt::CrossPattern);
    mybrush.setColor(QColor(121,54,36));//颜色 R G B
    mybrush.setColor(Qt::yellow);//颜色为黄色
    mypainter.setBrush(mybrush);

    QPointF points[4]={
        QPointF(134.0,92.0),
        QPointF(959.0,194.0),
        QPointF(809.0,712.0),
        QPointF(index,500.0)
    };
    mypainter.drawPolygon(points,4);//画多边形
}

//关闭窗口事件
void Widget::closeEvent(QCloseEvent *event){
    int ret = QMessageBox::information(this,"message","are you quit?",QMessageBox::Yes|QMessageBox::No);
    if(ret==QMessageBox::Yes)
    {
        event->accept();
    }
    else {
        event->ignore();
    }
}


//窗体大小事件
void Widget::resizeEvent(QResizeEvent *event){
        qDebug()<<"old:"<<event->oldSize()<<endl;
        qDebug()<<"new:"<<event->size()<<endl;
}

//按键信号处理
void Widget::doProcessBtnClicked(){
    qDebug()<<"btn_clicked"<<endl;
    index -=10;
    this->update();//跟新组件
}


4、widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QDebug>
#include <QMouseEvent>
#include <QPainter>
#include <QPen>
#include <QPaintEvent>

#include <QMessageBox>
#include <QCloseEvent>
#include <QResizeEvent>
namespace Ui {
class Widget;
}

class Widget : public QWidget
{
    Q_OBJECT

public:
    explicit Widget(QWidget *parent = nullptr);
    ~Widget();

private:
    Ui::Widget *ui;


    int index;
    void Init();
protected:
   void mousePressEvent(QMouseEvent *event);//鼠标按下事件
   void paintEvent(QPaintEvent *event);//绘画事件
   void closeEvent(QCloseEvent *event);//关闭窗口事件
   void resizeEvent(QResizeEvent *event);

private slots:
   void doProcessBtnClicked();//信号槽
};

#endif // WIDGET_H

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt中,QWidget的paintEvent事件用于处理绘图操作。当需要重新绘制窗口或部件时,Qt会自动调用该事件。在paintEvent事件中,您可以使用QPainter类进行绘图操作。通常,您需要在QWidget的子类中重新实现paintEvent事件来实现自定义绘图。以下是paintEvent事件的示例代码: ```c++ void MyWidget::paintEvent(QPaintEvent *event) { QPainter painter(this); painter.setPen(Qt::red); painter.setFont(QFont("Arial", 20)); painter.drawText(rect(), Qt::AlignCenter, "Hello World!"); } ``` 在这里,我们重新实现了QWidget的paintEvent事件,使用QPainter类在窗口中绘制了一段红色的“Hello World!”文本。首先,我们创建了一个QPainter对象,并将QWidget的this指针作为参数传递。接着,我们设置了绘图的画笔颜色和字体。最后,我们使用drawText方法在窗口中绘制文本。drawText方法的第一个参数是绘制文本的矩形区域,第二个参数是对齐方式,第三个参数是要绘制的文本内容。 需要注意的是,paintEvent事件窗口首次显示时会自动调用,以及每次需要重新绘制窗口时也会自动调用。因此,如果您需要在窗口中绘制动态内容,例如时钟、进度条等,您需要在paintEvent事件中实现相应的逻辑,以便在需要时重新绘制窗口。另外,如果您需要在窗口中显示大量的绘图内容,建议使用QPainter的高级绘图函数,例如drawRect、drawEllipse、drawImage等,以提高绘图效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值