Ecco una classe che uso per trovare tutte le SDcards su un dispositivo; integrato e rimovibile. L'ho usato su Ice Cream Sandwich, ma dovrebbe funzionare a 2 livelli.
public class GetRemovableDevice {
private final static String TAG = "GetRemoveableDevice";
public GetRemovableDevice() {
}
public static String[] getDirectories() {
MyLog.d(TAG, "getStorageDirectories");
File tempFile;
String[] directories = null;
String[] splits;
ArrayList<String> arrayList = new ArrayList<String>();
BufferedReader bufferedReader = null;
String lineRead;
try {
arrayList.clear(); // redundant, but what the hey
bufferedReader = new BufferedReader(new FileReader("/proc/mounts"));
while ((lineRead = bufferedReader.readLine()) != null) {
MyLog.d(TAG, "lineRead: " + lineRead);
splits = lineRead.split(" ");
// System external storage
if (splits[1].equals(Environment.getExternalStorageDirectory()
.getPath())) {
arrayList.add(splits[1]);
MyLog.d(TAG, "gesd split 1: " + splits[1]);
continue;
}
// skip if not external storage device
if (!splits[0].contains("/dev/block/")) {
continue;
}
// skip if mtdblock device
if (splits[0].contains("/dev/block/mtdblock")) {
continue;
}
// skip if not in /mnt node
if (!splits[1].contains("/mnt")) {
continue;
}
// skip these names
if (splits[1].contains("/secure")) {
continue;
}
if (splits[1].contains("/mnt/asec")) {
continue;
}
// Eliminate if not a directory or fully accessible
tempFile = new File(splits[1]);
if (!tempFile.exists()) {
continue;
}
if (!tempFile.isDirectory()) {
continue;
}
if (!tempFile.canRead()) {
continue;
}
if (!tempFile.canWrite()) {
continue;
}
// Met all the criteria, assume sdcard
arrayList.add(splits[1]);
}
} catch (FileNotFoundException e) {
} catch (IOException e) {
} finally {
if (bufferedReader != null) {
try {
bufferedReader.close();
} catch (IOException e) {
}
}
}
// Send list back to caller
if (arrayList.size() == 0) {
arrayList.add("sdcard not found");
}
directories = new String[arrayList.size()];
for (int i = 0; i < arrayList.size(); i++) {
directories[i] = arrayList.get(i);
}
return directories;
}
}
Il MyLog.d è una classe di traccia che si espande Log.d - può essere eliminato.
La classe si legge/proc/mounts/e:
- controlla se il nome del percorso è la directory sdcard interna
- controlli per vedere se un dispositivo a blocchi
- cassonetti mtdblock dispositivi
- salta tutto ciò che non è montata
- cassonetti directory sicuri e ASEC
- si assicura che esiste, è una directory, e leggere/write accessibile
Se tutto questo corrisponde, si presuppone che si disponga di una sdcard e si aggiunga il percorso all'elenco di array. Restituisce una serie di stringhe di nomi di percorsi.
per chiamare la funzione GetDirectories, codice di qualcosa di simile a:
String[] sdcardDirectories = GetRemoveableDevice.getDirectories();
I percorsi restituiti può essere utilizzato per creare una lista di selezione utente, eseguire la scansione di un file, o qualsiasi altra cosa.
Infine, ecco due linee di MyLog.d da un test emulatore (seconda riga è l'emulatore sdcard):
09-19 15: 57: 12,511: D/GetRemoveableDevice (651): lineRead:/dev/blocco/mtdblock2/cache YAFFS2 RW, nosuid, nodev 0 0
09-19 15: 57: 12,511: D/GetRemoveableDevice (651): lineRead:/dev/block/vold/179: 0/mnt/sdcard vfat rw, dirsync, nosuid, nodev, noexec, uid = 1000, gid = 1015, fmask = 0702, dmask = 0702, allow_utime = 0020, codepage = cp437, iocharset = iso8859-1, shortname = mixed, utf8, errors = remount -ro 0 0
Qualsiasi cosa oltre i metodi di 'Ambiente' è oltre i limiti dell'SDK e sarà inaffidabile. – CommonsWare