0

我要计算距离和时间以下的情况下,如何使用距离矩阵或其他Google API计算多个位置的距离和持续时间?

Start Point : A 
      A to 1(via)(2 km)(2 min) 
      A to 2(via)(5 km)(7 min) 
      A to 3(via)(8 km)(13 min) 
      A to B(16 km)(22 min) 
End Point : B 

因为这样我通过距离矩阵,那么谷歌地图返回两点之间的最短建立路径获取路径。

但我不想最短,我想通过计算。

请告诉我提示或正确的方法。

+0

有谷歌地图API第2版。它以JSON格式返回名称,距离和时间的路径。使用折线将其绘制在地图上 –

+0

我如何找到特定的位置距离和持续时间 – Rgv

+0

您可能需要在Google的API文档中进行一点挖掘。你是什​​么意思*计算通过*?详细说明这可能。 –

回答

0
public class DirectionsJSONParser { 

    /** 
    * Receives a JSONObject and returns a list of lists containing latitude and longitude 
    */ 
    public List<List<HashMap<String, String>>> parse(JSONObject jObject) { 

     List<List<HashMap<String, String>>> routes = new ArrayList<List<HashMap<String, String>>>(); 
     JSONArray jRoutes = null; 
     JSONArray jLegs = null; 
     JSONArray jSteps = null; 
     String jdist; 

     try { 

      jRoutes = jObject.optJSONArray("routes"); 

      /** Traversing all routes */ 
      for (int i = 0; i < jRoutes.length(); i++) { 
       jLegs = ((JSONObject) jRoutes.get(i)).getJSONArray("legs"); 

这会给你所有的路径在这里。检查日志的完整JSON

   Log.d("TAGTAG2", jLegs.getJSONObject(0).toString()); 

   Final_maps.distance = Math.ceil(jLegs.getJSONObject(0).getJSONObject("distance").optInt("value")); 
       List path = new ArrayList<HashMap<String, String>>(); 

       /** Traversing all legs */ 
       for (int j = 0; j < jLegs.length(); j++) { 
        jSteps = ((JSONObject) jLegs.get(j)).getJSONArray("steps"); 

        /** Traversing all steps */ 
        for (int k = 0; k < jSteps.length(); k++) { 
         String polyline = ""; 
         polyline = (String) ((JSONObject) ((JSONObject) jSteps.get(k)).get("polyline")).get("points"); 
         List<LatLng> list = decodePoly(polyline); 

         /** Traversing all points */ 
         for (int l = 0; l < list.size(); l++) { 
          HashMap<String, String> hm = new HashMap<String, String>(); 
          hm.put("lat", Double.toString(((LatLng) list.get(l)).latitude)); 
          hm.put("lng", Double.toString(((LatLng) list.get(l)).longitude)); 
          path.add(hm); 
         } 
        } 
        routes.add(path); 
       } 
      } 

     } catch (JSONException e) { 
      e.printStackTrace(); 
     } catch (Exception e) { 
     } 

     return routes; 
    } 

    /** 
    * Method to decode polyline points 
    * Courtesy : http://jeffreysambells.com/2010/05/27/decoding-polylines-from-google-maps-direction-api-with-java 
    */ 
    private List<LatLng> decodePoly(String encoded) { 

     List<LatLng> poly = new ArrayList<LatLng>(); 
     int index = 0, len = encoded.length(); 
     int lat = 0, lng = 0; 

     while (index < len) { 
      int b, shift = 0, result = 0; 
      do { 
       b = encoded.charAt(index++) - 63; 
       result |= (b & 0x1f) << shift; 
       shift += 5; 
      } while (b >= 0x20); 
      int dlat = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1)); 
      lat += dlat; 

      shift = 0; 
      result = 0; 
      do { 
       b = encoded.charAt(index++) - 63; 
       result |= (b & 0x1f) << shift; 
       shift += 5; 
      } while (b >= 0x20); 
      int dlng = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1)); 
      lng += dlng; 

      LatLng p = new LatLng((((double) lat/1E5)), 
        (((double) lng/1E5))); 
      poly.add(p); 
     } 

     return poly; 
    } 
} 
+0

是这个距离矩阵api或方向api – Rgv

+0

这是我得到的JSON响应。 {“distance”:{“text”:“4.0 km”,“value”:3950},“duration”:{“text”:“14分钟”,“value”:832},“end_address”:“。 ........... –

+0

在JSON结尾处还有一个**“via_waypoint”:[] **检查google文档以获得解决方案。 –