0

Google Maps APIを使用して、複数のルートからの運転距離を取得しています。各ルートは異なるドライバーによって使用されています。それらはすべて同じ開始点を持ちますが、異なる端点を持ち、複数のウェイポイントを持っている可能性があります。

私が抱えている問題は、APIが各ルートに名前を付ける方法を提供していないように見えるため、非同期で戻ってきたときに、どのルートがどのドライバーに属しているのかわからないことです。各ルートのアドレスが異なるのは事実ですが、DirectionsService応答オブジェクトは、送信したアドレスとは少し異なるアドレスを返します。たとえば、「Des Plaines、IL」は「DesPlaines、IL、USA」になり、比較の信頼性が低くなります。それらの。

APIでは、リクエストオブジェクトを使用して任意の文字列を送信し、一意の名前を付けることができないようです。それで、なにかお手伝いできますか?

私がしていることを明確にするのに役立つかもしれないコードスニペット:

$.getJSON(ajaxsource, function(data) {
    var darr = data.driver_info, // includes driver name, start and end addresses
        driver, start, end,
        waypts = [];
    for (var i=0,j=darr.length; i<j; i++) {
        if (driver==$.trim(darr[i][8])) { // same driver, next destination
            //  start = end;
            waypts.push({
                location: end,
                stopover: true });
        } else {
            waypts = [];
            driver = $.trim(darr[i][8]);
            start = $.trim(darr[i][4]);
        }
        end = $.trim(darr[i][2]);

        if (i+1==j || driver!=$.trim(darr[i+1][8])) { 
            var request = { // route object
                origin: start,
                destination: end,
                waypoints: waypts,
                optimizeWaypoints: true,
                travelMode: google.maps.DirectionsTravelMode.DRIVING
            };
            directionsDisplay = new google.maps.DirectionsRenderer();
            directionsService.route(request, function(response, status) {
                var legs = response.routes[0].legs;
                // console.log(response);
                for (var k=0; k<legs.length; k++) {
                    $('#results').append($('<li>').html("Driver " + driver + 
                        "<br>starts at " + legs[k].start_address + 
                        "<br>and drives " + legs[k].distance.text + 
                        "<br>to end at " + legs[k].end_address));
                }
            });
        };

    }; // end for
}); // end getJSON

そのコードは必要に応じてすべてのルート情報を返しますが、非同期であるため、各結果のinは私の配列driverにリストされている最後のドライバーの名前です。data.driver_info私が必要としているのは、その特定のルートに関連付けられるべきドライバーをリストすることです。

4

2 に答える 2

2

ループ内でを設定しvar loc_driver = driver;て、ループに対してローカルにすることができるようにしてからfor、「グローバル」(少なくとも呼び出し全体に対して)値に依存するのではなく、コールバックでその値を使用しますgetJSON

directionServiceへのコールバックには、forループと全体からのスコープ内変数がありますfunction(data){ ... }

問題はdriver、forループのパスごとに変化し、コールバックがその「グローバル」を使用することdriverです。代わりに、各forループのスコープ内にのみ存在する変数を設定し、コールバックがその変数に依存している場合、問題は解決しました。

編集:いくつかの参照と値の問題があるかもしれないので、どこか便利な場所で宣言するのはどうですか?

callbackFactory = function(driver) {
   return function(request, status) {
     var legs = response.routes[0].legs;
     console.log(response);
     for (var k=0; k<legs.length; k++) {
        $('#results').append($('<li>').html("Driver " + driver +
             "<br>starts at " + legs[k].start_address + 
             "<br>and drives " + legs[k].distance.text + 
             "<br>to end at " + legs[k].end_address));
     }
   };
};

次に、制御構造で:

directionsService.route(request, callbackFactory(driver));
于 2012-09-19T15:26:04.267 に答える
0

もう少しデバッグすると解決策が明らかになりました。Googleのドキュメントには、オブジェクトにステータスとルートだけでなく、送信したリクエストオブジェクトをミラーリングするresponseというサブオブジェクトも含まれているとは記載されていませんでした。ubこれを使用して、住所を正確に比較して、ルートをドライバーに一致させることができます。

Object
    routes: Array[1]
    status: "OK"
    ub: Object
        destination: "1234 Some Street, Antioch, IL"
        optimizeWaypoints: true
        origin: "2345 Anywhere Ave., Lake Forest, IL"
        travelMode: "DRIVING"
        waypoints: Array[0]
        __proto__: Object
    __proto__: Object

directionsService.route()コールバック内に次のコードを追加しました。

var driver = '',
    end_ub = response.ub.destination;
for (var a=0,b=darr.length; a<b; a++) {
    if (darr[a][2]==end_ub) {
        driver = darr[a][8];
        break;
    };
};
于 2012-09-19T15:34:31.183 に答える