diff options
Diffstat (limited to 'core')
-rw-r--r-- | core/src/main/java/de/danoeh/antennapod/core/asynctask/PicassoProvider.java | 27 |
1 files changed, 15 insertions, 12 deletions
diff --git a/core/src/main/java/de/danoeh/antennapod/core/asynctask/PicassoProvider.java b/core/src/main/java/de/danoeh/antennapod/core/asynctask/PicassoProvider.java index 6d9353a93..1ed29c23a 100644 --- a/core/src/main/java/de/danoeh/antennapod/core/asynctask/PicassoProvider.java +++ b/core/src/main/java/de/danoeh/antennapod/core/asynctask/PicassoProvider.java @@ -76,19 +76,11 @@ public class PicassoProvider { private static class MediaRequestHandler extends RequestHandler { - final MediaMetadataRetriever mmr; final Context context; public MediaRequestHandler(Context context) { super(); this.context = context; - mmr = new MediaMetadataRetriever(); - } - - @Override - protected void finalize() throws Throwable { - super.finalize(); - mmr.release(); } @Override @@ -99,11 +91,22 @@ public class PicassoProvider { @Override public Result load(Request data) throws IOException { Bitmap bitmap = null; - mmr.setDataSource(data.uri.getPath()); - byte[] image = mmr.getEmbeddedPicture(); - if (image != null) { - bitmap = decodeStreamFromByteArray(data, image); + MediaMetadataRetriever mmr = null; + try { + mmr = new MediaMetadataRetriever(); + mmr.setDataSource(data.uri.getPath()); + byte[] image = mmr.getEmbeddedPicture(); + if (image != null) { + bitmap = decodeStreamFromByteArray(data, image); + } + } catch (RuntimeException e) { + Log.e(TAG, "Failed to decode image in media file", e); + } finally { + if (mmr != null) { + mmr.release(); + } } + if (bitmap == null) { // check for fallback Uri String fallbackParam = data.uri.getQueryParameter(PicassoImageResource.PARAM_FALLBACK); |