0

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) {
   ...
   ...

aManassetManagerfilelistはアセットディレクトリファイルのリスト、selectedItemはリストに登録されており、再生したい要素です。そのため、リストアイテムをクリックすると、nullPointerExceptionでクラッシュします。メディアプレーヤーにロードされていないようです。奇妙なことに、私はfilelistを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]は、logcatに出力しただけなので、nullにすることはできません。

    12-09 14:31:58.442: V/TESTing filelist(1819): dk9_ch.WAV

わからない...

UPD3:これで動作します。Luksprogのおかげで、初期化することになりました。知らなかった。

4

1 に答える 1

4

問題を追跡するために、以下のようにコードを分割してください*

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

nullをfilelist[selectedItem]返すか、アセットフォルダに存在しないようです。251行目でメインアクティビティを確認してください

于 2012-12-09T09:23:00.113 に答える