0

This has started to happen in my app, when I got rid of the status bar in my Java file. I close the app (I use a real device) by using my phone's task manager, and then on my home screen, the message "My App has stopped working." What should I do?

Java File

package interactive.siddiqui.survivor;

import android.app.Activity;
import android.content.Intent;
import android.media.MediaPlayer;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.MenuItem;
import android.view.View;
import android.view.Window;
import android.view.WindowManager;

public class Main extends Activity {

private MediaPlayer mediaPlayer;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
            WindowManager.LayoutParams.FLAG_FULLSCREEN);

    setContentView(R.layout.activity_main);



    mediaPlayer = MediaPlayer.create(this, R.drawable.background_musicmain);
    mediaPlayer.start();




}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();

    //noinspection SimplifiableIfStatement
    if (id == R.id.action_settings) {
        return true;
    }

    return super.onOptionsItemSelected(item);
}
public void sendMessage(View view)
{
    Intent intent = new Intent(Main.this, GameView.class);
    startActivity(intent);
    onDestroy();
}

public void onDestroy() {
    if (mediaPlayer.isPlaying()) {
        mediaPlayer.stop();
    }
    mediaPlayer.release();
}

}

Logcat

07-28 01:06:05.389    2009-2009/? I/art﹕ Late-enabling -Xcheck:jni
07-28 01:06:05.673    2009-2009/interactive.siddiqui.survivor E/MediaPlayer﹕    Should have subtitle controller already set
07-28 01:06:05.680    2009-2030/interactive.siddiqui.survivor D/OpenGLRenderer﹕ Use EGL_SWAP_BEHAVIOR_PRESERVED: true
07-28 01:06:05.689    2009-2009/interactive.siddiqui.survivor D/Atlas﹕ Validating map...
07-28 01:06:05.701    2009-2009/interactive.siddiqui.survivor E/MediaPlayer﹕ Should have subtitle controller already set
07-28 01:06:05.739    2009-2030/interactive.siddiqui.survivor I/Adreno﹕ EGLInit: QTI Build: 03/04/15, eeab148,
07-28 01:06:05.749    2009-2030/interactive.siddiqui.survivor I/OpenGLRenderer﹕ Initialized EGL, version 1.4
07-28 01:06:05.750    2009-2030/interactive.siddiqui.survivor I/Adreno﹕ GetNativeFormatFromQctPixelFormat: Invalid qct format (611)
07-28 01:06:05.750    2009-2030/interactive.siddiqui.survivor I/Adreno﹕ GetNativeFormatFromQctPixelFormat: Invalid qct format (611)
07-28 01:06:05.750    2009-2030/interactive.siddiqui.survivor I/Adreno﹕ GetNativeFormatFromQctPixelFormat: Invalid qct format (611)
07-28 01:06:05.750    2009-2030/interactive.siddiqui.survivor I/Adreno﹕ GetNativeFormatFromQctPixelFormat: Invalid qct format (611)
07-28 01:06:05.750    2009-2030/interactive.siddiqui.survivor I/Adreno﹕ GetNativeFormatFromQctPixelFormat: Invalid qct format (612)
07-28 01:06:05.750    2009-2030/interactive.siddiqui.survivor I/Adreno﹕ GetNativeFormatFromQctPixelFormat: Invalid qct format (612)
07-28 01:06:05.750    2009-2030/interactive.siddiqui.survivor I/Adreno﹕ GetNativeFormatFromQctPixelFormat: Invalid qct format (612)
07-28 01:06:05.750    2009-2030/interactive.siddiqui.survivor I/Adreno﹕ GetNativeFormatFromQctPixelFormat: Invalid qct format (612)
07-28 01:06:05.757    2009-2030/interactive.siddiqui.survivor   D/OpenGLRenderer﹕ Enabling debug mode 0

Any suggestions?

Praneeth
  • 1,260
  • 18
  • 37
  • it may help you - [link](http://stackoverflow.com/questions/20087804/should-have-subtitle-controller-already-set-mediaplayer-error-android) – pRaNaY Jul 28 '15 at 05:14
  • @Override is missing in onDestroy. and it's better to handle music in Background service – Zar E Ahmer Jul 28 '15 at 06:48

1 Answers1

0

The onDestroy gets called and probably meets a NullPointerException. Add this check for null:

public void onDestroy() {
    if (mediaPlayer == null)
    { return; }

    if (mediaPlayer.isPlaying()) {
        mediaPlayer.stop();
    }
    mediaPlayer.release();
}
milez
  • 2,201
  • 12
  • 31