From b4be87600f47874c52b0b770b9164dac1778cfc5 Mon Sep 17 00:00:00 2001 From: mathildemerle Date: Thu, 12 Oct 2023 14:12:45 +0200 Subject: [PATCH] Merge pull request #1145 from mathildemerle/splashSpeed [SplashScreen] speeds up launch removing txt on splashscreen --- src/app/medInria/main.cpp | 10 +----- src/app/medInria/medSplashScreen.cpp | 51 ---------------------------- src/app/medInria/medSplashScreen.h | 36 +------------------- 3 files changed, 2 insertions(+), 95 deletions(-) diff --git a/src/app/medInria/main.cpp b/src/app/medInria/main.cpp index 386dc31396..fe548f99c5 100644 --- a/src/app/medInria/main.cpp +++ b/src/app/medInria/main.cpp @@ -149,8 +149,6 @@ int main(int argc,char* argv[]) bool show_splash = false; #endif - medSettingsManager* mnger = medSettingsManager::instance(); - QStringList posargs; for (int i=1;isetDatabaseLocation(); @@ -292,8 +285,7 @@ int main(int argc,char* argv[]) QGLFormat::setDefaultFormat(format); } - if (show_splash) - splash.finish(mainwindow); + splash.close(); #if(USE_PYTHON) if(!pythonErrorMessage.isEmpty()) diff --git a/src/app/medInria/medSplashScreen.cpp b/src/app/medInria/medSplashScreen.cpp index cb422f16cc..354738fb94 100644 --- a/src/app/medInria/medSplashScreen.cpp +++ b/src/app/medInria/medSplashScreen.cpp @@ -22,12 +22,10 @@ class medSplashScreenPrivate { public: QPixmap pixmap; - QString message; int alignment; QColor color; }; - //////////////////////////////////////////////////////////////////////////// medSplashScreen::medSplashScreen(const QPixmap& thePixmap) : QWidget(0, Qt::SplashScreen |Qt::FramelessWindowHint|Qt::WindowStaysOnTopHint) @@ -91,61 +89,12 @@ medSplashScreen::~medSplashScreen() d = nullptr; } -//////////////////////////////////////////////////////////////////////////// -void medSplashScreen::clearMessage() -{ - d->message.clear(); - repaint(); -} - -//////////////////////////////////////////////////////////////////////////// -void medSplashScreen::showMessage(const QString& message) -{ - const dtkPlugin* plugin = medPluginManager::instance()->plugin(message); - if (plugin) - { - d->message = QString("Loading: ") + plugin->name(); - } - else - { - d->message = QString("Loading: ") + message; - } - - repaint(); -} - -void medSplashScreen::repaint() -{ - QWidget::repaint(); - QApplication::flush(); - qApp->processEvents(QEventLoop::AllEvents); -} - -void medSplashScreen::finish(QWidget *mainWin) - -{ - if (mainWin) - { -#if defined(Q_OS_LINUX) - Q_UNUSED(QTest::qWaitForWindowExposed(mainWin)); -#endif - } - close(); -} - //////////////////////////////////////////////////////////////////////////// void medSplashScreen::paintEvent(QPaintEvent* pe) { Q_UNUSED(pe); - QRect aTextRect(rect()); - aTextRect.setRect(aTextRect.x() + 120, - aTextRect.y() + 5, - aTextRect.width() - 10, - aTextRect.height() - 10); - QPainter aPainter(this); aPainter.drawPixmap(rect(), d->pixmap); aPainter.setPen(d->color); - aPainter.drawText(aTextRect, d->alignment, d->message); } diff --git a/src/app/medInria/medSplashScreen.h b/src/app/medInria/medSplashScreen.h index 03a364cfad..f5eb5fc9a8 100644 --- a/src/app/medInria/medSplashScreen.h +++ b/src/app/medInria/medSplashScreen.h @@ -18,7 +18,7 @@ class medSplashScreenPrivate; /** - * @brief create SplaScreen widget with translucent background. + * @brief create Splashcreen widget with translucent background. * * not based on QSplashScreen which does not support this feature. Almost all features from the QSplashscreen are replicated, including messages refreshed before a QApplication event loop is running. @@ -38,41 +38,7 @@ class medSplashScreen : public QWidget medSplashScreen(const QPixmap& pixmap); ~medSplashScreen(); - /** - * @brief hides the splashscreen when w is shown. - * - * @param w - */ - void finish(QWidget *w); - - /** - * @brief Repaints the widget without the need of an event loop; - * - */ - void repaint(); - -public slots: - /** - * @brief Clears the message. - * - */ - void clearMessage(); - - /** - * @brief Shows a message with the desired alignment and color. - * - * @param theMessage - * @param theAlignment - * @param theColor - */ - void showMessage(const QString& theMessage); - private: - /** - * @brief - * - * @param pe - */ void paintEvent(QPaintEvent* pe); medSplashScreenPrivate * d;