I am facing a problem while setting album arts(bitmap images) on an image view but surprisingly it only crashes on my phone and runs perfectly fine on the emulator. I don't know what the problem is as i am not able to get in crash reports. But I am pretty sure that the problem is on these lines only :-
try {
MediaMetadataRetriever mmr = new MediaMetadataRetriever();
mmr.setDataSource(songPath);
byte[] data = mmr.getEmbeddedPicture();
bitmap = BitmapFactory.decodeByteArray(data, 0, data.length);
} catch (NullPointerException e) {
bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.round); //Converting resource image into bitmap
e.printStackTrace();
}
Because, on removing these lines makes it run perfectly..
Full method of retrieving data from the external storage is:
public ArrayList<Data> GetPlaylist() {
Bitmap bitmap=null;
ContentResolver contentResolver = getActivity().getContentResolver();
Uri songUri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
Cursor songCursor = contentResolver.query(songUri, null, null, null, MediaStore.Audio.Media.TITLE + " ASC");
if (songCursor != null && songCursor.moveToFirst()) {
do {
int songId = songCursor.getInt(songCursor.getColumnIndex(MediaStore.Audio.Media._ID));
String songTitle = songCursor.getString(songCursor.getColumnIndex(MediaStore.Audio.Media.TITLE));
String songArtist = songCursor.getString(songCursor.getColumnIndex(MediaStore.Audio.Media.ARTIST));
String songPath = songCursor.getString(songCursor.getColumnIndex(MediaStore.Audio.Media.DATA));
try {
MediaMetadataRetriever mmr = new MediaMetadataRetriever();
mmr.setDataSource(songPath);
byte[] data = mmr.getEmbeddedPicture();
bitmap = BitmapFactory.decodeByteArray(data, 0, data.length);
} catch (NullPointerException e) {
bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.round); //Converting resource image into bitmap
e.printStackTrace();
}
songList.add(new Data(songTitle, songArtist,bitmap));
}
while (songCursor.moveToNext());
}
songCursor.close();
return songList;
}
Here is the logcat details :-
03-04 12:09:39.711 30277-30277/com.dannproductions.myproject E/HAL: PATH3 /odm/lib64/hw/gralloc.qcom.so
03-04 12:09:39.711 30277-30277/com.dannproductions.myproject E/HAL: PATH2 /vendor/lib64/hw/gralloc.qcom.so
03-04 12:09:39.711 30277-30277/com.dannproductions.myproject E/HAL: PATH1 /system/lib64/hw/gralloc.qcom.so
03-04 12:09:39.711 30277-30277/com.dannproductions.myproject E/HAL: PATH3 /odm/lib64/hw/gralloc.msm8953.so
03-04 12:09:39.711 30277-30277/com.dannproductions.myproject E/HAL: PATH2 /vendor/lib64/hw/gralloc.msm8953.so
03-04 12:09:39.711 30277-30277/com.dannproductions.myproject E/HAL: PATH1 /system/lib64/hw/gralloc.msm8953.so
03-04 12:09:39.947 30277-30277/com.dannproductions.myproject E/MediaMetadataRetrieverJNI: getEmbeddedPicture: Call to getEmbeddedPicture failed.
03-04 12:09:41.652 30277-30277/com.dannproductions.myproject E/MediaMetadataRetrieverJNI: getEmbeddedPicture: Call to getEmbeddedPicture failed.
03-04 12:09:41.727 30277-30277/com.dannproductions.myproject E/MediaMetadataRetrieverJNI: getEmbeddedPicture: Call to getEmbeddedPicture failed.
03-04 12:09:41.804 30277-30277/com.dannproductions.myproject E/MediaMetadataRetrieverJNI: getEmbeddedPicture: Call to getEmbeddedPicture failed.
03-04 12:09:42.613 30277-30277/com.dannproductions.myproject E/MediaMetadataRetrieverJNI: getEmbeddedPicture: Call to getEmbeddedPicture failed.
03-04 12:09:43.794 30277-30277/com.dannproductions.myproject E/MediaMetadataRetrieverJNI: getEmbeddedPicture: Call to getEmbeddedPicture failed.
03-04 12:09:44.499 30277-30277/com.dannproductions.myproject E/MediaMetadataRetrieverJNI: getEmbeddedPicture: Call to getEmbeddedPicture failed.
03-04 12:09:44.782 30277-30277/com.dannproductions.myproject E/MediaMetadataRetrieverJNI: getEmbeddedPicture: Call to getEmbeddedPicture failed.
03-04 12:09:45.030 30277-30277/com.dannproductions.myproject E/MediaMetadataRetrieverJNI: getEmbeddedPicture: Call to getEmbeddedPicture failed.
03-04 12:09:45.534 30277-30277/com.dannproductions.myproject E/MediaMetadataRetrieverJNI: getEmbeddedPicture: Call to getEmbeddedPicture failed.
03-04 12:09:45.658 30277-30277/com.dannproductions.myproject E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.dannproductions.myproject, PID: 30277
java.lang.OutOfMemoryError: Failed to allocate a 9815052 byte allocation with 4403064 free bytes and 4MB until OOM
at dalvik.system.VMRuntime.newNonMovableArray(Native Method)
at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method)
at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:624)
at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:457)
at android.graphics.BitmapFactory.decodeResource(BitmapFactory.java:480)
at android.graphics.BitmapFactory.decodeResource(BitmapFactory.java:512)
at com.dannproductions.myproject.FragmentMusic.GetPlaylist(FragmentMusic.java:99)
at com.dannproductions.myproject.FragmentMusic.onCreateView(FragmentMusic.java:50)
at android.support.v4.app.Fragment.performCreateView(Fragment.java:2354)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1419)
at android.support.v4.app.FragmentManagerImpl.moveFragmentToExpectedState(FragmentManager.java:1740)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1809)
at android.support.v4.app.BackStackRecord.executeOps(BackStackRecord.java:799)
at android.support.v4.app.FragmentManagerImpl.executeOps(FragmentManager.java:2580)
at android.support.v4.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2367)
at android.support.v4.app.FragmentManagerImpl.removeRedundantOperationsAndExecute(FragmentManager.java:2322)
at android.support.v4.app.FragmentManagerImpl.execSingleAction(FragmentManager.java:2199)
at android.support.v4.app.BackStackRecord.commitNowAllowingStateLoss(BackStackRecord.java:651)
at android.support.v4.app.FragmentPagerAdapter.finishUpdate(FragmentPagerAdapter.java:145)
at android.support.v4.view.ViewPager.populate(ViewPager.java:1236)
at android.support.v4.view.ViewPager.populate(ViewPager.java:1084)
at android.support.v4.view.ViewPager.onMeasure(ViewPager.java:1614)
at android.view.View.measure(View.java:19759)
at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:715)
at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:461)
at android.view.View.measure(View.java:19759)
at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6122)
at android.widget.FrameLayout.onMeasure(FrameLayout.java:185)
at android.support.v7.widget.ContentFrameLayout.onMeasure(ContentFrameLayout.java:139)
at android.view.View.measure(View.java:19759)
at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6122)
at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1464)
at android.widget.LinearLayout.measureVertical(LinearLayout.java:758)
at android.widget.LinearLayout.onMeasure(LinearLayout.java:640)
at android.view.View.measure(View.java:19759)
at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6122)
at android.widget.FrameLayout.onMeasure(FrameLayout.java:185)
at android.view.View.measure(View.java:19759)
at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6122)
at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1464)
at android.widget.LinearLayout.measureVertical(LinearLayout.java:758)
at android.widget.LinearLayout.onMeasure(LinearLayout.java:640)
at android.view.View.measure(View.java:19759)
at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6122)
at android.widget.FrameLayout.onMeasure(FrameLayout.java:185)
at com.android.internal.policy.DecorView.onMeasure(DecorView.java:690)
at android.view.View.measure(View.java:19759)
at android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:2313)
at android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1400)
at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1649)
at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1288)
at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6359)
03-04 12:09:45.658 30277-30277/com.dannproductions.myproject E/AndroidRuntime: at android.view.Choreographer$CallbackRecord.run(Choreographer.java:873)
at android.view.Choreographer.doCallbacks(Choreographer.java:685)
at android.view.Choreographer.doFrame(Choreographer.java:621)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:859)
at android.os.Handler.handleCallback(Handler.java:754)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:163)
at android.app.ActivityThread.main(ActivityThread.java:6342)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:880)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:770)