我正在使用谷歌地图API。就我而言,我正在通过 php 接收来自 mysql 的纬度、经度和用户名。我一次集体接收所有用户。我尝试遵循代码,它只提供一个标记。请指导我。并且不要让它重复,因为我尝试了很多解决方案,但对我不起作用。如果您没有答案,请退出。请记录.class
public class Rec extends AppCompatActivity{
private GoogleMap mMap;
JSONObject jsonObject = new JSONObject();
JSONArray result = new JSONArray();
ArrayList<HashMap<String,String>> list = new ArrayList<>();
private String latitude,longitude,user_name;
Button btn;
private ProgressDialog loading;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_rec_gps);
btn = (Button) findViewById(R.id.btn);
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
recGps();
}
});
}
private void recGps() {
loading = ProgressDialog.show(this, "Please wait ......", "fetching....", false, false);
String url = Config.URL_CARD_INFO;
StringRequest stringRequest = new StringRequest(url, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
loading.dismiss();
showJSON(response);
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(RecGPS.this, error.getMessage().toString(), Toast.LENGTH_LONG).show();
}
});
RequestQueue requestQueue = Volley.newRequestQueue(this);
requestQueue.add(stringRequest);
}
private void showJSON(final String response) {
try {
jsonObject = new JSONObject(response);
result = jsonObject.getJSONArray(Config.TAG_JSON_ARRAY);
for (int i=0;i<result.length();i++) {
JSONObject collegeData = result.getJSONObject(i);
user_name=collegeData.getString(Config.TAG_NAME);
latitude = collegeData.getString(Config.TAG_ISSUE_DATE);
longitude = collegeData.getString(Config.TAG_Expiry_DATE);
HashMap<String,String> users = new HashMap<>();
users.put(Config.TAG_NAME,user_name);
users.put(Config.TAG_ISSUE_DATE,latitude);
users.put(Config.TAG_Expiry_DATE,longitude);
list.add(users);
}
} catch (JSONException e) {
e.printStackTrace();
}
SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
.findFragmentById(R.id.map);
mapFragment.getMapAsync(new OnMapReadyCallback() {
@Override
public void onMapReady(GoogleMap googleMap) {
mMap = googleMap;
mMap.getMaxZoomLevel();
for(int i=0;i<result.length();i++) {
mMap.addMarker(new MarkerOptions().position(new LatLng(Double.parseDouble(list.get(i).get(Config.TAG_ISSUE_DATE)), Double.parseDouble(list.get(i).get(Config.TAG_Expiry_DATE)))).icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_GREEN)).title(list.get(i).get(Config.TAG_NAME)));
}
}
});
}
}
兄弟 您的代码非常适合添加标记。我认为您在从 MySql (如 php 或任何其他来源(获取数据时遇到问题。请检查一下。 并且还使用以下方法更新您的代码,以专注于标记。
for (int i = 0; i < result.length(); i++) {
mMap.moveCamera(CameraUpdateFactory.newLatLngZoom(new LatLng(Double.parseDouble(list.get(i).get(Config.TAG_ISSUE_DATE)), Double.parseDouble(list.get(i).get(Config.TAG_Expiry_DATE))),list.size()));
mMap.addMarker(new MarkerOptions().position(new LatLng(Double.parseDouble(list.get(i).get(Config.TAG_ISSUE_DATE)), Double.parseDouble(list.get(i).get(Config.TAG_Expiry_DATE)))).icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_GREEN)).title(list.get(i).get(Config.TAG_NAME)));
}