QT图片轮播器实现方法二(QT实操2)

1.项目架构

1.UI界面

2.widget.h​

cpp 复制代码
#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QTimer>

#define TIMEOUT 1 * 1000
QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

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

private slots:
    void on_startButton_clicked();
    void timeoutSlot();


    void on_stopButton_clicked();

    void on_singleButton_clicked();

private:
    Ui::Widget *ui;
    QTimer *timer;
    int picId;
};
#endif // WIDGET_H

3.main.cpp​

cpp 复制代码
#include "widget.h"

#include <QApplication>

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

3.widget.cpp​

cpp 复制代码
#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    timer = new QTimer;

    picId = 2;
    QImage img;
    img.load("/data/wzh/QT/Qt_1/picture/1.png");
    ui->label->setPixmap(QPixmap::fromImage(img));
    //定时器时间到,发出timeout信号
    connect(timer,&QTimer::timeout,this,&Widget::timeoutSlot);
}

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


void Widget::on_startButton_clicked()
{
    timer->start(TIMEOUT);
}

void Widget::timeoutSlot()
{
    QString path("/data/wzh/QT/Qt_1/picture/");
    path += QString::number(picId);
    path += ".png";
    QImage img;
    img.load(path);
    ui->label->setPixmap(QPixmap::fromImage(img));
    picId++;
    if (5 == picId)
        picId = 1;
}

void Widget::on_stopButton_clicked()
{
    timer->stop();
}


void Widget::on_singleButton_clicked()
{
    QTimer::singleShot(1000,this,SLOT(timeoutSlot()));
}

2. 程序讲解

1. 初始化界面

cpp 复制代码
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    timer = new QTimer;

    picId = 2;
    QImage img;
    img.load("/data/wzh/QT/Qt_1/picture/1.png");
    ui->label->setPixmap(QPixmap::fromImage(img));
    // 定时器时间到,发出timeout信号
    connect(timer, &QTimer::timeout, this, &Widget::timeoutSlot);
}
  • 定时器初始化 :创建一个QTimer对象,用于定时触发事件。

  • 图片加载 :使用QImage加载第一张图片,并通过QPixmap::fromImage转换为QPixmap显示在QLabel上。

  • 信号槽连接 :将定时器的timeout信号连接到timeoutSlot槽函数,确保定时器触发时调用图片切换逻辑。

2. 启动定时器

cpp 复制代码
void Widget::on_startButton_clicked()
{
    timer->start(TIMEOUT);
}
  • 定时器启动 :点击"开始"按钮时,调用timer->start(TIMEOUT)启动定时器,TIMEOUT为定时器的时间间隔(毫秒)。

3. 定时器事件处理

cpp 复制代码
void Widget::timeoutSlot()
{
    QString path("/data/wzh/QT/Qt_1/picture/");
    path += QString::number(picId);
    path += ".png";
    QImage img;
    img.load(path);
    ui->label->setPixmap(QPixmap::fromImage(img));
    picId++;
    if (5 == picId)
        picId = 1;
}
  • 图片路径构造 :根据picId构造图片的完整路径。

  • 图片加载与显示 :使用QImage加载图片并转换为QPixmap,更新QLabel显示。

  • 图片ID循环picId递增,当达到5时重置为1,实现循环播放。

4. 停止定时器

cpp 复制代码
void Widget::on_stopButton_clicked()
{
    timer->stop();
}
  • 定时器停止 :点击"停止"按钮时,调用timer->stop()停止定时器。

5. 单次定时器

cpp 复制代码
void Widget::on_singleButton_clicked()
{
    QTimer::singleShot(1000, this, SLOT(timeoutSlot()));
}
  • 单次定时器 :点击"单次"按钮时,使用QTimer::singleShot设置一个单次定时器,1000毫秒后触发timeoutSlot,实现单次图片切换。
相关推荐
破刺不会编程14 分钟前
linux线程概念和控制
linux·运维·服务器·开发语言·c++
henreash22 分钟前
NLua和C#交互
开发语言·c#·交互
程序员编程指南30 分钟前
Qt OpenGL 集成:开发 3D 图形应用
c语言·数据库·c++·qt·3d
萌新小白的逆袭1 小时前
《Maven 核心基础笔记(第一天)》
java·开发语言·spring
小徐不徐说1 小时前
动态规划:从入门到精通
数据结构·c++·算法·leetcode·动态规划·代理模式
苦学编程的谢1 小时前
MyBatis_3
java·开发语言·后端·mybatis
go54631584652 小时前
Python点阵字生成与优化:从基础实现到高级渲染技术
开发语言·人工智能·python·深度学习·分类·数据挖掘
猫头虎2 小时前
2025年02月11日 Go生态洞察:Go 1.24 发布亮点全面剖析
开发语言·后端·python·golang·go·beego·go1.19
程序员编程指南2 小时前
Qt 网络编程进阶:RESTful API 调用
c语言·网络·c++·qt·restful
仰望天空—永强2 小时前
PS 2025【七月最新v26.5】PS铺软件安装|最新版|附带安装文件|详细安装说明|附PS插件
开发语言·图像处理·python·图形渲染·photoshop