我不知道如何從數(shù)據(jù)庫中的數(shù)組列表在 GoogleMaps 上添加標記。我已經(jīng)嘗試了很多但沒有任何效果。來自數(shù)據(jù)庫的數(shù)組列表:public ArrayList<HashMap<String, String>> GetUserByUserId(int userid){ SQLiteDatabase db = this.getWritableDatabase(); ArrayList<HashMap<String, String>> userList = new ArrayList<>(); String query = "SELECT Loc, Lat, Long FROM "+ TABLE_Users; Cursor cursor = db.query(TABLE_Users, new String[]{LocationName, Latitude, Longitude}, KEY_ID+ "=?",new String[]{String.valueOf(userid)},null, null, null, null); if (cursor.moveToNext()){ HashMap<String,String> user = new HashMap<>(); user.put("Loc",cursor.getString(cursor.getColumnIndex(LocationName))); user.put("Lat",cursor.getString(cursor.getColumnIndex(Latitude))); user.put("Long",cursor.getString(cursor.getColumnIndex(Longitude))); userList.add(user); } return userList;}我的嘗試@Overridepublic void onMapReady(GoogleMap googleMap) { Database db = new Database(this); ArrayList<HashMap<String, String>> userList = db.GetUsers(); mMap = googleMap; double latitude = 0; double longitude = 0; for (int i = 0; i < userList.size(); i++) { latitude = Double.parseDouble(userList.get(i).get("latitude").toString()); longitude = Double.parseDouble(userList.get(i).get("longitude").toString()); mMap.addMarker(new MarkerOptions().position(new LatLng(latitude, longitude))); }Google 地圖應(yīng)顯示數(shù)據(jù)庫中緯度和經(jīng)度的所有標記
1 回答

一只甜甜圈
TA貢獻1836條經(jīng)驗 獲得超5個贊
假設(shè)您的userList
列表在打印時包含以下格式的位置:
Log.d("userListTag", userList.toString())
輸出:
userListTag: [{Loc=California, Long=-117.985904, Lat=35.125801}, {Loc=Las Vegas, Long=-115.13983, Lat=36.169941}]
當我運行你的代碼時,我收到此錯誤:
java.lang.NullPointerException:嘗試在空對象引用上調(diào)用虛擬方法“java.lang.String java.lang.String.toString()”
這是因為您試圖獲取“緯度”和“經(jīng)度”,它們在userList
. 嘗試用“Lat”和“Long”替換它們,如下所示:
latitude = Double.parseDouble(userList.get(i).get("Lat").toString()); longitude = Double.parseDouble(userList.get(i).get("Long").toString());
我用上述更改測試了您的代碼,兩個示例標記在我的地圖上都顯示良好,所以我希望這對您有幫助!
添加回答
舉報
0/150
提交
取消