android 多线程刷新Location

我在做的一个功能是过几分钟就提交一次坐标到服务器,进行保存,跟踪司机地理位置。

 

 

主线程:

private static final String CONTEXT = Context.LOCATION_SERVICE; // 环境

LocationManager locationManager;

 

 

/** 获得LocationManager实例 */

public LocationManager getLocationManager() {

return (LocationManager) getSystemService(CONTEXT);

}

 

onCreate方法:

{

 

            Thread t = new Thread(new getLocation(provider));

t.setDaemon(true);// 设置为后台线程

t.start();

 

}

 

 

Handler h = new Handler() {

 

@Override

public void handleMessage(Message msg) {

LocationManager l = getLocationManager();

 

try {

String provider1 = getProvider(getLocationManager());

TimeUnit.MICROSECONDS.sleep(100);

l.requestLocationUpdates(provider1, 0, 0, locationListener);

 

Location location = l.getLastKnownLocation(provider1);

//打印效果。

System.out.println(location.getLatitude()

+ "{}{}{}{}{}{}{}{}___");

// 为绘制标志的类设置坐标,非常重要,刷新Location

mapOverlay.setLocation(location);

Thread t = new Thread(new getLocation(provider1));

t.start();

Thread.yield();

} catch (InterruptedException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

super.handleMessage(msg);

}

};

 

private class getLocation implements Runnable {

 

 

@Override

public void run() {

Message m = new Message();

h.handleMessage(m);  // Handler的实例

Thread.yield();

}

}

 

getLocation 和handler 这2个线程,让他们相互调用,形成死循环状态。

mapOverlay.setLocation(location); 这个方法太重要了。。。

 

程序总是出现在线程错误,不知道哪位大侠能够指点下原因:

下面是截图

Error

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android锁屏无法继续定位问题 产生问题的原因: 手机锁屏后,Android系统为了省电以及减少CPU消耗,在一段时间后会将手机进入休眠状态。此时的服务以及线程等都会停止。 最近就这个问题,阅读了很多代码以及官方文档,下面就说下最近都尝试过的方式,可能其中有些您实现了,我这边没实现,望见谅。本文采用的高德定位。 一、PowerManager.WakeLock (1)直接强制当前页面cpu运行 private PowerManager pm; private PowerManager.WakeLock wakeLock; @Override public void onCreate() { super.onCreate(); //创建PowerManager对象 pm = (PowerManager) getSystemService(Context.POWER_SERVICE); //保持cpu一直运行,不管屏幕是否黑屏 wakeLock = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "CPUKeepRunning"); wakeLock.acquire(); } @Override public void onDestroy() { wakeLock.release(); super.onDestroy(); } 这个写法我表示并没有什么用,并不能强制cpu持续运行。 (2)WakefulBroadcastReceiver public class WLWakefulReceiver extends WakefulBroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { // String extra = intent.getStringExtra("msg"); Intent serviceIntent = new Intent(context, MyIntentService.class); serviceIntent.putExtra("msg", extra); startWakefulService(context, serviceIntent); } } WakefulBroadcastReceiver 内部的原理也是PowerManager,注册广播时8.0的请动态注册,静态没有用。广播注册完了之后,写一个服务用来与广播互动。 public class MyIntentService extends IntentService { public MyIntentService() { super("MyIntentService"); } @Override public void onCreate() { super.onCreate(); } @Override protected void onHandleIntent(@Nullable final Intent intent) { //子线程中执行 Log.i("MyIntentService", "onHandleIntent"); String extra = intent.getStringExtra("msg"); new Thread(new Runnable() { @Override public void run() { Loca

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值