2017-08-11 55 views
0

我正在使用谷歌地图api。在我的情况下,我通过php从MySQL接收纬度,经度和用户名。我在一次收到所有用户。我尝试下面的代码,它只给出一个marker.Plz指导我。不把它复制,因为我尝试了许多解决方案,但不工作的me.If u有没有答案,请quit.Please Rec.class使用Maps API和获取来自Mysql的坐标不能获得多个标记。为什么?

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))); 

       } 

      } 
     }); 
    } 
} 
+0

我知道看到downvote或重复的伤害,但请避免像** quit **这样的词。 –

回答

0

兄弟你的代码是用于添加标记完全正确的。我认为你在从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))); 

      } 
+0

谢谢你我知道了。你说得对,我在php代码中遇到了问题 –

相关问题