/* * Strawberry Music Player * This file was part of Clementine. * Copyright 2010, David Sansome * * 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 "coversearchstatistics.h" #include #include #include #include #include #include #include #include class QNetworkReply; class QString; class AlbumCoverFetcherSearch; class CoverProviders; // This class represents a single search-for-cover request. It identifies // and describes the request. struct CoverSearchRequest { // an unique (for one AlbumCoverFetcher) request identifier quint64 id; // a search query QString artist; QString album; // is this only a search request or should we also fetch the first // cover that's found? bool search; }; // This structure represents a single result of some album's cover search request. // It contains an URL that leads to a found cover plus its description (usually // the "artist - album" string). struct CoverSearchResult { // used for grouping in the user interface. This is set automatically - don't // set it manually in your cover provider. QString provider; // description of this result (we suggest using the "artist - album" format) QString description; // an URL of a cover image described by this CoverSearchResult QUrl image_url; }; Q_DECLARE_METATYPE(CoverSearchResult); // This is a complete result of a single search request (a list of results, each // describing one image, actually). typedef QList CoverSearchResults; Q_DECLARE_METATYPE(QList); // 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: AlbumCoverFetcher(CoverProviders *cover_providers, QObject *parent = nullptr, QNetworkAccessManager *network = 0); virtual ~AlbumCoverFetcher() {} static const int kMaxConcurrentRequests; quint64 SearchForCovers(const QString &artist, const QString &album); quint64 FetchAlbumCover(const QString &artist, const QString &album); void Clear(); signals: void AlbumCoverFetched(quint64, const QImage &cover, const CoverSearchStatistics &statistics); void SearchFinished(quint64, const CoverSearchResults &results, const CoverSearchStatistics &statistics); private slots: void SingleSearchFinished(quint64, CoverSearchResults results); void SingleCoverFetched(quint64, const QImage &cover); void StartRequests(); private: void AddRequest(const CoverSearchRequest &req); CoverProviders *cover_providers_; QNetworkAccessManager *network_; quint64 next_id_; QQueue queued_requests_; QHash active_requests_; QTimer *request_starter_; }; #endif // ALBUMCOVERFETCHER_H