Googlemapカスタマイズ方法(レスポンシブ対応)【JavaScript編】

前回のおさらいGoogleMapをレスポンシブ対応で埋め込む【API Key取得編】
今回はGooglemapカスタマイズ方法【JavaScript編】です。
それでは早速…

HTML

<head> </head> <body onload="initialize();"> <div id="map_custmomize"></div> <script type="text/javascript"> (function(w,d,s){ var f=d.getElementsByTagName(s)[0],j=d.createElement(s); j.async=true;j.src='//dmp.im-apps.net/js/7262/0001/itm.js'; f.parentNode.insertBefore(j, f); })(window,document,'script'); </script> <script type="text/javascript" src="http://t.seesaa.net/analytics-seesaa-net.js?v=20150901&tid=UA-53911882-1&page_id=embellir-design%2Farticle%2F445416463&page_info=::41::92&page_words="></script></body>
もしくは、下記コード
<head> </head> <body> <div id="map_custmomize"></div> <script>initialize();</script> </body>
<script>initialize();</script>
を</body>内に記載してください。

CSS

#map_custmomize { width: 100%; height: 415px; } /*画面幅480px以下の設定 ---------------------------------------------------------------------------*/ @media (max-width:480px){ #map_custmomize { width: 100%; height: 250px; margin-bottom: 20px; } }

JavaScript

function initialize() { var latlng = new google.maps.LatLng(33.57667, 130.41457);/*表示したい場所の経度、緯度*/ var myOptions = { zoom: 18, /*拡大比率*/ center: latlng, /*表示枠内の中心点*/ scrollwheel: false, mapTypeControlOptions: { mapTypeIds: ['noText', google.maps.MapTypeId.ROADMAP] }/*表示タイプの指定*/ }; var map = new google.maps.Map(document.getElementById('map_custmomize'), myOptions);/*マップのID取得*/ /*スタイルのカスタマイズ*/ var styleOptions = [ { "featureType":"administrative.province", "elementType":"geometry.fill", "stylers":[ { "visibility": "off" } ] } , { "featureType":"administrative.locality", "elementType":"geometry.fill", "stylers":[ { "visibility": "on" } ] } , { "featureType":"landscape.man_made", "elementType":"geometry.fill", "stylers":[ { "visibility": "on" } , { "color": "#ffe4e4" } ] } , { "featureType":"landscape.natural", "elementType":"geometry.fill", "stylers":[ { "visibility": "on" } , { "color": "#ffd5db" } ] } , { "featureType":"poi", "elementType":"geometry.fill", "stylers":[ { "visibility": "on" } , { "color": "#bddcff" } ] } , { "featureType":"road", "elementType":"geometry", "stylers":[ { "lightness": 100 } , { "visibility": "simplified" } ] } , { "featureType":"road", "elementType":"labels", "stylers":[ { "visibility": "off" } ] } , { "featureType":"transit.line", "elementType":"geometry", "stylers":[ { "visibility": "on" } , { "lightness": 700 } ] } , { "featureType":"water", "elementType":"all", "stylers":[ { "color": "#eef5fd" } ] } ]; var styledMapOptions = { name: 'Embellir Design' } var sampleType = new google.maps.StyledMapType(styleOptions, styledMapOptions); map.mapTypes.set('sample', sampleType); map.setMapTypeId('sample'); /*アイコンの取得*/ var icon = new google.maps.MarkerImage('../images/map-logo.png',/*アイコンの場所*/ new google.maps.Size(50,60),/*アイコンのサイズ*/ new google.maps.Point(0,0)/*アイコンの位置*/ ); /*マーカーの設置*/ var markerOptions = { position: latlng,/*表示場所と同じ位置に設置*/ map: map, icon: icon, title: 'Embellir Design'/*マーカーのtitle*/ }; var marker = new google.maps.Marker(markerOptions); google.maps.event.addListener(marker, 'click', function() { infowindow.open(map,marker); }); google.maps.event.addDomListener(window, "resize", function() { var center = map.getCenter(); google.maps.event.trigger(map, "resize"); map.setCenter(center); }); }

Embellir DesignでのGooglemapカスタマイズをご紹介しました。
当マップはスクロールで拡大されないように設定されています。

もう少し詳しくご紹介します\(^o^)/

マーカーがクリックされたら情報ウィンドウを表示

google.maps.event.addListener(marker, 'click', function() { infowindow.open(map,marker); });

レスポンシブ対応にするために


下記コードを記載すればピンの位置をスマホでも地図の中心に配置する事ができます。

リサイズしたときセンタリングする処理を実装

google.maps.event.addDomListener(window, "resize", function() { var center = map.getCenter(); google.maps.event.trigger(map, "resize"); map.setCenter(center); });

以上となります。
マップのデザインを変えたい方は
Googlemapギャラリーサイト「Snazzy Maps」
コチラから好みのデザインを選んでコピペしたら

/*スタイルのカスタマイズ*/ var styleOptions = より下のコードを変更してください。

※注意※
;(セミコロン)は記載さていないので忘れずに記載してください。

以上です。
それではまた(^_^)/~


この記事へのコメント


この記事へのトラックバック