14

車を追跡し、地図上に移動経路のポリラインを描画するアプリがあります。ルート案内サービスのルーティングを使用して、このポリラインをルートに変換したいと考えています。これにより、パスをドラッグして操作できるようになります。

問題は、これに対する適切な解決策が思いつかないことです。また、それが可能かどうかもわかりません。ポリラインの座標の配列をルート案内サービス ルートに渡すと、ポリラインの始点と終点のみを使用してルートが描画され、その間の座標は考慮されません。

ポリライン座標配列を使用して「ウェイポイント」配列を均等に分割し、その間に8つの座標を取得してそれらをウェイポイントとして渡すことで、「ウェイポイント」配列を生成しようとしましたが、今はまったくレンダリングできません。ルートを描画することによって生成された座標配列を使用してコードをテストすると、機能するので、コードが機能していることがわかります。これらの座標の一部が道路からわずかに外れている可能性があるため (これは GPS 測位から描画されたポリラインであるため、100% 正確ではありません)、Google はそれを最も近い受け入れ可能な場所にスナップするだけではないため、失敗したと推測しています。

誰でもこれに対する解決策を考えることができますか?

少しわかりやすくするためのコード例を次に示します。

// In the polyline app
var encoded_path = google.maps.geometry.encoding.encodePath(coordinate_array)



// In the route app
var coordinates = google.maps.geometry.encoding.decodePath(encoded_path);

var waypoints = [];

// Evenly get coordinates across the entire array to be used as waypoints
for (var i = 1; i <= 8; ++i) {
   var index = Math.floor((coordinates.length/10) * i);

   if (index >= coordinates.length - 1)
      break;

   waypoints.push({
      'location': new google.maps.LatLng(coordinates[index].lat(), coordinates[index].lng()),
      'stopover': false
   });
}

var request = {
   origin: coordinates[0],
   destination: coordinates[coordinates.length - 1],
   travelMode: google.maps.DirectionsTravelMode.DRIVING,
   waypoints: waypoints
};

MapService.directionsService.route(request, function(response, status) {
   if (status == google.maps.DirectionsStatus.OK) {
      MapService.directionsDisplay.setDirections(response);
   }
});
4

3 に答える 3

2

しばらく経ちましたが、Roads API というより良い答えがあります: https://developers.google.com/maps/documentation/roads/intro

Directions API は、このユース ケースを意図したものではありません。試してはならない理由がいくつかあります。

  • ストップオーバー (デフォルト) であるウェイポイントは、前/次のウェイポイントに関係なく、最寄りの道路にスナップするときに、移動の方向 (内外) を許可します。

  • 途中降機ではない (via:) ウェイポイントは、道路にスナップするときに非常に厳密になります。典型的な GPS オフセットはそれを無視し、ZERO_RESULTS (ルートなし) を引き起こします-

  • すべてのウェイポイントがうまく機能したとしても、ルートは一般的なドライバーにとって最適なルートであり、ウェイポイントとして使用される位置をサンプリングした車両がたどるルートとは限りません。

  • 車両が異なる高度 (高架道路、橋、トンネルなど) にある 2 つの道路の交差点で位置をサンプリングする場合、GPS オフセットによってポイントが間違った道路にあると、ルーティングが大幅に外れることがあります。

于 2016-06-16T18:32:41.243 に答える
0

方向 API を使用して、道路で終了するときのウェイポイントを確認できます: Map of all points below a certain time of travel? . 次に、他のものを削除して、ポリライン全体からルートを作成します。

于 2013-10-30T19:07:56.757 に答える
-1
public String makeURL (double sourcelat, double sourcelog, double destlat, double destlog ){
    StringBuilder urlString = new StringBuilder();
    urlString.append("http://maps.googleapis.com/maps/api/directions/json");
    urlString.append("?origin=");// from
    urlString.append(Double.toString(sourcelat));
    urlString.append(",");
    urlString
            .append(Double.toString( sourcelog));
    urlString.append("&destination=");// to
    urlString
            .append(Double.toString( destlat));
    urlString.append(",");
    urlString.append(Double.toString( destlog));
    urlString.append("&sensor=false&mode=driving");
    return urlString.toString();

}

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


public class JSONParser {

    InputStream is = null;
    JSONObject jObj = null;
    String json = "";
    // constructor
    public JSONParser() {
    }
    public String getJSONFromUrl(String url) {

        // Making HTTP request
        try {
            // defaultHttpClient
            DefaultHttpClient httpClient = new DefaultHttpClient();
            HttpPost httpPost = new HttpPost(url);

            HttpResponse httpResponse = httpClient.execute(httpPost);
            HttpEntity httpEntity = httpResponse.getEntity();
            is = httpEntity.getContent();           

        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        } catch (ClientProtocolException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        try {
            BufferedReader reader = new BufferedReader(new InputStreamReader(
                    is, "iso-8859-1"), 8);
            StringBuilder sb = new StringBuilder();
            String line = null;
            while ((line = reader.readLine()) != null) {
                sb.append(line + "\n");
            }

            json = sb.toString();
            is.close();
        } catch (Exception e) {
            Log.e("Buffer Error", "Error converting result " + e.toString());
        }
        return json;

    }
}

public void drawPath(String  result) {

    try {
            //Tranform the string into a json object
           final JSONObject json = new JSONObject(result);
           JSONArray routeArray = json.getJSONArray("routes");
           JSONObject routes = routeArray.getJSONObject(0);
           JSONObject overviewPolylines = routes.getJSONObject("overview_polyline");
           String encodedString = overviewPolylines.getString("points");
           List<LatLng> list = decodePoly(encodedString);

           for(int z = 0; z<list.size()-1;z++){
                LatLng src= list.get(z);
                LatLng dest= list.get(z+1);
                theMap.addPolyline(new PolylineOptions()
                .add(src,dest)
                .width(2)
                .color(Color.BLUE).geodesic(true));
            }

    } 
    catch (JSONException e) {

    }
} 


private class connectAsyncTask extends AsyncTask<Void, Void, String>{
        private ProgressDialog progressDialog;
        String url;
        connectAsyncTask(String urlPass){
            url = urlPass;

        }
        @Override
        protected void onPreExecute() {
            // TODO Auto-generated method stub
            super.onPreExecute();
            progressDialog = new ProgressDialog(YOUR_Activity.this);
            progressDialog.setMessage("Fetching route, Please wait...");
            progressDialog.setIndeterminate(true);
            progressDialog.show();
        }
        @Override
        protected String doInBackground(Void... params) {
            JSONParser jParser = new JSONParser();
            String json = jParser.getJSONFromUrl(url);
            return json;
        }
        @Override
        protected void onPostExecute(String result) {
            super.onPostExecute(result);   
            progressDialog.hide();        
            if(result!=null){
                drawPath(result);
            }
        }
    }
于 2014-04-25T01:41:18.457 に答える