我遇到了停止我已启动的服务的问题。
当用户登录时调用该服务,并开始跟踪用户的位置。这工作正常。当用户按下注销按钮并成功注销时,该服务将停止。
这是一个Android服务,通过HTML按钮通过JavaScript界面调用。
这是我的主类,其中包含启动和停止服务的方法:
public class CasesMain extends DroidGap {
Intent gpsTracking;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
super.init();
appView.addJavascriptInterface(this, "StartGPS");
super.loadUrl(Config.getStartUrl());
}
public void startGPS(){
gpsTracking = new Intent(this, MyService.class);
startService(gpsTracking);
}
public void stopGPS(){
stopService( gpsTracking );
}
}
以下是MyService类:
public class MyService extends Service {
private LocationManager locManager;
private LocationListener locListener = new myLocationListener();
private boolean gps_enabled = false;
private boolean network_enabled = false;
private Handler handler = new Handler();
Thread t;
@Override
public IBinder onBind(Intent intent) {
return null;
}
@Override
public void onCreate() {
}
@Override
public void onDestroy() {
}
@Override
public void onStart(Intent intent, int startid) {
}
public int onStartCommand(Intent intent, int flags, int startId) {
Toast.makeText(getBaseContext(), "Service Started", Toast.LENGTH_SHORT)
.show();
final Runnable r = new Runnable() {
public void run() {
location();
handler.postDelayed(this, 10000);
}
};
handler.postDelayed(r, 10000);
return START_STICKY;
}
public void location() {
locManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
try {
gps_enabled = locManager
.isProviderEnabled(LocationManager.GPS_PROVIDER);
} catch (Exception ex) {
}
try {
network_enabled = locManager
.isProviderEnabled(LocationManager.NETWORK_PROVIDER);
} catch (Exception ex) {
}
if (gps_enabled) {
locManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0,
0, locListener);
}
if (network_enabled) {
locManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER,
0, 0, locListener);
}
}
private class myLocationListener implements LocationListener {
double lat_old = 0.0;
double lon_old = 0.0;
double lat_new;
double lon_new;
@Override
public void onLocationChanged(Location location) {
if (location != null) {
locManager.removeUpdates(locListener);
lon_new = location.getLongitude();
lat_new = location.getLatitude();
String longitude = "Longitude: " + location.getLongitude();
String latitude = "Latitude: " + location.getLatitude();
Log.v("Debug", "Latt: " + latitude + " Long: " + longitude);
Toast.makeText(getApplicationContext(),
longitude + "\n" + latitude, Toast.LENGTH_SHORT).show();
lat_old = lat_new;
lon_old = lon_new;
}
}
@Override
public void onProviderDisabled(String provider) {
}
@Override
public void onProviderEnabled(String provider) {
}
@Override
public void onStatusChanged(String provider, int status, Bundle extras) {
}
}
}
以下是我停止服务的电话:window.StartGPS.stopGPS();
开始工作完美,但是当我退出时,应用程序继续显示格子的消息,并且意味着对stopService()
的调用不起作用或未调用。
任何人都可以看到我的错误在哪里或出了什么问题?
任何帮助将不胜感激!
固定
在handler.removeCallbacksAndMessages(null);
onDestroy()
方法中添加MyService
为我修复了它。
答案 0 :(得分:14)
任何人都可以看到我的错误在哪里或出了什么问题?
您有一个空的onDestroy()
方法。您需要在removeCallbacks()
处致电Handler
。
答案 1 :(得分:2)
如果您在服务中使用任何android.os.Handler,请记得调用removeCallbacksAndMessages,如下所示:
@Override
public void onDestroy() {
Toast.makeText(this, "service onDestroy", Toast.LENGTH_LONG).show();
Utils.cancelNotification(this);
customHandler.removeCallbacksAndMessages(null);
}
该服务将成功销毁。它对我有用。
答案 2 :(得分:0)
这是我的建议 1)在导致stopService的调用中放入更多日志语句。 2)在ServiceConnection接口上实现,看看OServiceConnected和onServiceDisconnected中发生了什么。