Merge pull request #792 from chme/nowplaying_artwork

Fix for Remote not showing nowplaying artwork for Spotify tracks
This commit is contained in:
ejurgensen 2019-08-25 22:41:36 +02:00 committed by GitHub
commit ef0a194644
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -602,11 +602,6 @@ get_album_image(json_object *jsonalbum, int max_w)
artwork_url = NULL; artwork_url = NULL;
if (max_w <= 0)
{
return NULL;
}
if (!json_object_object_get_ex(jsonalbum, "images", &jsonimages)) if (!json_object_object_get_ex(jsonalbum, "images", &jsonimages))
{ {
DPRINTF(E_DBG, L_SPOTIFY, "No images in for spotify album object found\n"); DPRINTF(E_DBG, L_SPOTIFY, "No images in for spotify album object found\n");
@ -616,6 +611,7 @@ get_album_image(json_object *jsonalbum, int max_w)
// Find first image that has a smaller width than the given max_w // Find first image that has a smaller width than the given max_w
// (this should avoid the need for resizing and improve performance at the cost of some quality loss) // (this should avoid the need for resizing and improve performance at the cost of some quality loss)
// Note that Spotify returns the images ordered descending by width (widest image first) // Note that Spotify returns the images ordered descending by width (widest image first)
// Special case is if no max width (max_w = 0) is given, the widest images will be used
image_count = json_object_array_length(jsonimages); image_count = json_object_array_length(jsonimages);
for (index = 0; index < image_count; index++) for (index = 0; index < image_count; index++)
{ {
@ -624,7 +620,7 @@ get_album_image(json_object *jsonalbum, int max_w)
{ {
artwork_url = jparse_str_from_obj(jsonimage, "url"); artwork_url = jparse_str_from_obj(jsonimage, "url");
if (jparse_int_from_obj(jsonimage, "width") <= max_w) if (max_w <= 0 || jparse_int_from_obj(jsonimage, "width") <= max_w)
{ {
// We have the first image that has a smaller width than the given max_w // We have the first image that has a smaller width than the given max_w
break; break;
@ -650,8 +646,7 @@ parse_metadata_track(json_object *jsontrack, struct spotify_track *track, int ma
if (json_object_object_get_ex(jsonalbum, "artists", &jsonartists)) if (json_object_object_get_ex(jsonalbum, "artists", &jsonartists))
track->album_artist = jparse_str_from_array(jsonartists, 0, "name"); track->album_artist = jparse_str_from_array(jsonartists, 0, "name");
if (max_w > 0) track->artwork_url = get_album_image(jsonalbum, max_w);
track->artwork_url = get_album_image(jsonalbum, max_w);
} }
if (json_object_object_get_ex(jsontrack, "artists", &jsonartists)) if (json_object_object_get_ex(jsontrack, "artists", &jsonartists))