Qt的启动界面QSplashScreen详解

Qt的启动界面QSplashScreen详解

通常在程序启动的时候,程序需要进行一些初始化的操作,如连接网络,加载数据等等。而当这些操作耗费的时间超过2秒左右,这会给用户造成不太愉快的体验。因此通常程序在这种情况下,都会在主界面加载完成之前提供一个启动界面。Qt则专门提供了一个简单好用的QSplashScreen类来实现启动界面的功能。

头文件解析

QSplashScreen的头文件如下所示

class Q_WIDGETS_EXPORT QSplashScreen : public QWidget
{
    Q_OBJECT
public:

	/**
	 *  \brief  构造函数之一
	 *  \param  pixmap 图片资源
	 *  \param  f 窗口的标签,如可以设置该启动界面置顶等
	 */
    explicit QSplashScreen(const QPixmap &pixmap = QPixmap(), Qt::WindowFlags f = Qt::WindowFlags());

	/**
	 *  \brief 如果你的电脑是多屏的那么你就可以通过QScreen来设置当前的启动界面放置在哪个屏幕上面。只在Qt5.15之后才能使用。
	 *  \param screen 屏幕
	 *  \param pixmap 图片资源
	 *  \param f 窗口的标签,如可以设置该启动界面置顶等
	 */
    QSplashScreen(QScreen *screen, const QPixmap &pixmap = QPixmap(), Qt::WindowFlags f = Qt::WindowFlags());
	/**
   	 * \brief 析构函数
	 */
    virtual ~QSplashScreen();
	
	/**
	 * \brief 在构造函数之后,再次设置图片
	 * \param  pixmap 图片资源
	 */
    void setPixmap(const QPixmap &pixmap);

	/**
	 * \brief 返回当前的图片资源
	 */
    const QPixmap pixmap() const;
    
    /**
   	 * \brief 一般用来设置在主界面完全显示出来之后在退出该启动界面
   	 * \param w 一般为主界面
     */
    void finish(QWidget *w);
	
	/**
 	 *  \brief  QWidget的重绘函数
	 */
    void repaint();

	/**
	 * \brief 返回当前的提示消息
	 */
    QString message() const;

public Q_SLOTS:
	/**
	 * \brief 常用的槽函数之一,用来给启动界面设置提示消息
	 * \param message 提示的消息,可以为html文本
	 * \param alignment 对齐方式
	 * \param color 消息的颜色
	 */
    void showMessage(const QString &message, int alignment = Qt::AlignLeft,
                  const QColor &color = Qt::black);
 
 	/**
 	 * \brief 清空当前的提示消息
 	 */
    void clearMessage();

Q_SIGNALS:
	
	/**
	 * \brief 当前的提示消息改变之后的信号
	 * \param message 改变后的消息
	 */
    void messageChanged(const QString &message);

protected:
	/**
	 *  \brief 一些通用的事件
	 */
    bool event(QEvent *e) override;
    virtual void drawContents(QPainter *painter);
    void mousePressEvent(QMouseEvent *) override;

private:
	//禁止拷贝构造
    Q_DISABLE_COPY(QSplashScreen)
    Q_DECLARE_PRIVATE(QSplashScreen)
};

使用场景

一般是在main函数当前使用,代码如下。

#include "mainwindow.h"

#include <QApplication>
#include <QSplashScreen>

int main(int argc, char *argv[])
{
  QApplication a(argc, argv);

  QPixmap pixmap(":/picture/loader.jpg");  //这里填写图片的路径
  QSplashScreen splash(pixmap);
  splash.show();  //显示启动界面

#if QT_DEPRECATED_SINCE(5, 15)   //qt5.15之后的版本
  QScreen *screen = QGuiApplication::screens().at(1);  
  QPixmap pixmap(":/Chess/picture/loader.jpg");
  QSplashScreen splash(screen, pixmap);  //设置显示到的屏幕
  splash.show();
#endif

  //启动第一阶段
  
  ... //do something
  splash.showMessage(QStringLiteral("load file"), Qt::AlignHCenter|Qt::AlignBottom, Qt::white);  //设置消息

  //用户可以通过用鼠标单击来隐藏启动画面。由于启动画面通常在事件循环开始运行之前显示,因此有必要定期调用 QCoreApplication::processEvents() 以接收鼠标点击。
  QCoreApplication::processEvents();
  
  //启动第二阶段
  
  ... //do something
  //showMessage甚至于可以接受HTML格式的字符串,它会自动解析其样式,不过这个时候最后一个color参数将会失效
  splash.showMessage(QStringLiteral("<div style='background:#000; color:#FFF'>背景为黑色"), Qt::AlignHCenter|Qt::AlignVCenter);
  QCoreApplication::processEvents();

  MainWindow w;
  w.show();
  splash.finish(&w);  //等到w界面显示完成之后,启动界面才会退出
  return a.exec();
}

以上就是QSplashScreen 类的基本介绍和使用

  • 5
    点赞
  • 54
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值