gpt4 book ai didi

android - 通过 "onItemClick"在ListView Android item上从SQLite数据库获取数据到intent

转载 作者:太空宇宙 更新时间:2023-11-03 13:35:05 24 4
gpt4 key购买 nike

我真的需要你的帮助。

我有一个包含纬度和经度数据的数据库,这里是示例:

id_____姓名_____lat_________long

1_____酒店一___6.1234______-106.12345

2____酒店二____6.54321_____-107.23456

3___酒店三___7.12345_____-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 中的项目之一,则上面 Intent 中的 lat_var 和 long_var 中的数据不会给我数据库中的纬度和经度数据...

这是我的代码,你能编辑它吗,所以如果我单击 ListView 中的一个项目,它会给我数据库中的纬度和经度数据。例如,如果我点击酒店二,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);

}

我不知道问题是我的语法还是什么。请修复我的代码。我真的很感谢任何回答这个问题的人......

最佳答案

首先,只需要一个查询。无需两次查询您的表。其次,您需要使用您选择的参数调整您的查询:

@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 等强类型语言中没有必要这样做)

关于android - 通过 "onItemClick"在ListView Android item上从SQLite数据库获取数据到intent,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8285453/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com