код получить музыкальные файлы с SD-карты/музыки и просмотреть список тем
в android 5 происходит принудительное закрытие
думаю проблема в этой функции
ФильтрРасширенияФайла()
package com.ghs.musicsatsametime;
import java.io.File;
import java.io.FilenameFilter;
import java.util.ArrayList;
import java.util.HashMap;
public class SongsManager {
// SDCard Path
final String MEDIA_PATH = new String("/sdcard/Music");
private ArrayList<HashMap<String, String>> songsList = new ArrayList<HashMap<String, String>>();
// Constructor
public SongsManager(){
}
/**
* Function to read all mp3 files from sdcard
* and store the details in ArrayList
* */
public ArrayList<HashMap<String, String>> getPlayList(){
File home = new File(MEDIA_PATH);
if (home.listFiles(new FileExtensionFilter()).length > 0) {
for (File file : home.listFiles(new FileExtensionFilter())) {
HashMap<String, String> song = new HashMap<String, String>();
song.put("songTitle", file.getName().substring(0, (file.getName().length() - 4)));
song.put("songPath", file.getPath());
// Adding each song to SongList
songsList.add(song);
}
}
// return songs list array
return songsList;
}
/**
* Class to filter files which are having .mp3 extension
* */
class FileExtensionFilter implements FilenameFilter {
public boolean accept(File dir, String name) {
return (name.endsWith(".mp3") || name.endsWith(".MP3"));
}
}
}
и мой логкэт
10-30 10:45:30.176: E/AndroidRuntime(15788): FATAL EXCEPTION: main
10-30 10:45:30.176: E/AndroidRuntime(15788): Process: com.ghs.musicsatsametime, PID: 15788
10-30 10:45:30.176: E/AndroidRuntime(15788): java.lang.NullPointerException: Attempt to get length of null array
10-30 10:45:30.176: E/AndroidRuntime(15788): at com.ghs.musicsatsametime.SongsManager.getPlayList(SongsManager.java:25)
10-30 10:45:30.176: E/AndroidRuntime(15788): at com.ghs.musicsatsametime.dj.DJMusicFragment.getMusicList(DJMusicFragment.java:421)
10-30 10:45:30.176: E/AndroidRuntime(15788): at com.ghs.musicsatsametime.dj.DJMusicFragment.access$22(DJMusicFragment.java:415)
10-30 10:45:30.176: E/AndroidRuntime(15788): at com.ghs.musicsatsametime.dj.DJMusicFragment$7.onClick(DJMusicFragment.java:359)
10-30 10:45:30.176: E/AndroidRuntime(15788): at android.view.View.performClick(View.java:4856)
10-30 10:45:30.176: E/AndroidRuntime(15788): at android.view.View$PerformClick.run(View.java:19956)
10-30 10:45:30.176: E/AndroidRuntime(15788): at android.os.Handler.handleCallback(Handler.java:739)
10-30 10:45:30.176: E/AndroidRuntime(15788): at android.os.Handler.dispatchMessage(Handler.java:95)
10-30 10:45:30.176: E/AndroidRuntime(15788): at android.os.Looper.loop(Looper.java:211)
10-30 10:45:30.176: E/AndroidRuntime(15788): at android.app.ActivityThread.main(ActivityThread.java:5371)
10-30 10:45:30.176: E/AndroidRuntime(15788): at java.lang.reflect.Method.invoke(Native Method)
10-30 10:45:30.176: E/AndroidRuntime(15788): at java.lang.reflect.Method.invoke(Method.java:372)
10-30 10:45:30.176: E/AndroidRuntime(15788): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:945)
10-30 10:45:30.176: E/AndroidRuntime(15788): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:740)
length()
для нулевого экземпляра массива). - person JHH   schedule 30.10.2015