2014-01-03 4 views
1

Привет, AM, используя следующий код: How to get current location in Android Здесь я использую TextView для отображения координат местоположения один раз. Теперь Как я могу продолжить обновление местоположения в TextView после изменения местоположения.Получение обновлений местоположения на Android

коды я использую в настоящее время: Это моя основная активность

package com.example.locationtests; 

import android.os.Bundle; 
import android.app.Activity; 
import android.view.Menu; 
import android.widget.TextView; 

public class MainActivity extends Activity { 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    GPSTracker mGPS = new GPSTracker(this); 

    TextView text = (TextView) findViewById(R.id.texts); 
    if(mGPS.canGetLocation){ 
    mGPS.getLocation(); 
    text.setText("Lat"+mGPS.getLatitude()+"Lon"+mGPS.getLongitude()); 
    }else{ 
     text.setText("Unabletofind"); 
     System.out.println("Unable"); 
    } 
} 

@Override 
public boolean onCreateOptionsMenu(Menu menu) { 
    // Inflate the menu; this adds items to the action bar if it is present. 
    getMenuInflater().inflate(R.menu.main, menu); 
    return true; 
} 
} 

This is the class im using for Tracking: 

package com.example.locationtests; 

import android.app.AlertDialog; 
import android.content.Context; 
import android.content.DialogInterface; 
import android.content.Intent; 
import android.location.Location; 
import android.location.LocationListener; 
import android.location.LocationManager; 
import android.os.Bundle; 
import android.provider.Settings; 
import android.util.Log; 

public final class GPSTracker implements LocationListener { 

    private final Context mContext; 

    // flag for GPS status 
    public 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 = 1; // 10 meters 

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

    // Declaring a Location Manager 
    protected LocationManager locationManager; 

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

    /** 
    * Function to get the user's current location 
    * 
    * @return 
    */ 
    public Location getLocation() { 
     try { 
      locationManager = (LocationManager) mContext 
        .getSystemService(Context.LOCATION_SERVICE); 

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

      Log.v("isGPSEnabled", "=" + isGPSEnabled); 

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

      Log.v("isNetworkEnabled", "=" + isNetworkEnabled); 

      if (isGPSEnabled == false && isNetworkEnabled == false) { 
       // no network provider is enabled 
      } else { 
       this.canGetLocation = true; 
       if (isNetworkEnabled) { 
        location=null; 
        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) { 
        location=null; 
        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) { 
    } 

} 
This is my AndroidManifest.xml 

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
    package="com.example.locationtests" 
    android:versionCode="1" 
    android:versionName="1.0" > 
    <uses-permission android:name="android.permission.CAMERA" /> 
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> 
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> 
    <uses-permission android:name="android.permission.INTERNET"></uses-permission> 
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> 
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
    <uses-permission android:name="android.permission.VIBRATE" /> 
    <uses-feature android:name="android.hardware.camera" /> 
    <uses-feature android:name="android.hardware.location" android:required="true" /> 
    <uses-feature android:name="android.hardware.location.gps" android:required="false" /> 

    <uses-sdk 
     android:minSdkVersion="8" 
     android:targetSdkVersion="17" /> 

    <application 
     android:allowBackup="true" 
     android:icon="@drawable/ic_launcher" 
     android:label="@string/app_name" 
     android:theme="@style/AppTheme" > 
     <activity 
      android:name="com.example.locationtests.MainActivity" 
      android:label="@string/app_name" > 
      <intent-filter> 
       <action android:name="android.intent.action.MAIN" /> 

       <category android:name="android.intent.category.LAUNCHER" /> 
      </intent-filter> 
     </activity> 

ответ

1

При вызове метода requestLocationUpdates на locationManger, необходимо указать «это» как LocationListener:

locationManager.requestLocationUpdates(..., ..., ..., this); 

Это нормально поскольку класс реализует LocationListener. Обратный вызов, сделанный при изменении местоположения, является методом 'onLocationChanged'. У вас есть этот метод в своем классе, но это не имеет никакого кода, так делает ничего:

@Override 
public void onLocationChanged(Location location) { 
} 

Добавить соответствующий код, чтобы получить новую широту и долготу от параметра «местоположение» и обновить TextView назад в вашей деятельности. Существует несколько способов сделать это. Два, которые приходят на ум:

1) Передайте ссылку на TextView в конструкторе класса GPSTracker, чтобы вы могли получить к нему доступ из класса. 2) Передайте ссылку на Activity в конструкторе класса GPSTracker, чтобы вы могли вызвать метод в своей деятельности (который принимает отображаемые значения), который может обновить TextView.

EDIT:

У вас уже есть ссылки на которые я ссылаюсь в пункте 2 выше. При создании экземпляра вашего экземпляра GPSTracker в вашей деятельности, вы уже передать его «это»:

GPSTracker mGPS = new GPSTracker(this); 

В этом случае «это» является экземпляр вашего класса MainActivity и класс активности также случается быть Context. В конструкторе GPSTracker вы сохраняете этот контекст в переменной:

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

Поэтому вы можете использовать его для доступа к TextView. Cast контекст вы должны к деятельности, а затем вы можете использовать метод findViewById на нем:

@Override 
public void onLocationChanged(Location location) 
{ 
    TextView text = (TextView) ((Activity)mContext).findViewById(R.id.texts); 
    text.setText("Lat"+location.getLatitude()+"Lon"+location.getLongitude()); 
} 
+0

Привет Найджел, Может вы подробно изложите этот метод как то, что вы предложили именно в моем коде. Я новичок в Android и развиваюсь медленно. Вы будете очень благодарны за помощь. Отношения Сэм – user2943858

+0

См. Мое редактирование выше. – NigelK

+0

NigelK, Superrrrrrrrrb - это то, что я могу вам сказать ... Его работа и его работа очень хороши ... место постоянно обновляется на расстоянии еще менее 1 или 2 м .... Удивительная очень много .... Моя проблема решена .... привет, Sam – user2943858

0

что-то вроде этого:

Пример кода:

@Override 
public void onLocationChanged(Location location) { 
Log.d(TAG, "GPS LocationChanged"); 
double lat = location.getLatitude(); 
double lng = location.getLongitude(); 
Log.d(TAG, "Received GPS request for " + String.valueOf(lat) + "," + String.valueOf(lng)  + " , ready to rumble!"); 

// Do clever stuff here 
} 
+0

. Я новичок в этом .. я добавил это к своему коду, но не понял, что сделайте следующее ... можете ли вы просто разработать ... что за умные вещи, которые я должен сделать ... Можете ли вы увидеть мой код и дать мне шаги именно в том, что мне нужно делать. – user2943858

Смежные вопросы