从资产文件夹设置文件会导致Media Player为空指针异常

时间:2012-12-09 09:09:37

标签: android android-mediaplayer

我有一个资产文件夹文件列表,名为 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,我应该初始化它。不知道。

1 个答案:

答案 0 :(得分:4)

按照以下方式破解您的代码,以帮助您跟踪问题*

AssetFileDescriptor afd = getAssets().openFd(filelist[selectedItem]);
selectedItemPlayer.setDataSource(afd.getFileDescriptor(),afd.getStartOffset(),afd.getLength());

似乎filelist[selectedItem]返回null或者它不存在于您的资产foldre中。检查第251行的主要活动