2017-04-06 40 views
-2

对于使用基于android位置的服务,我们使用扩展了Service并实现LocationListener接口的GPS追踪器类。这里有什么服务类的用法?它只是为了获得位置更新在后台或更多?为什么GPS追踪器扩展服务

实施例以下代码:

public class GPSTracker extends Service implements LocationListener { 

    private final Context mContext; 

    // flag for GPS status 
    boolean isGPSEnabled = false; 

    // flag for network status 
    boolean isNetworkEnabled = false; 

    // flag for GPS status 
    boolean canGetLocation = false; 

    Location location; // location 
    double latitude; // latitude 
    double longitude; // longitude 

    // The minimum distance to change Updates in meters 
    private static final long MIN_DISTANCE_CHANGE_FOR_UPDATES = 10; // 10 meters 

    // The minimum time between updates in milliseconds 
    private static final long MIN_TIME_BW_UPDATES = 1000 * 60 * 1; // 1 minute 

    // Declaring a Location Manager 
    protected LocationManager locationManager; 

    public GPSTracker(Context context) { 
     this.mContext = context; 
     getLocation(); 
    } 

    public Location getLocation() { 
     try { 
     locationManager = (LocationManager) mContext.getSystemService(LOCATION_SERVICE); 

     // getting GPS status 
     isGPSEnabled = locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER); 

     // getting network status 
     isNetworkEnabled = locationManager 
      .isProviderEnabled(LocationManager.NETWORK_PROVIDER); 

     if (!isGPSEnabled && !isNetworkEnabled) { 
      // no network provider is enabled 
     } else { 
      this.canGetLocation = true; 
      // First get location from Network Provider 
      if (isNetworkEnabled) { 
       locationManager.requestLocationUpdates(
        LocationManager.NETWORK_PROVIDER, 
        MIN_TIME_BW_UPDATES, 
        MIN_DISTANCE_CHANGE_FOR_UPDATES, this); 

       Log.d("Network", "Network"); 
       if (locationManager != null) { 
        location = locationManager 
        .getLastKnownLocation(LocationManager.NETWORK_PROVIDER); 

        if (location != null) { 
        latitude = location.getLatitude(); 
        longitude = location.getLongitude(); 
        } 
       } 
      } 

      // if GPS Enabled get lat/long using GPS Services 
      if (isGPSEnabled) { 
       if (location == null) { 
        locationManager.requestLocationUpdates(
        LocationManager.GPS_PROVIDER, 
        MIN_TIME_BW_UPDATES, 
        MIN_DISTANCE_CHANGE_FOR_UPDATES, this); 

        Log.d("GPS Enabled", "GPS Enabled"); 
        if (locationManager != null) { 
        location = locationManager 
         .getLastKnownLocation(LocationManager.GPS_PROVIDER); 

        if (location != null) { 
         latitude = location.getLatitude(); 
         longitude = location.getLongitude(); 
        } 
        } 
       } 
      } 
     } 

     } catch (Exception e) { 
     e.printStackTrace(); 
     } 

     return location; 
    } 

    /** 
     * Stop using GPS listener 
     * Calling this function will stop using GPS in your app 
    * */ 

    public void stopUsingGPS(){ 
     if(locationManager != null){ 
     locationManager.removeUpdates(GPSTracker.this); 
     } 
    } 

    /** 
     * Function to get latitude 
    * */ 

    public double getLatitude(){ 
     if(location != null){ 
     latitude = location.getLatitude(); 
     } 

     // return latitude 
     return latitude; 
    } 

    /** 
     * Function to get longitude 
    * */ 

    public double getLongitude(){ 
     if(location != null){ 
     longitude = location.getLongitude(); 
     } 

     // return longitude 
     return longitude; 
    } 

    /** 
     * Function to check GPS/wifi enabled 
     * @return boolean 
    * */ 

    public boolean canGetLocation() { 
     return this.canGetLocation; 
    } 

    /** 
     * Function to show settings alert dialog 
     * On pressing Settings button will lauch Settings Options 
    * */ 

    public void showSettingsAlert(){ 
     AlertDialog.Builder alertDialog = new AlertDialog.Builder(mContext); 

     // Setting Dialog Title 
     alertDialog.setTitle("GPS is settings"); 

     // Setting Dialog Message 
     alertDialog.setMessage("GPS is not enabled. Do you want to go to settings menu?"); 

     // On pressing Settings button 
     alertDialog.setPositiveButton("Settings", new DialogInterface.OnClickListener() { 
     public void onClick(DialogInterface dialog,int which) { 
      Intent intent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS); 
      mContext.startActivity(intent); 
     } 
     }); 

     // on pressing cancel button 
     alertDialog.setNegativeButton("Cancel", new DialogInterface.OnClickListener() { 
     public void onClick(DialogInterface dialog, int which) { 
      dialog.cancel(); 
     } 
     }); 

     // Showing Alert Message 
     alertDialog.show(); 
    } 

    @Override 
    public void onLocationChanged(Location location) { 
    } 

    @Override 
    public void onProviderDisabled(String provider) { 
    } 

    @Override 
    public void onProviderEnabled(String provider) { 
    } 

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

    @Override 
    public IBinder onBind(Intent arg0) { 
     return null; 
    } 
} 
+2

请勿使用它。这是糟糕的代码。有[更多详情](http://gabesechansoftware.com/location-tracking/)。 –

+2

因为它是可怕的androidhive所谓的教程。 – Selvin

回答

-1

的该主要目的是不被活动的生命周期相关的。每当用户在活动之间导航时,大多数情况下您都不想销毁并创建新的GpsTracker。因此,Services进入阶段。然而,你应该强烈考虑避开这种技术,转而采用FusedLocationProviderApi,其目标是优化电池的使用。

+0

谢谢@azizbekian。你能否详细说明一下? – Nishith

+0

对不起,你会重述一下你的意思吗? – azizbekian

+1

当然不是,真实的服务需要不带参数的构造函数,它不需要上下文,因为它是一个上下文,显然不能用操作符new来“启动”,不要提到你不能以这种方式从服务启动对话... * *这只是一个可怕的androidhive网站的例子。** – Selvin