QT学习(5) 手动窗口重绘

仍然关注paintEvent,在上例中,它自动调用了。

这里想要手动调用paintEvent,该怎么做呢?

QT学习(5) 手动窗口重绘_第1张图片 

官方文档说,可以通过调用repaint或者update方法来重绘窗口。

在UI设计窗口添加一个按钮,当我们按下这个按钮时,让窗口上的一个图片从左往右移动一段距离。当图片到达窗口最右边时,再次点击按钮,图片会回到窗口的最左边。

在窗口中绘制图片:

p.drawPixmap(x, 300, 80, 80, QPixmap("../Image/noya.jpg"));

按钮点击的事件响应函数:

void Widget::on_pushButton_clicked()
{
    x += 20;
    if(x > width()){
        x = 0;
    }
    //刷新窗口,让窗口重绘
    update();
}

初始状态:

QT学习(5) 手动窗口重绘_第2张图片

点了几下之后:

QT学习(5) 手动窗口重绘_第3张图片 

点到了最右边,脸都被遮住了:

QT学习(5) 手动窗口重绘_第4张图片 

继续点击,就又回到初始状态了。

很简单的例子,通过按钮的事件响应函数调用update重绘窗口。 

整理自B站视频,侵删歉。

你可能感兴趣的:(QT笔记)