【问题标题】:GPS not working in Async TaskGPS 在异步任务中不起作用
【发布时间】:2012-05-18 10:16:36
【问题描述】:

我已经实现了一个简单的 GPS 程序,它可以获取坐标并将它们显示在屏幕上。当我尝试改进此设计并实现异步任务时,GPS 似乎由于某种原因无法工作。将异步任务与 GPS 一起使用是否存在一些问题?这是我的代码:

private class DownloadTask extends AsyncTask<String, Void, Object> {
        protected Object doInBackground(String... args) {
            Log.i("MyApp", "Background thread starting");

            LocationManager mLocationManager;
            Gpslistener Gpslistener;

            Gpslistener = new Gpslistener();

            try{

               mLocationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);

               mLocationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0,Gpslistener);

            }catch (Exception e) {

                test_gps = true;
           }


        return null;
    }

    protected void onPostExecute(Object result) {

        if(test_gps == true){
            if (ParkingActivity.this.progressDialog != null) {
                ParkingActivity.this.progressDialog.dismiss();
            }               
            AlertMessage("GPS Error", "Unable to get location");
        }



public class Gpslistener implements LocationListener
{
        @Override
        public void onLocationChanged(Location loc)
        {
            loc.getLatitude();
            loc.getLongitude();
        }

        @Override
        public void onProviderDisabled(String provider)
        {       
        }

        @Override
        public void onProviderEnabled(String provider)
        {
        }

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

每次我运行它时,它总是会捕获一个异常。 GPS 权限在清单中设置,我总是使用不同的应用程序来确保 GPS 连接在线,因此我将这些作为潜在错误排除了。老实说,我想不出其他任何事情,没有异步任务它可以完美运行!非常感谢任何帮助,谢谢!

已编辑 我的异常日志猫:

05-09 22:56:20.199: E/EXCEPTION:(8874): java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare()
05-09 22:56:20.199: E/EXCEPTION:(8874): java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare()
05-09 22:56:20.199: E/EXCEPTION:(8874):     at android.os.Handler.<init>(Handler.java:121)
05-09 22:56:20.199: E/EXCEPTION:(8874):     at android.location.LocationManager$ListenerTransport$1.<init>(LocationManager.java:173)
05-09 22:56:20.199: E/EXCEPTION:(8874):     at android.location.LocationManager$ListenerTransport.<init>(LocationManager.java:173)
05-09 22:56:20.199: E/EXCEPTION:(8874):     at android.location.LocationManager._requestLocationUpdates(LocationManager.java:579)
05-09 22:56:20.199: E/EXCEPTION:(8874):     at android.location.LocationManager.requestLocationUpdates(LocationManager.java:446)
05-09 22:56:20.199: E/EXCEPTION:(8874):     at stefan.testservice.ParkingActivity$DownloadTask.doInBackground(ParkingActivity.java:163)
05-09 22:56:20.199: E/EXCEPTION:(8874):     at stefan.testservice.ParkingActivity$DownloadTask.doInBackground(ParkingActivity.java:1)
05-09 22:56:20.199: E/EXCEPTION:(8874):     at android.os.AsyncTask$2.call(AsyncTask.java:185)
05-09 22:56:20.199: E/EXCEPTION:(8874):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306)
05-09 22:56:20.199: E/EXCEPTION:(8874):     at java.util.concurrent.FutureTask.run(FutureTask.java:138)
05-09 22:56:20.199: E/EXCEPTION:(8874):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088)
05-09 22:56:20.199: E/EXCEPTION:(8874):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581)
05-09 22:56:20.199: E/EXCEPTION:(8874):     at java.lang.Thread.run(Thread.java:1019)

【问题讨论】:

标签: android gps android-asynctask locationmanager


【解决方案1】:

与许多其他事物一样,gps 监听器只能由循环线程(如 ui 线程)监听。最简单的方法是通过 ui 线程来实现。

此外,gps 侦听器的名称并非无缘无故。只有当它获得一个位置(这可能需要时间)时,它才会调用方法“onLocationChanged”。 你不需要为此设置 asyncTask,因为所有对“requestLocationUpdates”的调用都是异步的......

【讨论】:

    【解决方案2】:

    你不能那样做。只要doInBackground() 返回,线程就会终止。 GPS 监听器是一个 Handler,它需要一个 Looper 线程来操作。在doInBackground() 的开头,您需要调用Looper.prepare(),然后在结尾调用Looper.loop()。它将永远循环,直到您在线程的 Looper 对象上调用 quit()

    AsyncTask 确实是为一次性临时线程设计的,所以我会为此使用普通线程。虽然,我想你没有理由不这样做。您只需 100% 确保结束循环,否则即使在用户关闭应用后它也会永远运行。

    Java Can't create handler inside thread that has not called Looper.prepare()

    【讨论】:

      【解决方案3】:

      如果你想要一种肮脏而又不那么性感的方式:

      mLocationManager = (LocationManager)getActivity().getSystemService(Context.LOCATION_SERVICE);
      Looper.prepare();
      Looper.loop();
      if(mLocationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)){    
        mLocationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, GPS_MINIMUM_TIME, GPS_MINIMUM_DISTANCE, MyFragment.this);
      }
      Looper.myLooper().quit();
      

      基本上,它使当前线程成为将在其上执行消息的主线程,不久您就放弃了该线程作为主线程。我不确定这样做的后果。

      【讨论】:

        猜你喜欢
        • 2015-10-16
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2017-03-29
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多