通过Android ListView中的“onItemClick”,将数据从SQLite数据库传递到Intent

3

我真的需要你的帮助。

我有一个包含纬度和经度数据的数据库,例如:

id_____名称_____纬度_________经度

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中的某个项目,上面意图中的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);

        }

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

1个回答

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编辑器中编写的,可能不能直接使用,但可以给您提供一个思路。

(此外,在像Java这样的强类型语言中,不需要将后缀“_var”或“_long”添加到变量中)


谢谢你的答案,我已经使用它了。但是getListAdapter()方法怎么用呢?在我的情况下,你能提供一下代码吗? - forgiven24

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接