我正在尝试将Environment.getExternalStorageDirectory()
中的文件加载到SoundPool
。该文件存在,但我仍然
E/SoundPool: error loading /storage/emulated/0/dialpad/sounds/mamacita_us/one.mp3
当我尝试加载它时。在真实的设备上,它完全可以从完全相同的路径运行。
这是我用来加载文件的代码:
if( isExternalStorageReadable() ){
String externalStorageAbsolutePath = Environment.getExternalStorageDirectory().getAbsolutePath();
String soundFilesPath = (new File(externalStorageAbsolutePath, "dialpad/sounds/mamacita_us")).getPath();
Log.d("DEBUG", (new File(soundFilesPath, "one.mp3")).getAbsolutePath() );
Log.d("DEBUG", (new File(soundFilesPath, "one.mp3")).exists() ? "EXISTS" : "DOES NOT EXSIST");
sounds.put("1", soundPool.load((new File(soundFilesPath, "one.mp3")).getAbsolutePath(), 1));
sounds.put("2", soundPool.load( (new File(soundFilesPath, "two.mp3")).getPath(), 1 ));
}
isExternalStorageReadable()
是辅助方法:
public boolean isExternalStorageReadable() {
String state = Environment.getExternalStorageState();
if (Environment.MEDIA_MOUNTED.equals(state) ||
Environment.MEDIA_MOUNTED_READ_ONLY.equals(state)) {
return true;
}
return false;
}
LogCat输出说
D/DEBUG: /storage/emulated/0/dialpad/sounds/mamacita_us/one.mp3
D/DEBUG: EXISTS
我有一个想法,也许这是一个文件权限问题,但我不知道...... ls -l
adb shell
给了我
-rw-rw---- root sdcard_rw 18288 2009-07-06 13:42 one.mp3
-rw-rw---- root sdcard_rw 21422 2009-07-06 13:44 two.mp3
尝试使用chmod
更改权限,但它们永远不会更改。我已经使用adb push
将文件推送到模拟器。
任何人都知道如何解决这个问题?正如我所说,它在同一条路径的真实设备上完美运行,因此它似乎是Genymotion模拟器和/或文件系统的问题。模拟器运行的是Android 6.0(API23)。
哦,是的,我正在宣布
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
在我的清单中。
答案 0 :(得分:0)
READ_EXTERNAL_STORAGE被视为&#34;危险许可&#34;在Android 6.0中引入的新运行时权限模型下。
您需要请求访问外部存储空间的权限。
您的设备可能正在运行Android版本&lt; 6.0,因此无需请求许可即可使用该版本。
http://developer.android.com/guide/topics/security/permissions.html#normal-dangerous