У меня действительно странная ошибка, я просто не могу понять, что происходит. В моем коде я использую медиаплеер через SoundsClass вот так:
public class SoundsClass {
private int sound;
private Context mContext;
public SoundsClass(int sound, Context mContext) {
this.sound=sound;
this.mContext=mContext;
}
public void clickOnAndroid() {
switch(this.sound) {
case R.raw.sound1:
MediaPlayer mediaPlayer = MediaPlayer.create(mContext, R.raw.sound1);
mediaPlayer.start();
mediaPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
public void onCompletion(MediaPlayer mp) {
mp.release();
}
});
break;
case R.raw.sound2:
mediaPlayer = MediaPlayer.create(mContext, R.raw.sound2);
mediaPlayer.start();
mediaPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
public void onCompletion(MediaPlayer mp) {
mp.release();
}
});
break;
case R.raw.sound3:
mediaPlayer = MediaPlayer.create(mContext, R.raw.sound3);
mediaPlayer.start();
mediaPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
public void onCompletion(MediaPlayer mp) {
mp.release();
}
});
break;
}
}
}
Итак, я использую этот класс в своей основной деятельности следующим образом:
new SoundsClass(R.raw.sound1, getBaseContext()).clickOnAndroid();
В двух местах в этом действии все работает нормально, но третье выдает NullPointerException, вызванное строкой в SoundsClass, указывающей на:
mediaPlayer.start();
Есть идеи, почему? Я неправильно использую MediaPlayer?
Логкат:
java.lang.NullPointerException
at com.testingapp.app.SoundsClass.clickOnAndroid(SoundsClass.java:42)
at com.testingapp.app.MainActivity$2.onClick(MainActivity.java:147)
at android.view.View.performClick(View.java:2485)
at android.view.View$PerformClick.run(View.java:9080)
at android.os.Handler.handleCallback(Handler.java:587)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:130)
at android.app.ActivityThread.main(ActivityThread.java:3683)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:507)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
at dalvik.system.NativeStart.main(Native Method)
Возможно, мне следует добавить, что я вызываю этот SoundsClass очень часто и без или почти без пауз между ними. И иногда я получаю:
bufferCount is to small and increased to 12.