Ich mache etwas ähnliches zu dir selbst, aber ich benutze einen Server. Der Grund, warum ich das tue, ist aus Rechengründen. Wenn die Anwendung zum ersten Mal gestartet wird, wird eine HTTP-Anfrage an ein PHP-Skript gesendet, das eine MySQL-Abfrage enthält. Das PHP-Skript empfängt den aktuellen Lat/Long des Benutzers und gibt in einem JSON alle Punkte innerhalb von 1 KM des aktuellen Standorts zurück. Die Anwendung analysiert dann diesen JSON in einer lokalen MySQL-Datenbank und erledigt damit.
Um die HTTP-Anforderung und analysieren, um die JSON in eine Datenbank ich folgendes mache ..
//http post
try{
HttpClient httpclient = new DefaultHttpClient();
HttpPost httppost = new HttpPost("http://URL");
httppost.setEntity(new UrlEncodedFormEntity(parameters));
HttpResponse response = httpclient.execute(httppost);
HttpEntity entity = response.getEntity();
InputStream is = entity.getContent();
//convert response to string
BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);
StringBuilder sb = new StringBuilder();
String line = null;
while ((line = reader.readLine()) != null) {
sb.append(line + "\n");
}
is.close();
result=sb.toString();
}catch(Exception e){
new AlertDialog.Builder(this)
.setTitle("Woops!")
.setMessage("Getlocations:It appears the server is not reachable. Check your connectivity and try again.")
.setPositiveButton("Ok", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,
int which) {
//User wants to start activity..
}
})
.show();
Log.e("log_tag", "Error in connection or convert "+e.toString());
}
//parse json data
try{
System.out.println("parsing data");
JSONArray jArray = new JSONArray(result);
if(icount != 0){
try{
SQLiteDatabase db = tweets.getWritableDatabase();
db.delete(TABLE_NAME,null,null);
}finally {
tweets.close();
}
}
//TODO: Change this to num
for(int i=0;i<jArray.length() && q < 1;i++){
System.out.println("ARRAY LENGTH " + jArray.length());
q++;
JSONObject json_data = jArray.getJSONObject(i);
System.out.println("Getting Info");
Double lat = json_data.getDouble("lat");
Double lng = json_data.getDouble("lng");
String link = json_data.getString("link");
String message = json_data.getString("message");
String sname = json_data.getString("sname");
String name = json_data.getString("name");
//Add each entry to SQL database...
System.out.println("Adding table row!");
try{
addloc(name,sname,message,link,lat,lng);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
tweets.close();
}
count();
}
}catch(JSONException e){
new AlertDialog.Builder(this)
.setTitle("Woops!")
.setMessage("Getlocations: It appears something went wrong processing the information.")
.setPositiveButton("Ok", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,
int which) {
//User wants to start activity..
}
})
.show();
Log.e("log_tag", "Error parsing data "+e.toString());
}
Hierzu zu senden eine Datei kurze PHP ist alles was Sie brauchen dafür einzusetzen, den Lat/lng Etwas nimmt wie ...
<?php
mysql_connect("host","user","pass");
mysql_select_db("database");
$lat = $_REQUEST['currlat'];
$lng = $_REQUEST['currlng'];
$q=mysql_query("QUERY") or die(mysql_error());
if (mysql_num_rows($q) == 0) {
echo "No rows found, nothing to print so am exiting";
exit;
}
if(!q){
echo "NO RESULT";
exit;
}
while($e=mysql_fetch_assoc($q))
$output[]=$e;
print(json_encode($output));
mysql_close();
?>
Das wird die Werte aufnehmen und Ergebnisse in JSON drucken.
// edit: Um den lat/lng an erster Stelle zu bekommen benutze ich das GPS.
Hoffe, das hilft.
Vielen Dank für den Hinweis Twaroog - es hat ganz gut funktioniert. Dank dir konnte ich mit meinem Projekt ein Stück weiter gehen. – Pavel
Kein Problem, ich mache das auch in meinem Projekt. – LordTwaroog