Итак, у меня есть такой код:
String thisPath = cursor.getString(pathColumn);
MediaMetadataRetriever mmr = new MediaMetadataRetriever();
mmr.setDataSource(thisPath);
byte[] data = mmr.getEmbeddedPicture();
if (data != null) {
bitmap = BitmapFactory.decodeByteArray(data, 0, data.length);
} else {
bitmap = null;
}
Все работало нормально, пока я не начал получать java.lang.IllegalArgumentException в строке setDataSource(), после некоторого покопания я пришел к выводу, что путь, возвращенный курсором с использованием int pathColumn = cursor.getColumnIndex(MediaStore.Audio.Media.DATA), указывал на файл, которого больше нет в этом месте, я думаю, что это то, что вызывая проблему.
Invalid path: "/storage/emulated/0/zedge/.../Alarm_Clock.mp3"
Я уже установил разрешения на хранилище, и он работает для остальных файлов, которые я ищу, я даже не знаю, как я получаю этот путь, поскольку там нет файла.
Кто-нибудь может помочь?
Ваше здоровье,
Обновлено:
thisPath на самом деле просто строка
String thisPath = musicCursor.getString(pathColumn);
Но здесь инициализируется pathColumn:
ContentResolver contentResolver = getContentResolver();
Uri uri = android.provider.MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
Cursor cursor = contentResolver.query(uri, null, null, null, null);
if (cursor != null && cursor.moveToFirst()) {
int pathColumn = cursor.getColumnIndex(MediaStore.Audio.Media.DATA);
do {
String thisPath = cursor.getString(pathColumn);
MediaMetadataRetriever mmr = new MediaMetadataRetriever();
mmr.setDataSource(thisPath);
byte[] data = mmr.getEmbeddedPicture();
if (data != null) {
bitmap = BitmapFactory.decodeByteArray(data, 0, data.length);
} else {
bitmap = null;
}
songList.add(new Song(thisId, thisTitle, thisArtist, thisAlbum, bitmap));
} while (cursor.moveToNext());
Трассировки стека:
05-15 13:55:50.181 3616-3616/com.bot.lit E/AndroidRuntime: FATAL EXCEPTION: main Process: com.bot.lit, PID: 3616 java.lang.RuntimeException: Unable to start activity ComponentInfo{com.bot.lit/com.bot.lit.MainActivity}: java.lang.IllegalArgumentException at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2606) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2672) at android.app.ActivityThread.access$1100(ActivityThread.java:180) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1517) at android.os.Handler.dispatchMessage(Handler.java:111) at android.os.Looper.loop(Looper.java:207) at android.app.ActivityThread.main(ActivityThread.java:5856) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:933) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:782) Caused by: java.lang.IllegalArgumentException at android.media.MediaMetadataRetriever.setDataSource(MediaMetadataRetriever.java:73) at com.bot.lit.MainActivity.getSongList(MainActivity.java:273) at com.bot.lit.MainActivity.onCreate(MainActivity.java:108) at android.app.Activity.performCreate(Activity.java:6347) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1113) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2559) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2672) at android.app.ActivityThread.access$1100(ActivityThread.java:180) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1517) at android.os.Handler.dispatchMessage(Handler.java:111) at android.os.Looper.loop(Looper.java:207) at android.app.ActivityThread.main(ActivityThread.java:5856) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:933) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:782) `
In case it might be of help, this image shows the path I'm referring to Боже мой ... удали этот образ. Просто опубликуйте этот путь как текст.
was pointing to a file that's no longer in that location, I think that's what's causing the issue. Затем сначала проверьте, существует ли файл с помощью File: exists (), и не продолжайте, если это не так.
Исправлю это, извините @greenapps
Добавил то, что вы просили @Ben
Был в процессе, ты слишком быстр, товарищ c:
почему бы вам просто не использовать setDataSource(String) вместо setDataSource(Context context, Uri uri)?




I got to the conclusion that the path returned from the cursor using
int pathColumn = cursor.getColumnIndex(MediaStore.Audio.Media.DATA)was pointing to a file that's no longer in that location
Это вполне возможно, поскольку индекс MediaStore может быть устаревшим. Также возможно, что DATA указывает на что-то, к чему у вас нет доступа для чтения. Я считаю, что есть сценарии, в которых DATA - это null.
Что ж, я видел здесь вопрос о том, что он возвращает null, не показался мне таким полезным: l Я думал то же самое, после перезагрузки моего телефона он действительно работал нормально, поэтому я полагаю, что индекс каким-то образом обновился, но я не могу действительно считаю это исправлением :)
@ b0taSs: «после перезагрузки телефона он действительно работал нормально, поэтому я полагаю, что индекс каким-то образом обновился» - есть крошечная версия робота Google, который периодически сканирует внешнее хранилище и обновляет MediaStore. Это запустится после перезагрузки. «Исправление» состоит в том, что вы не можете предполагать, что DATA полезен.
Не могли бы вы включить полную версию StackTrace и свой код, в котором вы инициализируете
thisPath.