1
0
mirror of https://github.com/TeamNewPipe/NewPipe synced 2025-01-09 08:50:34 +00:00

cleaned up BackgroundPlayer code a little

This commit is contained in:
Adam Howard 2015-11-25 17:36:01 +00:00
parent 6b2c3217ab
commit dc0fc05a9e

View File

@ -1,6 +1,5 @@
package org.schabi.newpipe; package org.schabi.newpipe;
import android.app.IntentService;
import android.app.Notification; import android.app.Notification;
import android.app.NotificationManager; import android.app.NotificationManager;
import android.app.Service; import android.app.Service;
@ -9,17 +8,11 @@ import android.content.Intent;
import android.media.AudioManager; import android.media.AudioManager;
import android.media.MediaPlayer; import android.media.MediaPlayer;
import android.net.wifi.WifiManager; import android.net.wifi.WifiManager;
import android.os.Handler;
import android.os.HandlerThread;
import android.os.IBinder; import android.os.IBinder;
import android.os.Looper;
import android.os.Message;
import android.os.PowerManager; import android.os.PowerManager;
import android.support.v7.app.NotificationCompat; import android.support.v7.app.NotificationCompat;
import android.util.Log; import android.util.Log;
import android.widget.Toast; import android.widget.Toast;
import android.os.Process;
import android.widget.VideoView;
import java.io.IOException; import java.io.IOException;
@ -53,23 +46,11 @@ public class BackgroundPlayer extends Service /*implements MediaPlayer.OnPrepare
public BackgroundPlayer() { public BackgroundPlayer() {
super(); super();
VideoView v;
} }
@Override @Override
public void onCreate() { public void onCreate() {
// Start up the thread running the service. Note that we create a
// separate thread because the service normally runs in the process's
// main thread, which we don't want to block. We also make it
// background priority so CPU-intensive work will not disrupt our UI.
super.onCreate(); super.onCreate();
//HandlerThread thread = new HandlerThread(TAG, Process.THREAD_PRIORITY_BACKGROUND);
//thread.start();
// Get the HandlerThread's Looper and use it for our Handler
//mServiceLooper = thread.getLooper();
//mServiceHandler = new ServiceHandler(mServiceLooper);
} }
@Override @Override
public int onStartCommand(Intent intent, int flags, int startId) { public int onStartCommand(Intent intent, int flags, int startId) {
@ -94,13 +75,9 @@ public class BackgroundPlayer extends Service /*implements MediaPlayer.OnPrepare
@Override @Override
public void onDestroy() { public void onDestroy() {
//Toast.makeText(this, "service done", Toast.LENGTH_SHORT).show(); //Toast.makeText(this, "service done", Toast.LENGTH_SHORT).show();
//mServiceLooper.quit();
//if (mMediaPlayer != null) mMediaPlayer.release();
//todo: call MediaPlayer.release() as soon as video is complete
} }
private class PlayerThread extends Thread { private class PlayerThread extends Thread {
private MediaPlayer mediaPlayer; private MediaPlayer mediaPlayer;
private String source; private String source;
private String title; private String title;
@ -120,6 +97,7 @@ public class BackgroundPlayer extends Service /*implements MediaPlayer.OnPrepare
mediaPlayer.prepare(); //We are already in a separate worker thread, mediaPlayer.prepare(); //We are already in a separate worker thread,
//so calling the blocking prepare() method should be ok //so calling the blocking prepare() method should be ok
//alternatively:
//mediaPlayer.setOnPreparedListener(this); //mediaPlayer.setOnPreparedListener(this);
//mediaPlayer.prepareAsync(); //prepare async to not block main thread //mediaPlayer.prepareAsync(); //prepare async to not block main thread
} catch (IOException ioe) { } catch (IOException ioe) {
@ -175,7 +153,7 @@ public class BackgroundPlayer extends Service /*implements MediaPlayer.OnPrepare
noteMgr.notify(noteID, noteBuilder.build()); noteMgr.notify(noteID, noteBuilder.build());
} }
noteBuilder.setProgress(0, 0, false);//remove bar noteBuilder.setProgress(0, 0, false);//remove bar
//noteMgr.notify(0, noteBuilder.build()); noteMgr.cancel(noteID);
} }
} }
/* /*
@ -198,6 +176,7 @@ public class BackgroundPlayer extends Service /*implements MediaPlayer.OnPrepare
wl.release();//release wifilock wl.release();//release wifilock
stopForeground(true);//remove ongoing notification stopForeground(true);//remove ongoing notification
stopSelf(); stopSelf();
mp.release();
//todo:release cpu lock //todo:release cpu lock
} }
} }