Android port: The RockboxService introduction broke 1.5/1.6 compability. This should bring it back (heaviliy based on the example given in the Android docs).
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@27748 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
parent
2113e22c46
commit
8978b2bafa
2 changed files with 87 additions and 13 deletions
|
@ -8,4 +8,4 @@
|
||||||
# project structure.
|
# project structure.
|
||||||
|
|
||||||
# Project target.
|
# Project target.
|
||||||
target=android-7
|
target=android-4
|
||||||
|
|
|
@ -4,6 +4,8 @@ import java.io.BufferedInputStream;
|
||||||
import java.io.BufferedOutputStream;
|
import java.io.BufferedOutputStream;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
|
import java.lang.reflect.InvocationTargetException;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
import java.util.Enumeration;
|
import java.util.Enumeration;
|
||||||
import java.util.zip.ZipEntry;
|
import java.util.zip.ZipEntry;
|
||||||
import java.util.zip.ZipFile;
|
import java.util.zip.ZipFile;
|
||||||
|
@ -23,10 +25,29 @@ public class RockboxService extends Service
|
||||||
public static RockboxFramebuffer fb = null;
|
public static RockboxFramebuffer fb = null;
|
||||||
private static RockboxService instance;
|
private static RockboxService instance;
|
||||||
private Notification notification;
|
private Notification notification;
|
||||||
|
private static final Class[] mStartForegroundSignature = new Class[] {
|
||||||
|
int.class, Notification.class};
|
||||||
|
private static final Class[] mStopForegroundSignature = new Class[] {
|
||||||
|
boolean.class};
|
||||||
|
|
||||||
|
private NotificationManager mNM;
|
||||||
|
private Method mStartForeground;
|
||||||
|
private Method mStopForeground;
|
||||||
|
private Object[] mStartForegroundArgs = new Object[2];
|
||||||
|
private Object[] mStopForegroundArgs = new Object[1];
|
||||||
@Override
|
@Override
|
||||||
public void onCreate()
|
public void onCreate()
|
||||||
{
|
{
|
||||||
mNM = (NotificationManager)getSystemService(NOTIFICATION_SERVICE);
|
mNM = (NotificationManager)getSystemService(NOTIFICATION_SERVICE);
|
||||||
|
try {
|
||||||
|
mStartForeground = getClass().getMethod("startForeground",
|
||||||
|
mStartForegroundSignature);
|
||||||
|
mStopForeground = getClass().getMethod("stopForeground",
|
||||||
|
mStopForegroundSignature);
|
||||||
|
} catch (NoSuchMethodException e) {
|
||||||
|
// Running on an older platform.
|
||||||
|
mStartForeground = mStopForeground = null;
|
||||||
|
}
|
||||||
startservice();
|
startservice();
|
||||||
instance = this;
|
instance = this;
|
||||||
}
|
}
|
||||||
|
@ -34,6 +55,8 @@ public class RockboxService extends Service
|
||||||
private void do_start(Intent intent)
|
private void do_start(Intent intent)
|
||||||
{
|
{
|
||||||
LOG("Start Service");
|
LOG("Start Service");
|
||||||
|
/* Display a notification about us starting. We put an icon in the status bar. */
|
||||||
|
create_notification();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void LOG(CharSequence text)
|
private void LOG(CharSequence text)
|
||||||
|
@ -41,18 +64,14 @@ public class RockboxService extends Service
|
||||||
Log.d("Rockbox", (String) text);
|
Log.d("Rockbox", (String) text);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onStart(Intent intent, int startId) {
|
public void onStart(Intent intent, int startId) {
|
||||||
do_start(intent);
|
do_start(intent);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public int onStartCommand(Intent intent, int flags, int startId)
|
public int onStartCommand(Intent intent, int flags, int startId)
|
||||||
{
|
{
|
||||||
do_start(intent);
|
do_start(intent);
|
||||||
/* Display a notification about us starting. We put an icon in the status bar. */
|
return 1; /* START_STICKY */
|
||||||
create_notification();
|
|
||||||
return START_STICKY;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startservice()
|
private void startservice()
|
||||||
|
@ -130,10 +149,7 @@ public class RockboxService extends Service
|
||||||
public IBinder onBind(Intent intent) {
|
public IBinder onBind(Intent intent) {
|
||||||
// TODO Auto-generated method stub
|
// TODO Auto-generated method stub
|
||||||
return null;
|
return null;
|
||||||
}
|
} /**
|
||||||
private NotificationManager mNM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for clients to access. Because we know this service always
|
* Class for clients to access. Because we know this service always
|
||||||
* runs in the same process as its clients, we don't need to deal with
|
* runs in the same process as its clients, we don't need to deal with
|
||||||
* IPC.
|
* IPC.
|
||||||
|
@ -179,7 +195,7 @@ public class RockboxService extends Service
|
||||||
* provides enough cpu time to do music decoding in the
|
* provides enough cpu time to do music decoding in the
|
||||||
* background
|
* background
|
||||||
*/
|
*/
|
||||||
instance.startForeground(R.string.notification, instance.notification);
|
instance.startForegroundCompat(R.string.notification, instance.notification);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -187,8 +203,66 @@ public class RockboxService extends Service
|
||||||
{
|
{
|
||||||
if (instance.notification != null)
|
if (instance.notification != null)
|
||||||
{
|
{
|
||||||
instance.stopForeground(true);
|
instance.stopForegroundCompat(R.string.notification);
|
||||||
instance.mNM.cancel(R.string.notification);
|
instance.mNM.cancel(R.string.notification);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This is a wrapper around the new startForeground method, using the older
|
||||||
|
* APIs if it is not available.
|
||||||
|
*/
|
||||||
|
void startForegroundCompat(int id, Notification notification) {
|
||||||
|
// If we have the new startForeground API, then use it.
|
||||||
|
if (mStartForeground != null) {
|
||||||
|
mStartForegroundArgs[0] = Integer.valueOf(id);
|
||||||
|
mStartForegroundArgs[1] = notification;
|
||||||
|
try {
|
||||||
|
mStartForeground.invoke(this, mStartForegroundArgs);
|
||||||
|
} catch (InvocationTargetException e) {
|
||||||
|
// Should not happen.
|
||||||
|
Log.w("ApiDemos", "Unable to invoke startForeground", e);
|
||||||
|
} catch (IllegalAccessException e) {
|
||||||
|
// Should not happen.
|
||||||
|
Log.w("ApiDemos", "Unable to invoke startForeground", e);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Fall back on the old API.
|
||||||
|
setForeground(true);
|
||||||
|
mNM.notify(id, notification);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This is a wrapper around the new stopForeground method, using the older
|
||||||
|
* APIs if it is not available.
|
||||||
|
*/
|
||||||
|
void stopForegroundCompat(int id) {
|
||||||
|
// If we have the new stopForeground API, then use it.
|
||||||
|
if (mStopForeground != null) {
|
||||||
|
mStopForegroundArgs[0] = Boolean.TRUE;
|
||||||
|
try {
|
||||||
|
mStopForeground.invoke(this, mStopForegroundArgs);
|
||||||
|
} catch (InvocationTargetException e) {
|
||||||
|
// Should not happen.
|
||||||
|
Log.w("ApiDemos", "Unable to invoke stopForeground", e);
|
||||||
|
} catch (IllegalAccessException e) {
|
||||||
|
// Should not happen.
|
||||||
|
Log.w("ApiDemos", "Unable to invoke stopForeground", e);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Fall back on the old API. Note to cancel BEFORE changing the
|
||||||
|
// foreground state, since we could be killed at that point.
|
||||||
|
mNM.cancel(id);
|
||||||
|
setForeground(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDestroy() {
|
||||||
|
// Make sure our notification is gone.
|
||||||
|
stopForegroundCompat(R.string.notification);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue