我真的需要你的帮助。
我有一个包含纬度和经度数据的数据库,例如:
ID_的 _ __ _ 名称的 _ ____ LAT 的 _ __ _ ____ _long
1_ _ ___ 酒店一 _ __ 6.1234 < / EM> _ __ _ __ -106.12345
2_ _ __ 酒店二 _ ___ 6.54321 < / EM> _ __ _ _ -107.23456
3_ _ _ 酒店三 _ __ 7.12345 < / EM> _ __ _ _ -106.98765
Android上的ListView中的数据显示。我使用onItemClick,所以如果我点击ListView中的一个项目,它将转到
Intent(android.content.Intent.ACTION_VIEW, Uri.parse("http://maps.google.com/maps?f=d&saddr=&daddr="+lat_var+","+long_var))
但问题是如果我单击ListView中的一个项目,lat_var中的数据和上面的intent中的long_var将不会从我的数据库中提供lat和long数据......
这里是我的代码,你可以编辑它,所以如果我单击ListView中的一个项目,它将从我的数据库中给我lat和long数据。例如,如果我单击hotel 2,lat_var将更改为6.54321,long_var将更改为-107.23456。
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,
long arg3) {
// TODO Auto-generated method stub
SQLiteDatabase dbs = dbHotelHelper.getReadableDatabase();
String get_lat = "SELECT lat FROM hoteltbl";
Cursor result_lat = dbs.rawQuery(get_lat, null);
double lat_var = result_lat.getColumnIndex("lat");
String get_long = "SELECT lat FROM hoteltbl";
Cursor result_long = dbs.rawQuery(get_long, null);
double long_var = result_long.getColumnIndex("long");
Intent intent = new Intent(android.content.Intent.ACTION_VIEW, Uri.parse("http://maps.google.com/maps?f=d&saddr=&daddr="+lat_var+","+long_var));
startActivity(intent);
}
我不知道问题是我的语法还是什么。请修复我的代码。我非常感谢任何回答这个问题的人......
答案 0 :(得分:4)
首先,只需要一个查询。无需两次查询您的表。 其次,您需要使用您选择的参数调整查询:
@Override
protected void onListItemClick(ListView listView, View view, int position, long id) {id) {
String selectedItem = (String) getListAdapter().getItem(position);
String query = "SELECT lat, long FROM hoteltbl WHERE name = '" + selectedItem + "'";
SQLiteDatabase dbs = dbHotelHelper.getReadableDatabase();
Cursor result = dbs.rawQuery(query, null);
result.moveToFirst();
double lat = result.getDouble(result.getColumnIndex("lat"));
double long = result.getDouble(result.getColumnIndex("long"));
....
此代码是在StackOverflow编辑器中编写的,它可能无法正常工作,但会给你一个想法。
(另外,不要在变量中添加后缀“_var”或“_long”,在Java等强类型语言中没有必要)