简体   繁体   English

Android MediaPlayer无法正常工作

[英]Android MediaPlayer doesnt work properly

I wrote an application that should play a sound when I press a button. 我编写了一个应用程序,当我按下一个按钮时,它应该会播放声音。 But the sound is played just about every fourth click and not in its full lenght. 但是声音大约每四声一次播放一次,而不是全部播放一次。

@Override
public void onClick(View v) {
    if (v == bplus) {
        vib.vibrate(100);

        MediaPlayer mp = MediaPlayer.create(getBaseContext(), R.raw.beep);

        mp.start();

        mp.setOnCompletionListener(new OnCompletionListener() {

            @Override
            public void onCompletion(MediaPlayer mp) {
                // TODO Auto-generated method stub
                mp.release();
            }

        });

        counter++;
    }

When I use mp.prepare() before mp.start() the sound is still irregular and I get this : 当我在mp.start()之前使用mp.prepare()时,声音仍然不规则,我得到了以下信息:

    02-16 23:19:41.761: E/MediaPlayer(750): prepareAsync called in state 8
02-16 23:19:41.761: W/System.err(750): java.lang.IllegalStateException
02-16 23:19:41.771: W/System.err(750):  at android.media.MediaPlayer.prepare(Native Method)
02-16 23:19:41.781: W/System.err(750):  at de.christianschmitz.counter.Starter.onClick(Starter.java:100)
02-16 23:19:41.791: W/System.err(750):  at android.view.View.performClick(View.java:3480)
02-16 23:19:41.791: W/System.err(750):  at android.view.View$PerformClick.run(View.java:13983)
02-16 23:19:41.801: W/System.err(750):  at android.os.Handler.handleCallback(Handler.java:605)
02-16 23:19:41.801: W/System.err(750):  at android.os.Handler.dispatchMessage(Handler.java:92)
02-16 23:19:41.811: W/System.err(750):  at android.os.Looper.loop(Looper.java:137)
02-16 23:19:41.811: W/System.err(750):  at android.app.ActivityThread.main(ActivityThread.java:4340)
02-16 23:19:41.821: W/System.err(750):  at java.lang.reflect.Method.invokeNative(Native Method)
02-16 23:19:41.831: W/System.err(750):  at java.lang.reflect.Method.invoke(Method.java:511)
02-16 23:19:41.831: W/System.err(750):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
02-16 23:19:41.841: W/System.err(750):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
02-16 23:19:41.851: W/System.err(750):  at dalvik.system.NativeStart.main(Native Method)
02-16 23:19:41.851: E/MediaPlayer(750): error (-19, 0)

you have to learn more about MediaPlayer State Diagram 您必须了解有关MediaPlayer状态图的更多信息

在此处输入图片说明

http://developer.android.com/reference/android/media/MediaPlayer.html http://developer.android.com/reference/android/media/MediaPlayer.html

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM