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文檔以獲得解決方案。 –