我有一个资产文件夹文件列表,名为 filelist 。我在ListView中显示了所有这些元素,因此当点击其中一些元素时,我希望它被播放。在这里它给了我 nullpointerexception 。代码,导致错误:
try {
selectedItemPlayer.setDataSource(
aMan.openFd(filelist[selectedItem]).getFileDescriptor(),
aMan.openFd(filelist[selectedItem]).getStartOffset(),
aMan.openFd(filelist[selectedItem]).getLength());
selectedItemPlayer.prepare();
selectedItemPlayer.start();
selectedItemPlayer.setLooping(false);
} catch (IllegalArgumentException e) {
...
...
aMan 是 assetManager , filelist 是资产目录文件的列表, selectedItem 是具有的元素已被列入清单,我想玩。因此,当我点击列表项时,它会崩溃并返回nullPointerException。似乎,声音没有加载到媒体播放器。很奇怪,因为我使用文件列表,使用soundPool,它工作得很好......任何想法?
UPD1:Logcat消息
12-09 14:17:06.964: W/dalvikvm(23404): threadid=1: thread exiting with uncaught exception (group=0x2b542210)
12-09 14:17:06.974: E/AndroidRuntime(23404): FATAL EXCEPTION: main
12-09 14:17:06.974: E/AndroidRuntime(23404): java.lang.NullPointerException
12-09 14:17:06.974: E/AndroidRuntime(23404): at uk.co.futurelite.elite.drum.machine.MainActivity$1.onClick(MainActivity.java:251)
12-09 14:17:06.974: E/AndroidRuntime(23404): at com.android.internal.app.AlertController$AlertParams$3.onItemClick(AlertController.java:924)
12-09 14:17:06.974: E/AndroidRuntime(23404): at android.widget.AdapterView.performItemClick(AdapterView.java:292)
12-09 14:17:06.974: E/AndroidRuntime(23404): at android.widget.AbsListView.performItemClick(AbsListView.java:1065)
12-09 14:17:06.974: E/AndroidRuntime(23404): at android.widget.AbsListView$PerformClick.run(AbsListView.java:2522)
12-09 14:17:06.974: E/AndroidRuntime(23404): at android.widget.AbsListView$1.run(AbsListView.java:3183)
12-09 14:17:06.974: E/AndroidRuntime(23404): at android.os.Handler.handleCallback(Handler.java:605)
12-09 14:17:06.974: E/AndroidRuntime(23404): at android.os.Handler.dispatchMessage(Handler.java:92)
12-09 14:17:06.974: E/AndroidRuntime(23404): at android.os.Looper.loop(Looper.java:137)
12-09 14:17:06.974: E/AndroidRuntime(23404): at android.app.ActivityThread.main(ActivityThread.java:4441)
12-09 14:17:06.974: E/AndroidRuntime(23404): at java.lang.reflect.Method.invokeNative(Native Method)
12-09 14:17:06.974: E/AndroidRuntime(23404): at java.lang.reflect.Method.invoke(Method.java:511)
12-09 14:17:06.974: E/AndroidRuntime(23404): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
12-09 14:17:06.974: E/AndroidRuntime(23404): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
12-09 14:17:06.974: E/AndroidRuntime(23404): at dalvik.system.NativeStart.main(Native Method)
UPD2: 在第251行,我有以下代码
selectedItemPlayer.setDataSource(aMan.openFd(filelist[selectedItem]).getFileDescriptor(),
filelist [selectedItem] 无法为null,因为我只是在logcat中打印
12-09 14:31:58.442: V/TESTing filelist(1819): dk9_ch.WAV
不知道......
UPD3:现在它可以工作了,感谢Luksprog,我应该初始化它。不知道。
答案 0 :(得分:4)
按照以下方式破解您的代码,以帮助您跟踪问题*
AssetFileDescriptor afd = getAssets().openFd(filelist[selectedItem]);
selectedItemPlayer.setDataSource(afd.getFileDescriptor(),afd.getStartOffset(),afd.getLength());
似乎filelist[selectedItem]
返回null或者它不存在于您的资产foldre中。检查第251行的主要活动