I have an music player app and I have a problem. When I call on BackPressed or finish() it jumps to onPause method not to finish(). Why? I can't finish my app. Thank you very much for your help.
my code
public class MusicPlayer extends ThemableActivity implements SeekBar.OnSeekBarChangeListener {
MediaPlayer musicPlayer;
int abc;
@Override
protected void onCreate(Bundle SavedInstanceState) {
super.onCreate(SavedInstanceState);
setContentView(R.layout.media_player_layout);
Intent intent = getIntent();
String track = intent.getDataString();
TextView txt = (TextView)findViewById(R.id.txt);
txt.setGravity(Gravity.CENTER);
txt.setText(track);
ImageView img = (ImageView)findViewById(R.id.img);
img.setLayerType(View.LAYER_TYPE_SOFTWARE, null);
final Uri uri = getIntent() != null ? getIntent().getData() : null;
final SharedPreferences premiumSettings = getSharedPreferences("PREMIUM", Context.MODE_PRIVATE);
final boolean isPremium = premiumSettings.getBoolean("isPremium", false);
final SeekBar seekBar = (SeekBar) findViewById(R.id.seekBar);
TextView max = (TextView)findViewById(R.id.max);
final TextView actual = (TextView)findViewById(R.id.actual);
seekBar.setOnSeekBarChangeListener(this);
Button loop = (Button)findViewById(R.id.loop);
if (isPremium) {
musicPlayer = MediaPlayer.create(MusicPlayer.this, uri);
musicPlayer.setWakeMode(this.getApplicationContext(), PowerManager.PARTIAL_WAKE_LOCK);
seekBar.setMax(musicPlayer.getDuration());
musicPlayer.start();
max.setText(String.format("%dm %ds",
TimeUnit.MILLISECONDS.toMinutes((long) musicPlayer.getDuration() ),
TimeUnit.MILLISECONDS.toSeconds((long) musicPlayer.getDuration()) - TimeUnit.MINUTES.toSeconds(TimeUnit.MILLISECONDS.toMinutes((long) musicPlayer.getDuration()))));
final ImageButton play = (ImageButton) findViewById(R.id.play);
if(!musicPlayer.isPlaying()){
play.setImageResource(android.R.drawable.ic_media_play);
}
else{
play.setImageResource(android.R.drawable.ic_media_pause);
}
play.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View view) {
if(musicPlayer.isPlaying()){
play.setImageResource(android.R.drawable.ic_media_play);
musicPlayer.stop();
return true;
}
return false;
}
});
play.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
int position = musicPlayer.getCurrentPosition();
if(musicPlayer.isPlaying()){
musicPlayer.pause();
play.setImageResource(android.R.drawable.ic_media_play);
}
else if(!musicPlayer.isPlaying()) {
musicPlayer.seekTo(position);
musicPlayer.start();
play.setImageResource(android.R.drawable.ic_media_pause);
}}
});
loop.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
musicPlayer.setLooping(true);
}
});
final Handler mHandler = new Handler();
Runnable mRunnable;
mRunnable = new Runnable() {
@Override
public void run() {
int mCurrentPosition = 0;
if (musicPlayer != null) {
mCurrentPosition = musicPlayer.getCurrentPosition();
seekBar.setProgress(mCurrentPosition);
}
mHandler.postDelayed(this, 1000);
actual.setText(String.format("%dm %ds",
TimeUnit.MILLISECONDS.toMinutes((long) mCurrentPosition),
TimeUnit.MILLISECONDS.toSeconds((long) mCurrentPosition) - TimeUnit.MINUTES.toSeconds(TimeUnit.MILLISECONDS.toMinutes((long) mCurrentPosition))));
}
};
mRunnable.run();
ImageButton exit = (ImageButton) findViewById(R.id.exit);
exit.setImageResource(android.R.drawable.btn_dialog);
exit.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if(musicPlayer.isPlaying()) {
musicPlayer.setLooping(false);
musicPlayer.stop();
}
musicPlayer = null;
finish();
}
});
}
else {
AlertDialog.Builder builder = new AlertDialog.Builder(MusicPlayer.this);
builder.setTitle("Error");
builder.setMessage("You are not premium user. Please enter the promocode or buy the full version");
builder.setIcon(R.drawable.holo_dark_action_info);
builder.setPositiveButton("OK", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int whichButton) {
finish();
}
});
AlertDialog dialog = builder.create();
dialog.show();
}}
public void onBackPressed () {
if(musicPlayer.isPlaying()) {
musicPlayer.setLooping(false);
musicPlayer.stop();
}
musicPlayer = null;
finish();
}
@Override
public void onPause(){
super.onPause();
abc = musicPlayer.getCurrentPosition();
musicPlayer.pause();
}
@Override
public void onResume(){
super.onResume();
musicPlayer.seekTo(abc);
musicPlayer.start();
}
@Override
public void onProgressChanged(SeekBar seekBar, int i, boolean b) {
if (musicPlayer != null && b){
musicPlayer.seekTo(i);
}
}
@Override
public void onStartTrackingTouch(SeekBar seekBar) {
}
@Override
public void onStopTrackingTouch(SeekBar seekBar) {
}
That's because onPause is called before when you exit an application.
Make sure musicPlayer is not null when you call onPause.
@Override
public void onPause(){
super.onPause();
if(musicPlayer == null )
return;
abc = musicPlayer.getCurrentPosition();
musicPlayer.pause();
}
More info here: http://developer.android.com/training/basics/activity-lifecycle/stopping.html