【问题标题】:how to get notified from updates in Service via ServiceConnection如何通过 ServiceConnection 从服务中的更新中获得通知
【发布时间】:2011-08-15 07:22:19
【问题描述】:

我对@9​​87654321@、ActivityIntent 的概念感到困惑。我想要做的是TrackerMapService 每 5 秒在后台工作一次检查位置,如果它被更改 TextView 的活动将更新跟踪的位置数。

公共类 TrackerService 扩展 IntentService 实现 LocationListener {

private static final String LOGTAG = "TrackerService";

private LocationManager manager;
private ArrayList<Location> storedLocations;

private boolean isTracking = false;

public TrackerService() {
    super("TrackerServiceName");
}

/* Service Setup Methods */
@Override
public void onCreate() {
    manager = (LocationManager)getSystemService(LOCATION_SERVICE);
    storedLocations = new ArrayList<Location>();
    Log.i(LOGTAG, "Tracking Service Running...");
}

public void startTracking() {
    if(!manager.isProviderEnabled(LocationManager.GPS_PROVIDER)) {
        return;
    }
    Toast.makeText(this, "Starting Tracker", Toast.LENGTH_SHORT).show();
    manager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 30000, 0, this);

    isTracking = true;
}

public void stopTracking() {
    Toast.makeText(this, "Stopping Tracker", Toast.LENGTH_SHORT).show();
    manager.removeUpdates(this);
    isTracking = false;
}

public boolean isTracking() {
    return isTracking;
}

@Override
public void onDestroy() {
    manager.removeUpdates(this);
    Log.i(LOGTAG, "Tracking Service Stopped...");
}

/* Service Access Methods */
public class TrackerBinder extends Binder {
    TrackerService getService() {
        return TrackerService.this;
    }
}

private final IBinder binder = new TrackerBinder();

@Override
public IBinder onBind(Intent intent) {
    return binder;
}

public int getLocationsCount() {
    return storedLocations.size();
}

public ArrayList<Location> getLocations() {
    return storedLocations;
}

/* LocationListener Methods */
@Override
public void onLocationChanged(Location location) {
    Log.i("TrackerService", "Adding new location");
    storedLocations.add(location);
}

@Override
public void onProviderDisabled(String provider) { }

@Override
public void onProviderEnabled(String provider) { }

@Override
public void onStatusChanged(String provider, int status, Bundle extras) { }

@Override
protected void onHandleIntent(Intent intent) {
    int updatedLocNumber = getLocationsCount();
    Log.d("IntentService", "logged" + updatedLocNumber + "location in intent");

    // TODO Auto-generated method stub
    Intent broadcastIntent = new Intent();
    broadcastIntent.setAction("LOCATION_UPDATED");
    getBaseContext().sendBroadcast(broadcastIntent);
}

}

公共类ServiceActivity扩展Activity实现View.OnClickListener {

Button enableButton, disableButton;
TextView statusView;

TrackerService trackerService;
Intent serviceIntent;

IntentFilter intentFilter;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    enableButton = (Button)findViewById(R.id.enable);
    enableButton.setOnClickListener(this);
    disableButton = (Button)findViewById(R.id.disable);
    disableButton.setOnClickListener(this);
    statusView = (TextView)findViewById(R.id.status);

    serviceIntent = new Intent(this, TrackerService.class);


    //intent to filter for updates
    intentFilter = new IntentFilter();
    intentFilter.addAction("LOCATION_UPDATED");
    registerReceiver(intentReceiver, intentFilter);
}

@Override
public void onResume() {
    super.onResume();
    //Starting the service makes it stick, regardless of bindings
    startService(serviceIntent);
    //Bind to the service
    bindService(serviceIntent, serviceConnection, Context.BIND_AUTO_CREATE);
}

@Override
public void onPause() {
    super.onPause();
    if(!trackerService.isTracking()) {
        //Stopping the service let's it die once unbound
        stopService(serviceIntent);
    }
    //Unbind from the service
    unbindService(serviceConnection);
}

@Override
public void onClick(View v) {
    switch(v.getId()) {
    case R.id.enable:
        trackerService.startTracking();
        break;
    case R.id.disable:
        trackerService.stopTracking();
        break;
    default:
        break;
    }
    updateStatus();
}

private void updateStatus() {
    if(trackerService.isTracking()) {
        statusView.setText(String.format("Tracking enabled.  %d locations logged.",trackerService.getLocationsCount()));
    } else {
        statusView.setText("Tracking not currently enabled.");
    }
}

private ServiceConnection serviceConnection = new ServiceConnection() {
    public void onServiceConnected(ComponentName className, IBinder service) {
        trackerService = ((TrackerService.TrackerBinder)service).getService();
        updateStatus();
    }

    public void onServiceDisconnected(ComponentName className) {
        trackerService = null;
    }
};

private BroadcastReceiver intentReceiver = new BroadcastReceiver() {

    @Override
    public void onReceive(Context context, Intent intent) {
        Toast.makeText(getBaseContext(), "AAAAA", Toast.LENGTH_LONG);

    }
};

} 编辑 LogCat: 08-15 14:40:36.982: 错误/ActivityManager(67): com.tugce.TrackerService 中的 ANR 08-15 14:40:36.982: ERROR/ActivityManager(67): 原因:执行服务 com.tugce.TrackerService/.TrackerService 08-15 14:40:36.982: 错误/ActivityManager(67): 负载: 0.63 / 0.19 / 0.15 08-15 14:40:36.982: ERROR/ActivityManager(67): CPU 使用率从 10147ms 到 0ms 前: 08-15 14:40:36.982: 错误/ActivityManager(67): 1.1% 133/com.android.launcher: 0.5% 用户 + 0.5% 内核/故障: 31 次要 08-15 14:40:36.982: 错误/ActivityManager(67): 0.4% 67/system_server: 0.2% 用户 + 0.1% 内核 08-15 14:40:36.982: 错误/ActivityManager(67): 0.1% 229/com.android.defcontainer: 0.1% 用户 + 0% 内核/故障: 33 次要 08-15 14:40:36.982: 错误/ActivityManager(67): 0% 40/adbd: 0% 用户 + 0% 内核 08-15 14:40:36.982: 错误/ActivityManager(67): 8.5% 总计: 5.9% 用户 + 2.5% 内核 08-15 14:40:36.982: ERROR/ActivityManager(67): CPU 使用率从 988ms 到 1576ms 后: 08-15 14:40:36.982: 错误/ActivityManager(67): 12% 67/system_server: 7% 用户 + 5.2% 内核 08-15 14:40:36.982: 错误/ActivityManager(67): 8.7% 80/ActivityManager: 5.2% 用户 + 3.5% 内核 08-15 14:40:36.982: 错误/ActivityManager(67): 1.7% 68/HeapWorker: 1.7% 用户 + 0% 内核 08-15 14:40:36.982: 错误/ActivityManager(67): 1.7% 229/com.android.defcontainer: 0% 用户 + 1.7% 内核 08-15 14:40:36.982: 错误/ActivityManager(67): 1.7% 230/HeapWorker: 0% 用户 + 1.7% 内核 08-15 14:40:36.982: ERROR/ActivityManager(67): 15% TOTAL: 12% user + 3.4% kernel

PS:请不要写任何其他不合适的方式而是“拯救一天”的解决方案,例如sharedPreferences。我想以最好的方式做到这一点..

【问题讨论】:

    标签: android


    【解决方案1】:

    您可以从服务中广播意图。

       Intent i = new Intent(NEW_UPDATE);  
       sendBroadcast(i);
    

    在活动中调用updateStatus()BroadcastReceiver

    public class Receiver extends BroadcastReceiver 
    {
    @Override
       public void onReceive(Context context, Intent intent) 
       {    
        String action = intent.getAction();
           if(action.equalsIgnoreCase(NEW_UPDATE)){  
               updateStatus();
           }
       }
    }
    

    创建广播接收器类的对象

    private Receiver mUpdateReceiver= new Receiver();
    

    并通过调用注册广播接收器

    registerReceiver(mUpdateReceiver, new IntentFilter(NEW_UPDATE));
    

    【讨论】:

    • 我已更新代码,但出现运行时错误。我在集成 LocationListener 和 Intent 时遇到了麻烦,请您检查一下代码吗?
    • 只是说运行时错误并没有帮助。请提供logcat异常报告。
    • 08-15 14:40:36.982:错误/ActivityManager(67):com.tugce.TrackerService 中的 ANR 08-15 14:40:36.982:错误/ActivityManager(67):原因:正在执行服务 com.tugce.TrackerService/.TrackerService
    • 对 logcat 没什么帮助。我无法让它为 locationListener 的 IntentService 和后台服务一起工作
    • UI 线程被阻塞。我想它的Android没有响应对话框。什么时候会发生这种情况
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2019-07-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-06-19
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多