2012年6月19日火曜日

Google Mapでドラッグ可能なルートを作成する

引用先: Google Maps JavaScript API V3 サービス

DirectionsRenderer で動的に表示されたルートが「ドラッグ可能」である場合、ユーザーは地図上に表示された結果パスをドラッグしてルートを変更できます。レンダラの表示をドラッグ可能にするには、draggable プロパティを true に設定します。

ルートがドラッグ可能になっていると、表示された結果のパス(またはウェイポイント)を選択して、それらのコンポーネントを新しい場所に移動できます。変更後のパスは、DirectionsRenderer によって動的に更新されて表示されます。ドロップすると、暫定的なウェイポイント(白い小さなマーカー)が地図に追加されます。パス セグメントを選択して移動すると、ルートの該当区間が変更されます。一方、ウェイポイント マーカー(始点と終点を含む)を選択して移動すると、そのウェイポイントを通過するルートの区間が変更されます。

ドラッグ可能なルートはクライアント側で変更、表示されるため、表示されているルートをユーザーが変更したときの DirectionsRendererdirections_changed イベントを、必要に応じてモニタおよび処理してください。

次に示すコードは、シドニーからニュー サウス ウェールズの奥地をめぐる旅です。このコードでは、directions_changed イベントをモニタして、旅の全区間の総移動距離を更新しています。

var rendererOptions = {
  draggable: true
};
var directionsDisplay = new google.maps.DirectionsRenderer(rendererOptions);;
var directionsService = new google.maps.DirectionsService();
var map;
var australia = new google.maps.LatLng(-25.274398, 133.775136);

function initialize() {
  var myOptions = {
    zoom: 7,
    mapTypeId: google.maps.MapTypeId.ROADMAP,
    center: australia
  };
  map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
  directionsDisplay.setMap(map);
  directionsDisplay.setPanel(document.getElementById("directionsPanel"));

  google.maps.event.addListener(directionsDisplay, 'directions_changed', function() {
    computeTotalDistance(directionsDisplay.directions);
  });

  calcRoute();
}

function calcRoute() {
  var request = {
    origin: "Sydney, NSW",
    destination: "Sydney, NSW",
    waypoints:[{location: "Bourke, NSW"}, {location: "Broken Hill, NSW"}],
    travelMode: google.maps.TravelMode.DRIVING
  };
  directionsService.route(request, function(response, status) {
    if (status == google.maps.DirectionsStatus.OK) {
      directionsDisplay.setDirections(response);
    }
  });
}

function computeTotalDistance(result) {
  var total = 0;
  var myroute = result.routes[0];
  for (i = 0; i < myroute.legs.length; i++) {
    total += myroute.legs[i].distance.value;
  }
  total = total / 1000.
  document.getElementById("total").innerHTML = total + " km";
}

Total Distance:

2012年6月18日月曜日

Gmailの検索やフィルタで使用できるコマンド(演算子)一覧表

http://gmail.1o4.jp/operators.htmlhttp://gmail.1o4.jp/operators.html

GoogleMapで緯度経度を検索

GeoLocator
http://tools.freeside.sk/geolocator/geolocator.html

Google Maps API V3を利用したブックマークレット、GeoLocator(ジオロケーター)。グーグルマップ上の任意の地点の緯度・経度を簡単に取得することができます。
http://www.blades.co.jp/blog/applications/geolocator/
GeoLocatorを起動

ウィンドウを開く

ポリライン(折れ線)、ポリゴン(多角形)生成



http://rnk.mitelog.jp/oyaji/2011/05/googlemap-api-v-37bb.html

view plaincopy to clipboardprint?
<head> 
<title>Google Map API v3-7</title> 
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false" charset="utf-8"></script> 
<script type="text/javascript"> 
function initialize() { 
    // Google Mapで利用する初期設定用の変数 
    var latlng = new google.maps.LatLng(36.062092, 136.223323); 
    var mapOptions = { 
        zoom: 14, 
        mapTypeId: google.maps.MapTypeId.ROADMAP, 
        center: latlng 
    }; 
    // GoogleMapの生成 
    var map = new google.maps.Map(document.getElementById("map"), mapOptions); 
    // 5個の座標(値は特に意味は無い) 
    var latlngData = [ 
        { lat:"35.6937103543", lng:"139.7192966822 " }, 
        { lat:"36.065487", lng:"136.230723" }, 
        { lat:"36.062456", lng:"136.230704" }, 
        { lat:"36.061456", lng:"136.220904" }, 
        { lat:"36.063794", lng:"136.210064" } 
    ]; 
    // 5個の座標2(値は特に意味は無い) 
    var latlngData2 = [ 
        { lat:"36.057258", lng:"136.220604" }, 
        { lat:"36.055487", lng:"136.230723" }, 
        { lat:"36.052456", lng:"136.230704" }, 
        { lat:"36.051456", lng:"136.220904" }, 
        { lat:"36.053794", lng:"136.210064" } 
    ]; 
    var arrCoords = new Array(); 
    for (i = 0;i < latlngData.length;i++) { 
        // 座標地をlatlng値に変換 
        var latlng = new google.maps.LatLng(latlngData[i].lat, latlngData[i].lng); 
        // latlng値を配列に退避 
        arrCoords.push(latlng); 
    } 
    var arrCoords2 = new Array(); 
    for (i = 0;i < latlngData2.length;i++) { 
        // 座標地をlatlng値に変換 
        var latlng2 = new google.maps.LatLng(latlngData2[i].lat, latlngData2[i].lng); 
        // latlng値を配列に退避 
        arrCoords2.push(latlng2); 
    } 
    // ポリライン(折れ線)を生成し、マップに表示 
    var poly = new google.maps.Polyline({ 
        map: map,              //マップ 
        path: arrCoords,       //ポリラインの座標の列 
        strokeWeight: 5,       //ストローク幅(ピクセル単位) 
        strokeColor: "#f01010",//16進数形式のストロークの色 
        strokeOpacity: 0.5     //ストロークの不透明度(0.0~1.0) 
    }); 
    // ポリゴン(多角形)を生成し、マップに表示 
    var poly2 = new google.maps.Polygon({ 
        map: map,              //マップ 
        paths: arrCoords2,     //閉ループを示す座標列 
        strokeWeight: 5,       //ストローク幅(ピクセル単位) 
        strokeColor: "#f01010",//ストロークの色(16進数形式) 
        strokeOpacity: 0.5,    //ストロークの不透明度 
        fillColor: "#fc4040",  //塗りつぶしの色(16進数形式) 
        fillOpacity: 0.1       //塗りつぶしの不透明度(0.0~1.0) 
    }); 

</script>  
</head>  
<body onload="initialize();"> 
  <div id="map" style="width: 400px; height: 400px;"></div> 
</body>  
</html>