从SQLite数据库获取数据到意图,通过"onItemClick"列表视图Android中的项目


我真的需要你的帮助。

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

id_ _ __ _ 名称 _ ___ lat _ __ _ ___ _long

1

_ _ ___ 酒店一个 _ __ 6.1234 _ __ _ __

-106.123452

_ _ __ 酒店两个 _ ___ 6.54321 _ __ _ _

-107.234563

_ _ _ 酒店三 _ __ 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它会给我从我的数据库的后期和长期数据。例如,如果我点击hotel two, 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等强类型语言中是不必要的)

相关内容

  • 没有找到相关文章

最新更新