diff options
| author | TheKodeToad <TheKodeToad@proton.me> | 2023-07-02 16:44:54 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-07-02 16:44:54 +0100 | 
| commit | 43e6f05ed5931180f04681f8c7cb255b23f293bd (patch) | |
| tree | 901d878a7fe2ccbcd94dfdc8b72f383284f1e3d0 /launcher/ui | |
| parent | b51f1f1d41a6153c37b1d61a04df8ece5004cc27 (diff) | |
| parent | 75bd626f33a5182facff2ef1f9938f60553c3352 (diff) | |
| download | PrismLauncher-43e6f05ed5931180f04681f8c7cb255b23f293bd.tar.gz PrismLauncher-43e6f05ed5931180f04681f8c7cb255b23f293bd.tar.bz2 PrismLauncher-43e6f05ed5931180f04681f8c7cb255b23f293bd.zip | |
Merge pull request #1232 from telans/screenshots-update
ScreenshotsPage fixes
Diffstat (limited to 'launcher/ui')
| -rw-r--r-- | launcher/ui/pages/instance/ScreenshotsPage.cpp | 64 | 
1 files changed, 31 insertions, 33 deletions
| diff --git a/launcher/ui/pages/instance/ScreenshotsPage.cpp b/launcher/ui/pages/instance/ScreenshotsPage.cpp index 35237594..bcce5f57 100644 --- a/launcher/ui/pages/instance/ScreenshotsPage.cpp +++ b/launcher/ui/pages/instance/ScreenshotsPage.cpp @@ -97,37 +97,30 @@ public:              return;          if ((info.suffix().compare("png", Qt::CaseInsensitive) != 0))              return; -        int tries = 5; -        while (tries) -        { -            if (!m_cache->stale(m_path)) -                return; -            QImage image(m_path); -            if (image.isNull()) -            { -                QThread::msleep(500); -                tries--; -                continue; -            } -            QImage small; -            if (image.width() > image.height()) -                small = image.scaledToWidth(512).scaledToWidth(256, Qt::SmoothTransformation); -            else -                small = image.scaledToHeight(512).scaledToHeight(256, Qt::SmoothTransformation); -            QPoint offset((256 - small.width()) / 2, (256 - small.height()) / 2); -            QImage square(QSize(256, 256), QImage::Format_ARGB32); -            square.fill(Qt::transparent); - -            QPainter painter(&square); -            painter.drawImage(offset, small); -            painter.end(); - -            QIcon icon(QPixmap::fromImage(square)); -            m_cache->add(m_path, icon); -            m_resultEmitter.emitResultsReady(m_path); +        if (!m_cache->stale(m_path)) +            return; +        QImage image(m_path); +        if (image.isNull()) { +            m_resultEmitter.emitResultsFailed(m_path); +            qDebug() << "Error loading screenshot: " + m_path + ". Perhaps too large?";              return;          } -        m_resultEmitter.emitResultsFailed(m_path); +        QImage small; +        if (image.width() > image.height()) +            small = image.scaledToWidth(512).scaledToWidth(256, Qt::SmoothTransformation); +        else +            small = image.scaledToHeight(512).scaledToHeight(256, Qt::SmoothTransformation); +        QPoint offset((256 - small.width()) / 2, (256 - small.height()) / 2); +        QImage square(QSize(256, 256), QImage::Format_ARGB32); +        square.fill(Qt::transparent); + +        QPainter painter(&square); +        painter.drawImage(offset, small); +        painter.end(); + +        QIcon icon(QPixmap::fromImage(square)); +        m_cache->add(m_path, icon); +        m_resultEmitter.emitResultsReady(m_path);      }      QString m_path;      SharedIconCachePtr m_cache; @@ -146,9 +139,12 @@ public:          m_thumbnailCache = std::make_shared<SharedIconCache>();          m_thumbnailCache->add("placeholder", APPLICATION->getThemedIcon("screenshot-placeholder"));          connect(&watcher, SIGNAL(fileChanged(QString)), SLOT(fileChanged(QString))); -        // FIXME: the watched file set is not updated when files are removed      } -    virtual ~FilterModel() { m_thumbnailingPool.waitForDone(500); } +    virtual ~FilterModel() { +        m_thumbnailingPool.clear(); +        if (!m_thumbnailingPool.waitForDone(500)) +            qDebug() << "Thumbnail pool took longer than 500ms to finish"; +    }      virtual QVariant data(const QModelIndex &proxyIndex, int role = Qt::DisplayRole) const      {          auto model = sourceModel(); @@ -215,10 +211,12 @@ private slots:      void fileChanged(QString filepath)      {          m_thumbnailCache->setStale(filepath); -        thumbnailImage(filepath);          // reinsert the path...          watcher.removePath(filepath); -        watcher.addPath(filepath); +        if (QFile::exists(filepath)) { +            watcher.addPath(filepath); +            thumbnailImage(filepath); +        }      }  private: | 
