/* * Strawberry Music Player * This file was part of Clementine. * Copyright 2010, David Sansome * Copyright 2018-2021, Jonas Kvinge * * Strawberry is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Strawberry is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Strawberry. If not, see . * */ #ifndef ALBUMCOVERFETCHER_H #define ALBUMCOVERFETCHER_H #include "config.h" #include #include #include #include #include #include #include #include #include #include #include #include "coversearchstatistics.h" #include "albumcoverimageresult.h" class QTimer; class NetworkAccessManager; class CoverProviders; class AlbumCoverFetcherSearch; // This class represents a single search-for-cover request. It identifies and describes the request. struct CoverSearchRequest { explicit CoverSearchRequest() : id(0), search(false), batch(false) {} // An unique (for one AlbumCoverFetcher) request identifier quint64 id; // A search query QString artist; QString album; QString title; // Is this only a search request or should we also fetch the first cover that's found? bool search; // Is the request part of a batch (fetching all missing covers) bool batch; }; // This structure represents a single result of some album's cover search request. struct CoverProviderSearchResult { explicit CoverProviderSearchResult() : score_provider(0.0), score_match(0.0), score_quality(0.0), number(0) {} // Used for grouping in the user interface. QString provider; // Artist and album returned by the provider QString artist; QString album; // An URL of a cover image QUrl image_url; // Image size QSize image_size; // Score for this provider float score_provider; // Score for match float score_match; // Score for image quality float score_quality; // The result number int number; // Total score for this result float score() const { return score_provider + score_match + score_quality; } }; Q_DECLARE_METATYPE(CoverProviderSearchResult) // This is a complete result of a single search request (a list of results, each describing one image, actually). using CoverProviderSearchResults = QList; Q_DECLARE_METATYPE(CoverProviderSearchResults) // This class searches for album covers for a given query or artist/album and returns URLs. It's NOT thread-safe. class AlbumCoverFetcher : public QObject { Q_OBJECT public: explicit AlbumCoverFetcher(CoverProviders *cover_providers, NetworkAccessManager *network, QObject *parent = nullptr); ~AlbumCoverFetcher() override; static const int kMaxConcurrentRequests; quint64 SearchForCovers(const QString &artist, const QString &album, const QString &title = QString()); quint64 FetchAlbumCover(const QString &artist, const QString &album, const QString &title, const bool batch); void Clear(); signals: void AlbumCoverFetched(const quint64 request_id, const AlbumCoverImageResult &result, const CoverSearchStatistics &statistics); void SearchFinished(const quint64 request_id, const CoverProviderSearchResults &results, const CoverSearchStatistics &statistics); private slots: void SingleSearchFinished(const quint64 id, const CoverProviderSearchResults &results); void SingleCoverFetched(const quint64 id, const AlbumCoverImageResult &result); void StartRequests(); private: void AddRequest(const CoverSearchRequest &req); CoverProviders *cover_providers_; NetworkAccessManager *network_; quint64 next_id_; QQueue queued_requests_; QHash active_requests_; QTimer *request_starter_; }; #endif // ALBUMCOVERFETCHER_H