지도 영역 내의 '은행' 카테고리에 해당하는 장소를 검색하고 검색결과를 지도 위에 마커로 표시합니다. 마커를 클릭하면 인포윈도우에 장소명을 표시합니다.
카테고리 코드목록을 보시려면 여기를 클릭하세요!
// 마커를 클릭하면 장소명을 표출할 인포윈도우 입니다 var infowindow = new kakao.maps.InfoWindow({zIndex:1}); var mapContainer = document.getElementById('map'), // 지도를 표시할 div mapOption = { center: new kakao.maps.LatLng(37.566826, 126.9786567), // 지도의 중심좌표 level: 3 // 지도의 확대 레벨 }; // 지도를 생성합니다 var map = new kakao.maps.Map(mapContainer, mapOption); // 장소 검색 객체를 생성합니다 var ps = new kakao.maps.services.Places(map); // 카테고리로 은행을 검색합니다 ps.categorySearch('BK9', placesSearchCB, {useMapBounds:true}); // 키워드 검색 완료 시 호출되는 콜백함수 입니다 function placesSearchCB (data, status, pagination) { if (status === kakao.maps.services.Status.OK) { for (var i=0; i<data.length; i++) { displayMarker(data[i]); } } } // 지도에 마커를 표시하는 함수입니다 function displayMarker(place) { // 마커를 생성하고 지도에 표시합니다 var marker = new kakao.maps.Marker({ map: map, position: new kakao.maps.LatLng(place.y, place.x) }); // 마커에 클릭이벤트를 등록합니다 kakao.maps.event.addListener(marker, 'click', function() { // 마커를 클릭하면 장소명이 인포윈도우에 표출됩니다 infowindow.setContent('<div style="padding:5px;font-size:12px;">' + place.place_name + '</div>'); infowindow.open(map, marker); }); }
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>카테고리로 장소 검색하기</title> </head> <body> <p style="margin-top:-12px"> <em class="link"> <a href="/web/documentation/#CategoryCode" target="_blank">카테고리 코드목록을 보시려면 여기를 클릭하세요!</a> </em> </p> <div id="map" style="width:100%;height:350px;"></div> <script type="text/javascript" src="//dapi.kakao.com/v2/maps/sdk.js?appkey=발급받은 APP KEY를 사용하세요&libraries=services"></script> <script> // 마커를 클릭하면 장소명을 표출할 인포윈도우 입니다 var infowindow = new kakao.maps.InfoWindow({zIndex:1}); var mapContainer = document.getElementById('map'), // 지도를 표시할 div mapOption = { center: new kakao.maps.LatLng(37.566826, 126.9786567), // 지도의 중심좌표 level: 3 // 지도의 확대 레벨 }; // 지도를 생성합니다 var map = new kakao.maps.Map(mapContainer, mapOption); // 장소 검색 객체를 생성합니다 var ps = new kakao.maps.services.Places(map); // 카테고리로 은행을 검색합니다 ps.categorySearch('BK9', placesSearchCB, {useMapBounds:true}); // 키워드 검색 완료 시 호출되는 콜백함수 입니다 function placesSearchCB (data, status, pagination) { if (status === kakao.maps.services.Status.OK) { for (var i=0; i<data.length; i++) { displayMarker(data[i]); } } } // 지도에 마커를 표시하는 함수입니다 function displayMarker(place) { // 마커를 생성하고 지도에 표시합니다 var marker = new kakao.maps.Marker({ map: map, position: new kakao.maps.LatLng(place.y, place.x) }); // 마커에 클릭이벤트를 등록합니다 kakao.maps.event.addListener(marker, 'click', function() { // 마커를 클릭하면 장소명이 인포윈도우에 표출됩니다 infowindow.setContent('<div style="padding:5px;font-size:12px;">' + place.place_name + '</div>'); infowindow.open(map, marker); }); } </script> </body> </html>