質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CoffeeScript

CoffeeScriptはプログラミング言語です。シンタックスシュガーの導入により、JavaScriptのコードに変換された後動作します。JavaScriptに比べ、可読性と簡潔性が向上しています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Google マップ

Google Mapは、Google社がオンラインで提供している地図・ローカル検索サービスです。GIS(Geographic Information System:地理情報システム)の中の「WebGIS」に該当します。地図・航空写真・地形の表示方式があり、それぞれユーザーが縮尺を調整して表示させることができます。地域の情報サービスを検索する機能やルート検索の機能も搭載されています。

Q&A

解決済

1回答

3189閲覧

kmlを読み込むと、地図の中心が勝手にkmlになる

muro

総合スコア99

CoffeeScript

CoffeeScriptはプログラミング言語です。シンタックスシュガーの導入により、JavaScriptのコードに変換された後動作します。JavaScriptに比べ、可読性と簡潔性が向上しています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Google マップ

Google Mapは、Google社がオンラインで提供している地図・ローカル検索サービスです。GIS(Geographic Information System:地理情報システム)の中の「WebGIS」に該当します。地図・航空写真・地形の表示方式があり、それぞれユーザーが縮尺を調整して表示させることができます。地域の情報サービスを検索する機能やルート検索の機能も搭載されています。

0グッド

0クリップ

投稿2015/08/05 10:18

Google Maps JavaScript API V3についての質問です。

googlemap上の、特定の都道府県の塗りつぶしを行うkmlファイルを二つ読み込んだあと、その二つの県が画面内に収まる位置まで、自動的にズームを行う処理を作成しようと思っています。
なお、今回の例として、塗りつぶしを行う県は大阪と東京とし、kmlファイルは下記のサイトのものを使用しています。
Google Maps and Street View (グーグルマップ&ストリートビュー) API 例文辞典

完成イメージ
↑完成イメージ

これを実現するために、以下のようなコードを作成しました。

html

1<div class="googlemap"> 2 <!-- ここにgooglemapを出力 --> 3</div>

css

1.googlemap { 2 width: 640px; 3 height: 480px; 4}

coffeescript

1$ -> 2 $googlemap = $(".googlemap").get(0) 3 $show_map = new google.maps.Map($googlemap) 4 $areas = ["osaka", "tokyo"] 5 $.each $areas, ($i, $area) -> 6 $kml_url = "http://example.com/" 7 $kml_url += $area + ".kml" 8 $ctaLayer = new google.maps.KmlLayer 9 url: $kml_url 10 map: $show_map 11 $sw = new google.maps.LatLng(35.051324354627674, 135.09346961975098) 12 $ne = new google.maps.LatLng(35.89857594497401 ,138.9428472518921) 13 $latlngBounds = new google.maps.LatLngBounds($sw, $ne) 14 $show_map.fitBounds($latlngBounds)

javascript

1// coffeescriptの変換結果 2$(function() { 3 var $areas, $googlemap, $latlngBounds, $ne, $show_map, $sw; 4 $googlemap = $(".googlemap").get(0); 5 $show_map = new google.maps.Map($googlemap); 6 $areas = ["osaka", "tokyo"]; 7 $.each($areas, function($i, $area) { 8 var $ctaLayer, $kml_url; 9 $kml_url = "http://example.com/"; 10 $kml_url += $area + ".kml"; 11 return $ctaLayer = new google.maps.KmlLayer({ 12 url: $kml_url, 13 map: $show_map 14 }); 15 }); 16 $sw = new google.maps.LatLng(35.051324354627674, 135.09346961975098); 17 $ne = new google.maps.LatLng(35.89857594497401, 138.9428472518921); 18 $latlngBounds = new google.maps.LatLngBounds($sw, $ne); 19 return $show_map.fitBounds($latlngBounds); 20});

実際の結果
しかし、上記のコードを実際に実行すると、kmlによって塗りつぶしが行われた、どちらかの県だけを中心にズームされた地図になってしまいます。
しかも、どの県がズームになるかは、ページを読み込む度に変化します。
上記の写真の場合は東京がズームになっていますが、大阪になる場合もあります。

fitBoundsによって、2点の座標が収まるように画面を調整するはずであり、kmlの読み込みを行ったあとで実行しているのにも関わらず、kml読み込みの処理が存在していると、fitBoundsが無視されてしまいます。

どうすれば、kml読み込み後の勝手に中心を変えてしまう処理を止められるのでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

KmlLayerのコンストラクタでpreserveViewporttrueを設定することで指定した範囲全体を表示することができます。
KmlLayerOptions

preserveViewport
Type: boolean
By default, the input map is centered and zoomed to the bounding box of the contents of the layer. If this option is set to true, the viewport is left unchanged, unless the map's center and zoom were never set.

投稿2015/08/06 02:07

sho_cs

総合スコア3541

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

muro

2015/08/06 02:37

ありがとうございます。解決いたしました。 たった一行で解決するとは思わなかったです。 日本語の解説サイトもありました。↓ http://waox.main.jp/news/?p=2125
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問