Erste Standort-Updates in Android
Hallo BIN mit dem folgenden code verwendet : Wie man der aktuellen Lage in Android
Hier bin mit dem TextView Anzeige der Positionskoordinaten einmal.
Nun, Wie kann ich halten Aktualisierung der Lage in TextView einmal die Lage ändert sich ständig.
Codes, die ich jetzt verwende: Das ist meine Haupttätigkeit
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>
InformationsquelleAutor user2943858 | 2014-01-03
Du musst angemeldet sein, um einen Kommentar abzugeben.
Beim Aufruf der Methode requestLocationUpdates auf locationManger, geben Sie 'dies' als LocationListener:
Das ist in Ordnung, da die Klasse die LocationListener implementiert. Der Rückruf erfolgt, wenn der Standort sich ändert ist die Methode "onLocationChanged'. Sie haben diese Methode in der Klasse, aber es hat keinen code, also macht nix:
Fügen Sie entsprechenden code, um die neue Breite und Länge aus der 'location' parameter und aktualisieren Sie die TextView zurück in Ihre Tätigkeit. Es gibt eine Reihe von Möglichkeiten, dies zu tun. Zwei, die den Sinn kommen:
1) Übergeben Sie einen Verweis auf die TextView in der GPSTracker-Klasse-Konstruktor, so dass Sie zugreifen können es aus der Klasse.
2) Übergeben Sie einen Verweis auf die Aktivität in der GPSTracker-Klasse-Konstruktor, so können Sie rufen eine Methode in der Activity (, akzeptiert die Werte zu zeigen) , können dann aktualisieren Sie die TextView.
EDIT:
Haben Sie bereits die Referenz Verweise ich auf die in Punkt 2 oben. Wenn Sie instanziiert Instanz von GPSTracker in Ihrer Tätigkeit, die Sie bereits übergeben "this":
In diesem Fall 'das' ist die Instanz der MainActivity-Klasse und einer Activity-Klasse kommt auch zu einem Kontext. Im Konstruktor der GPSTracker, den Sie speichern diesem Zusammenhang in einer Variablen:
Daher können Sie es verwenden, um den Zugriff auf die TextView. Cast Zusammenhang haben Sie, um eine Aktivität, und Sie können dann verwenden Sie die findViewById Methode:
Bitte siehe mein edit oben.
NigelK, Superrrrrrrrrb ist das, was ich Ihnen sagen kann....Seine Arbeit und seine arbeiten in einer sehr guten Art und Weise..er Lage hält die Aktualisierung selbst in einer Entfernung von sogar weniger als 1 oder 2 m.....Genial ty sehr viel....Mein problem ist gelöst....Grüße, Sam
Nigelk....zusätzlich zu dieser....Jetzt habe ich die aktualisierten Koordinaten des Standorts in eine Datei....bin in den Prozess der tranfering die Datei auf meinem laptop und verwenden Sie es weiter...ich kann nicht verwenden, internet-services, wo jeder in der Strömung..Zusammenfassung ist, ich habe eine Datei, gespeichert im internen Speicher meines android-Handy und ich habe, um es zu senden, um meinen windows-basierten laptop über den wireless-Netzwerk-Technologie, ohne die Verwendung von internet-Dienstleistungen..ich kann nicht USB verwenden, als auch weil das Gefühl braucht, zu erhalten aktualisiert mit den Koordinaten...
Sam - ich Stelle mir Bluetooth ist der Weg zu gehen. Nicht etwas, was ich behandelt haben, so heben Sie bitte eine neue Frage und du bekommst viel Hilfe von anderen. Thx.
InformationsquelleAutor NigelK
Etwas wie das hier tun:
Beispielcode:
InformationsquelleAutor user2074792