지도 객체
Constructor kakao.maps.Map(container, options) 지도를 생성한다.지도 생성하기 샘플보기
var container = document . getElementById ( 'map' ),
options = {
center : new kakao . maps . LatLng ( 33.450701 , 126.570667 ),
level : 3
};
var map = new kakao . maps . Map ( container , options );
Parameters container
Node : 지도가 표시될 HTML elementoptions
Object center
LatLng : 중심 좌표 (필수)level
Number : 확대 수준 (기본값: 3)mapTypeId
MapTypeId : 지도 종류 (기본값: 일반 지도)draggable
Boolean : 마우스 드래그, 휠, 모바일 터치를 이용한 시점 변경(이동, 확대, 축소) 가능 여부scrollwheel
Boolean : 마우스 휠, 모바일 터치를 이용한 확대 및 축소 가능 여부disableDoubleClick
Boolean : 더블클릭 이벤트 및 더블클릭 확대 가능 여부disableDoubleClickZoom
Boolean : 더블클릭 확대 가능 여부projectionId
String : 투영법 지정 (기본값: kakao.maps.ProjectionId.WCONG )tileAnimation
Boolean : 지도 타일 애니메이션 설정 여부 (기본값: true)keyboardShortcuts
Boolean | Object : 키보드의 방향키와 +, – 키로 지도 이동,확대,축소 가능 여부 (기본값: false)Methods setCenter(latlng) 지도의 중심 좌표를 설정한다.지도 이동시키기 샘플보기
map . setCenter ( new kakao . maps . LatLng ( 37.537183 , 127.005454 ));
Parameters getCenter() 지도의 중심 좌표를 반환한다.지도 정보 얻어오기 샘플보기
var position = map . getCenter ();
Returns setLevel(level, options) 지도의 확대 수준을 설정한다.MapTypeId 의 종류에 따라 설정 범위가 다르다.SKYVIEW , HYBRID 일 경우 0 ~ 14, ROADMAP 일 경우 1 ~ 14.지도 레벨바꾸기 샘플보기
// 지도 레벨을 4로 설정한다
map . setLevel ( 4 );
// 지도 레벨을 4로 설정하고 특정 좌표를 기준으로 확대 또는 축소되도록 한다
map . setLevel ( 4 , { anchor : new kakao . maps . LatLng ( 33.450705 , 126.570677 )});
// setLevel 시 애니메이션 효과 옵션 설정, 기본지속시간은 300ms이다
map . setLevel ( 4 , { animate : true });
// setLevel 시 애니메이션 효과의 지속시간을 500ms로 설정
map . setLevel ( 4 , {
animate : {
duration : 500
}
});
Parameters level
Number options
Object animate
Boolean | Object : 지도 확대수준 변경 시 애니메이션 효과 여부 (현재 지도 레벨과의 차이가 2 이하인 경우에만 애니메이션 효과 가능)duration
Number : 애니메이션 효과 지속 시간 (단위: ms)anchor
LatLng : 지도 확대수준 변경 시 기준 좌표getLevel() 지도의 확대 수준을 반환한다.지도 정보 얻어오기 샘플보기
var level = map . getLevel ();
Returns setMapTypeId(mapTypeId) 지도의 타입을 설정한다.지도 타입 바꾸기1 샘플보기 지도 타입 바꾸기2 샘플보기
map . setMapTypeId ( kakao . maps . MapTypeId . HYBRID );
Parameters getMapTypeId() 지도의 타입을 반환한다.지도 정보 얻어오기 샘플보기
map . getMapTypeId (); // kakao.maps.MapTypeId.ROADMAP
Returns setBounds(bounds[, paddingTop, paddingRight, paddingBottom, paddingLeft]) 주어진 영역이 화면 안에 전부 나타날 수 있도록 지도의 중심 좌표와 확대 수준을 설정한다. 주어진 영역외에 추가로 padding값을 지정할 수 있다. 2번째 파라메터부터 top, right, bottom, left값이며 파라메터를 1개 이상 지정한 경우 지정하지 않은 파라메터에 대해서는 CSS의 padding rule을 따른다. (ex. paddingTop:100, paddingRight:50 을 지정한 경우. top, right, bottom, left 순서로 100 50 100 50) padding값을 지정하지 않으면 기본값으로 상하좌우 32가 적용된다.지도 범위 재설정 하기 샘플보기
map . setBounds ( bounds );
Parameters bounds
LatLngBounds paddingTop
Number paddingRight
Number paddingBottom
Number paddingLeft
Number getBounds() 지도의 영역을 반환한다.지도 정보 얻어오기 샘플보기
var bounds = map . getBounds ();
bounds . toString (); // "((33.44843745687413, 126.56798357402302), (33.452964008206735, 126.57333898904454))"
Returns setMinLevel(minLevel) 지도의 최저 레벨 값을 설정한다. 기본적으로 레벨 값이 작을수록 지도는 확대되는데 이 함수로 설정한 레벨까지만 확대할 수 있게 된다.
map . setMinLevel ( 3 );
Parameters setMaxLevel(maxLevel) 지도의 최고 레벨 값을 설정한다. 기본적으로 레벨 값이 클수록 지도는 축소되는데 이 함수로 설정한 레벨까지만 축소할 수 있게 된다.
map . setMaxLevel ( 10 );
Parameters panBy(dx, dy) 중심 좌표를 지정한 픽셀 만큼 부드럽게 이동한다. 만약 이동할 거리가 지도 화면의 크기보다 클 경우 애니메이션 없이 이동한다.
map . panBy ( 100 , 50 );
Parameters panTo(latlng_or_bounds[, padding]) 중심 좌표를 지정한 좌표 또는 영역으로 부드럽게 이동한다. 필요하면 확대 또는 축소도 수행한다. 만약 이동할 거리가 지도 화면의 크기보다 클 경우 애니메이션 없이 이동한다. 첫 번째 매개변수로 좌표나 영역을 지정할 수 있으며, 영역(bounds)을 지정한 경우에만 padding 옵션이 유효하다. padding 값을 지정하면 그 값만큼의 상하좌우 픽셀이 확보된 영역으로 계산되어 이동한다. padding의 기본값은 32.지도 이동시키기 샘플보기
var moveLatLng = new kakao . maps . LatLng ( 33.450580 , 126.574942 );
map . panTo ( moveLatLng );
Parameters addControl(control, position) 지도에 컨트롤을 추가한다.지도에 컨트롤 올리기 샘플보기
var control = new kakao . maps . ZoomControl ();
map . addControl ( control , kakao . maps . ControlPosition . TOPRIGHT );
Parameters removeControl(control) 지도에서 컨트롤을 제거한다.
map . removeControl ( control , kakao . maps . ControlPosition . TOPRIGHT );
Parameters setDraggable(draggable) 마우스 드래그와 모바일 터치를 이용한 지도 이동 가능 여부를 설정한다.지도 이동 막기 샘플보기
map . setDraggable ( false );
Parameters getDraggable() 마우스 드래그와 모바일 터치를 이용한 지도 이동 가능 여부를 반환한다.
// 지도가 드래그로 이동이 가능한 상태면 true, 아니면 false를 반환한다.
map . getDraggable ();
Returns setZoomable(zoomable) 마우스 휠과 모바일 터치를 이용한 지도 확대, 축소 가능 여부를 설정한다. 지도 객체 함수 호출을 통한 확대, 축소는 동작한다.지도 확대 축소 막기 샘플보기
// 지도의 마우스 휠, 모바일 터치를 이용한 확대, 축소 기능을 막는다.
map . setZoomable ( false );
// 지도 객체 함수 호출을 통한 확대, 축소는 동작한다.
map . setLevel ( 3 );
Parameters getZoomable() 마우스 휠과 모바일 터치를 이용한 지도 확대, 축소 가능 여부를 반환한다.
// 지도가 마우스 휠과 모바일 터치를 이용해 확대, 축소가 가능한 상태이면 true, 아니면 false를 반환한다.
map . getZoomable ();
Returns setProjectionId(projectionId) 지도의 projectionId를 지정한다. 이 메소드로 API 내부의 좌표계의 투영 방법을 설정할 수 있다. 기본값은 kakao.maps.ProjectionId.WCONG
// API 내부의 좌표게가 특정 투영법을 사용하지 않도록 할 경우.
map . setProjectionId ( kakao . maps . ProjectionId . NONE );
Parameters getProjectionId() 지도의 projectionId를 반환한다.
map . getProjectionId ();
Returns relayout() 지도를 표시하는 HTML elemente의 크기를 변경한 후에는 반드시 이 함수를 호출해야 한다. 단, window의 resize 이벤트에 대해서는 자동으로 호출한다.지도 영역 크기 동적 변경하기 샘플보기
var container = document . getElementById ( 'map' ),
options = {
center : new kakao . maps . LatLng ( 33.450701 , 126.570667 ),
level : 3
};
var map = new kakao . maps . Map ( container , options );
container . style . width = '1200px' ;
container . style . height = '800px' ;
map . relayout ();
addOverlayMapTypeId(mapTypeId) 지도에 로드뷰, 교통정보 등의 오버레이 타입의 타일 이미지를 올린다. 로드뷰 타일 이미지를 추가할 경우 RoadviewOverlay 와 동일한 기능을 수행한다.지도에 교통정보 표시하기 샘플보기 지도에 로드뷰 도로 표시하기 샘플보기 지도에 지형도 표시하기 샘플보기
map . addOverlayMapTypeId ( kakao . maps . MapTypeId . TRAFFIC );
Parameters removeOverlayMapTypeId(mapTypeId) 지도에 로드뷰, 교통정보 등의 오버레이 타입의 타일 이미지를 삭제한다.
map . removeOverlayMapTypeId ( kakao . maps . MapTypeId . TRAFFIC );
Parameters setKeyboardShortcuts(active) 키보드의 방향키와 +,-키로 지도 이동,확대,축소 가능여부를 설정한다.
// 키보드로 지도를 조작할 수 없도록 설정한다
map . setKeyboardShortcuts ( false );
Parameters getKeyboardShortcuts() 키보드의 방향키와 +,-키로 지도 이동,확대,축소 가능여부를 반환한다.
// true를 반환하면 현재 지도를 키보드로 조작할 수 있는 상태이다
map . getKeyboardShortcuts ();
Returns setCopyrightPosition(copyrightPosition[, reversed]) copyright의 위치를 설정한다
// copyright의 위치를 오른쪽 아래로 설정하고, 로고와의 위치를 반전시킨다
// 실행 결과는 아래 이미지와 같다
map . setCopyrightPosition ( kakao . maps . CopyrightPosition . BOTTOMRIGHT , true );
Parameters getProjection() 지도의 좌표 변환 객체를 반환한다.
var proj = map . getProjection ();
Returns setCursor(style) 지도 위에 마우스 커서가 위치할 경우 보여지는 커서의 스타일을 지정한다.
// 커서 스타일을 'move'로 변경한다.
map . setCursor ( 'move' );
// URL 형태로도 설정 가능하다.
map . setCursor ( 'url(/cursor.ico), default' :
Parameters Events center_changed 중심 좌표가 변경되면 발생한다.중심좌표 변경 이벤트 등록하기 샘플보기
kakao . maps . event . addListener ( map , 'center_changed' , function () {
alert ( 'center changed!' );
});
zoom_start 확대 수준이 변경되기 직전 발생한다.
kakao . maps . event . addListener ( map , 'zoom_start' , function () {
alert ( 'Map is going to zoom!' );
});
zoom_changed 확대 수준이 변경되면 발생한다.확대, 축소 이벤트 등록하기 샘플보기
kakao . maps . event . addListener ( map , 'zoom_changed' , function () {
alert ( 'zoom changed!' );
});
bounds_changed 지도 영역이 변경되면 발생한다.영역 변경 이벤트 등록하기 샘플보기
kakao . maps . event . addListener ( map , 'bounds_changed' , function () {
alert ( 'bounds changed!' );
});
click 지도를 클릭하면 발생한다.클릭 이벤트 등록하기 샘플보기 클릭한 위치에 마커 표시하기 샘플보기
kakao . maps . event . addListener ( map , 'click' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
alert ( 'click! ' + latlng . toString ());
});
Arguments dblclick 지도를 더블클릭하면 발생한다.
kakao . maps . event . addListener ( map , 'dblclick' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
alert ( 'double click! ' + latlng . toString ());
});
Arguments rightclick 지도를 마우스 오른쪽 버튼으로 클릭하면 발생한다.
kakao . maps . event . addListener ( map , 'rightclick' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
alert ( 'right click! ' + latlng . toString ());
});
Arguments mousemove 지도에서 마우스 커서를 이동하면 발생한다.
kakao . maps . event . addListener ( map , 'mousemove' , function ( mouseEvent ) {
// do something
});
Arguments dragstart 드래그를 시작할 때 발생한다.
kakao . maps . event . addListener ( map , 'dragstart' , function () {
// do something
});
drag 드래그를 하는 동안 발생한다.
kakao . maps . event . addListener ( map , 'drag' , function () {
// do something
});
dragend 드래그가 끝날 때 발생한다.
kakao . maps . event . addListener ( map , 'dragend' , function () {
// do something
});
idle 중심 좌표나 확대 수준이 변경되면 발생한다. 단, 애니메이션 도중에는 발생하지 않는다.
kakao . maps . event . addListener ( map , 'idle' , function () {
// do something
});
tilesloaded 확대수준이 변경되거나 지도가 이동했을때 타일 이미지 로드가 모두 완료되면 발생한다. 지도이동이 미세하기 일어나 타일 이미지 로드가 일어나지 않은경우 발생하지 않는다.타일로드 이벤트 등록하기 샘플보기
kakao . maps . event . addListener ( map , 'tilesloaded' , function () {
// do something
});
maptypeid_changed 지도 기본 타일(일반지도, 스카이뷰, 하이브리드)이 변경되면 발생한다.
kakao . maps . event . addListener ( map , 'maptypeid_changed' , function () {
// do something
});
MapTypeControl
일반 지도/하이브리드 간 지도 타입 전환 컨트롤을 생성한다.Map 객체의 addControl 또는 removeControl 메소드의 인자로 사용된다. 현재는 일반 지도/하이브리드 간 전환 컨트롤만 지원되며 다른 지도 타입을 제어하는 컨트롤이 필요할 경우에는 직접 구현해야 한다. 지도에 컨트롤 올리기 샘플보기
Constructor kakao.maps.MapTypeControl() var mapTypeControl = new kakao . maps . MapTypeControl ();
// 지도 오른쪽 위에 지도 타입 컨트롤이 표시되도록 지도에 컨트롤을 추가한다.
map . addControl ( mapTypeControl , kakao . maps . ControlPosition . TOPRIGHT );
ZoomControl
주어진 객체로 확대·축소 컨트롤을 생성한다.Map 객체의 addControl 또는 removeControl 메소드의 인자로 사용된다.지도에 컨트롤 올리기 샘플보기
Constructor kakao.maps.ZoomControl() // 아래와 같이 옵션을 입력하지 않아도 된다
var zoomControl = new kakao . maps . ZoomControl ();
// 지도 오른쪽에 줌 컨트롤이 표시되도록 지도에 컨트롤을 추가한다.
map . addControl ( zoomControl , kakao . maps . ControlPosition . RIGHT );
MapTypeId kakao.maps.MapTypeId 객체
Constants kakao.maps.MapTypeId.MAP_TYPE_ID
지도의 타입이 상수 값으로 정의되어 있다.MAP_TYPE_ID
값으로 사용 가능한 목록은 다음과 같다.
ROADMAP
: 일반 지도SKYVIEW
: 스카이뷰HYBRID
: 하이브리드(스카이뷰 + 레이블)ROADVIEW
: 로드뷰OVERLAY
: 레이블TRAFFIC
: 교통정보TERRAIN
: 지형도BICYCLE
: 자전거BICYCLE_HYBRID
: 스카이뷰를 위한 자전거 (어두운 지도에서 활용)USE_DISTRICT
: 지적편집도지도의 타입은 용도에 따라 두 가지로 분류한다.
베이스 타입 : ROADMAP
SKYVIEW
HYBRID
오버레이 타입 : OVERLAY
TERRAIN
TRAFFIC
BICYCLE
BICYCLE_HYBRID
USE_DISTRICT
기본 타일은 베이스 타입 을 사용한다.Map.setMapTypeId 함수를 통해 지정 가능하다.
기본 타일 위에 얹는 타일은 오버레이 타입 을 사용한다.Map.addOverlayMapTypeId 함수를 통해 지정한 타일을 지도 위에 올릴 수 있다.
그리고 Map.removeOverlayMapTypeId 함수로 언제든 올렸던 오버레이 타일을 걷어낼 수도 있다.
지적편집도 오버레이 타입은 현행 지적 정보와 일치하지 않을 수 있으며 참고 이외의 용도로 사용하실 수 없습니다.
지도 타입 바꾸기1 샘플보기 지도 타입 바꾸기2 샘플보기
ProjectionId kakao.maps.ProjectionId 객체
Constants kakao.maps.ProjectionId.PROJECTION_ID
지도의 projectionId 값이 상수 값으로 정의되어 있다.PROJECTION_ID
값으로 사용 가능한 목록은 다음과 같다.
NONE
: 투영 없는 API 내부의 좌표계 자체. left-bottom을 (0,0)으로 하는 픽셀단위의 좌표계.WCONG
: API 내부 좌표계를 WCongnamul좌표계로 투영. 외부에서 WCongnamul 좌표를 받아 사용가능.ControlPosition kakao.maps.ControlPosition 객체
Contstants kakao.maps.ControlPosition.CONTROL_POSITION
컨트롤 위치가 상수 값으로 정의되어 있다.CONTROL_POSITION
값으로 사용 가능한 목록은 다음과 같다.
TOP
: 위 가운데를 의미한다. 아래로 쌓인다.TOPLEFT
: 왼쪽 위를 의미한다. 오른쪽으로 쌓인다.TOPRIGHT
: 오른쪽 위를 의미한다. 왼쪽으로 쌓인다.LEFT
: 왼쪽 위를 의미한다. 아래로 쌓인다. (주의: 왼쪽 중앙을 의미하는 것이 아니다.)RIGHT
: 오른쪽 위를 의미한다. 아래로 쌓인다. (주의: 오른쪽 중앙을 의미하는 것이 아니다.)BOTTOMLEFT
: 왼쪽 아래를 의미한다. 오른쪽으로 쌓인다.BOTTOM
: 아래 가운데를 의미한다. 위로 쌓인다.BOTTOMRIGHT
: 오른쪽 아래를 의미한다. 왼쪽으로 쌓인다.다음과 같이 접근한다.kakao . maps . ControlPosition . TOPLEFT ;
지도 컨트롤 올리기 샘플보기
CopyrightPosition kakao.maps.CopyrightPosition 객체
Contstants kakao.maps.CopyrightPosition.COPYRIGHT_POSITION
copyright의 위치가 상수값으로 정의되어 있다.COPYRIGHT_POSITION
값으로 사용 가능한 목록은 다음과 같다.
BOTTOMLEFT
: 왼쪽 아래를 의미한다.BOTTOMRIGHT
: 오른쪽 아래를 의미한다.다음과 같이 접근한다.kakao . maps . CopyrightPosition . BOTTOMRIGHT ;
주어진 객체로 타일셋을 생성한다.커스텀 타일셋1 샘플보기 커스텀 타일셋2 샘플보기
Constructor kakao.maps.Tileset(width, height, urlFunc, copyright, dark, minZoom, maxZoom)
var tileset =
new kakao . maps . Tileset ( 256 , 256 , function ( x , y , z ) {
/**
* x: column
* y: row
* z: level
**/
// 세 parameter를 조합하여 타일 주소를 조합/반환한다.
return 'http://return.tile.image.url/' + z + '/' + y + '/' + x + '.png' ;
}, [], false , 2 , 5 );
Parameters width
Number : 타일의 가로 크기height
Number : 타일의 세로 크기urlFunc
Function : 타일 주소를 반환하는 함수. 세 개의 파라메터를 가진다.copyright
Array.<TilesetCopyright> : 생성할 타일의 카피라이트(기본값: [])dark
Boolean : 어두운 타일인지 여부minZoom
Number : 최소 레벨maxZoom
Number : 최대 레벨getTile
Function : 타일 Element를 반환하는 함수. 세개의 파라미터를 가진다. urlFunc 옵션 대신 사용한다.Static Methods add(id, tileset) 타일셋에 ID를 지정해 추가한다. 추가되면 kakao.maps.[지정한ID] 로 타일셋을 사용할 수 있다.
Parameters id
String : 지정할 타일셋의 IDtileset
Tileset : 생성한 Tileset 객체
kakao . maps . Tileset . add ( 'SAMPLE' , tileset ); // kakao.maps.MapTypeId.SAMPLE
var map = kakao . maps . Map ( container , options );
map . setMapTypeId ( kakao . maps . MapTypeId . SAMPLE );
TilesetCopyright 주어진 객체로 타일셋 카피라이트를 생성한다.
Constructor kakao.maps.TilesetCopyright(msg, shortMsg, minZoom) var copyright = new kakao . maps . TilesetCopyright ( 'Nasa' , 'Nasa' , 9 );
Parameters msg
String : 기본적으로 출력되는 카피라이트shortMsg
String : 지도 영역이 작아졌을 때 출력되는 짧은 카피라이트minZoom
Number : 해당 카피라이트가 노출될 최소 줌 레벨(기본값: 0)Wcongnamul 좌표 정보를 가지고 있는 객체를 생성한다.
Constructor kakao.maps.Coords(x, y) var coords = new kakao . maps . Coords ( 400207.5 , - 11710 );
Parameters x
Number : x 좌표y
Number : y 좌표Methods getX() x 좌표를 반환한다.
var coords = new kakao . maps . Coords ( 400207.5 , - 11710 );
coords . getX (); // 400207.5
Returns getY() y 좌표를 반환한다.
var coords = new kakao . maps . Coords ( 400207.5 , - 11710 );
coords . getY (); // -11710
Returns equals(coords) 객체가 가지고 있는 좌표와 같은 좌표를 가지고 있는 객체인지 비교한다.
var coords = new kakao . maps . Coords ( 400207.5 , - 11710 ),
coords1 = new kakao . maps . Coords ( 400207.5 , - 11710 ),
coords2 = new kakao . maps . Coords ( 400207 , 11710 );
coords . equals ( coords1 ); // true
coords . equals ( coords2 ); // false
Parameters Returns toString() 객체가 가지고 있는 좌표를 문자열로 반환한다.
var coords = new kakao . maps . Coords ( 400207.5 , - 11710 );
coords . toString (); // (400207.5, -11710)
Returns toLatLng() 객체가 가지고 있는 좌표를 WGS84 좌표로 반환한다.var coords = new kakao . maps . Coords ( 400207.5 , - 11710 );
coords . toLatLng (). toString (); // (33.45067375096625, 126.5706721005115)
Returns WGS84 좌표 정보를 가지고 있는 객체를 생성한다.
Constructor kakao.maps.LatLng(latitude, longitude) var latlng = new kakao . maps . LatLng ( 37 , 127 );
Parameters latitude
Number : 위도longitude
Number : 경도Methods getLat() 위도를 반환한다.
var latlng = new kakao . maps . LatLng ( 37 , 127 );
latlng . getLat (); // 37
Returns getLng() 경도를 반환한다.
var latlng = new kakao . maps . LatLng ( 37 , 127 );
latlng . getLng (); // 127
Returns equals(latlng) 객체가 가지고 있는 좌표와 같은 좌표를 가지고 있는 객체인지 비교한다.
var latlng = new kakao . maps . LatLng ( 37.1 , 127.1 ),
latlng1 = new kakao . maps . LatLng ( 37.1 , 127.1 ),
latlng2 = new kakao . maps . LatLng ( 37.2 , 127.2 );
latlng . equals ( latlng1 ); // true
latlng . equals ( latlng2 ); // false
Parameters Returns toString() 객체가 가지고 있는 좌표를 문자열로 반환한다.
var latlng = new kakao . maps . LatLng ( 37 , 127 );
latlng . toString (); // "(37, 127)"
Returns toCoords() 객체가 가지고 있는 좌표를 Wcongnamul 좌표로 반환한다.
var latlng = new kakao . maps . LatLng ( 37 , 127 );
latlng . toCoords (). toString (); // "(500000, 972532.3892234056)"
Returns WGS84 좌표계에서 사각영역 정보를 표현하는 객체를 생성한다.지도 범위 재설정 하기 샘플보기
Constructor kakao.maps.LatLngBounds(sw, ne) var sw = new kakao . maps . LatLng ( 36 , 127 ),
ne = new kakao . maps . LatLng ( 37 , 128 );
var bounds = new kakao . maps . LatLngBounds ( sw , ne ); // 인자를 주지 않으면 빈 영역을 생성한다.
Parameters Methods equals(latlngBounds) 객체가 가지고 있는 영역 정보와 같은 영역 정보를 가지고 있는 객체인지 비교한다.
var sw = new kakao . maps . LatLng ( 36 , 127 ),
ne = new kakao . maps . LatLng ( 37 , 128 ),
lb = new kakao . maps . LatLngBounds ( sw , ne ),
lb1 = new kakao . maps . LatLngBounds ( sw , ne ),
lb2 = new kakao . maps . LatLngBounds ();
lb . equals ( lb1 ); // true
lb . equals ( lb2 ); // false
Parameters Returns toString() 객체가 가지고 있는 영역 정보를 문자열로 반환한다.
var sw = new kakao . maps . LatLng ( 36 , 127 ),
ne = new kakao . maps . LatLng ( 37 , 128 ),
lb = new kakao . maps . LatLngBounds ( sw , ne );
lb . toString (); // "((36, 127), (37, 128))"
Returns getSouthWest() 영역의 남서쪽 좌표를 반환한다.
var sw = new kakao . maps . LatLng ( 36 , 127 ),
ne = new kakao . maps . LatLng ( 37 , 128 ),
lb = new kakao . maps . LatLngBounds ( sw , ne );
lb . getSouthWest (). toString (); // "(36, 127)"
Returns getNorthEast() 영역의 북동쪽 좌표를 반환한다.
var sw = new kakao . maps . LatLng ( 36 , 127 ),
ne = new kakao . maps . LatLng ( 37 , 128 ),
lb = new kakao . maps . LatLngBounds ( sw , ne );
lb . getNorthEast (). toString (); // "(37, 128)"
Returns isEmpty() 영역 정보가 비어있는지 확인한다.
var sw = new kakao . maps . LatLng ( 36 , 127 ),
ne = new kakao . maps . LatLng ( 37 , 128 ),
lb1 = new kakao . maps . LatLngBounds ( sw , ne );
lb2 = new kakao . maps . LatLngBounds ();
lb1 . isEmpty (); // false
lb2 . isEmpty (); // true
Returns extend(latlng) 인수로 주어진 좌표를 포함하도록 영역 정보를 확장한다.
var sw = new kakao . maps . LatLng ( 36 , 127 ),
ne = new kakao . maps . LatLng ( 37 , 128 ),
lb = new kakao . maps . LatLngBounds ( sw , ne ),
extraLatLng = new kakao . maps . LatLng ( 36.5 , 128.5 );
lb . toString (); // "((36, 127), (37, 128))"
lb . extend ( extraLatLng );
lb . toString (); // "((36, 127), (37, 128.5))"
Parameters contain(latlng) 영역 객체가 인수로 주어진 좌표를 포함하는지 확인한다.
var sw = new kakao . maps . LatLng ( 36 , 127 ),
ne = new kakao . maps . LatLng ( 37 , 128 ),
lb = new kakao . maps . LatLngBounds ( sw , ne ),
l1 = new kakao . maps . LatLng ( 36.5 , 127.5 ),
l2 = new kakao . maps . LatLng ( 37 , 128 );
lb . contain ( l1 ); // true
lb . contain ( l2 ); // false
Parameters Returns 화면 좌표(픽셀 단위) 정보를 담고 있는 객체
Constructor kakao.maps.Point(x, y) 화면 좌표 정보를 담고 있는 포인트 객체를 생성한다.
var point = new kakao . maps . Point ( 12 , 34 );
Parameters Methods equals(point) 포인트 객체와 같은 좌표를 가지고 있는 객체인지 비교한다.
var p = new kakao . maps . Point ( 1 , 1 ),
p1 = new kakao . maps . Point ( 1 , 1 ),
p2 = new kakao . maps . Point ( 2 , 2 );
p . equals ( p1 ); // true
p . equals ( p2 ); // false
Parameters Returns toString() 포인트 객체가 가지고 있는 좌표를 문자열로 반환한다.
var p = new kakao . maps . Point ( 480 , 960 );
p . toString (); // "(480, 960)"
Returns 크기 정보(픽셀 단위)를 담고 있는 객체
Constructor kakao.maps.Size(width, height) 크기 정보를 담고 있는 사이즈 객체를 생성한다.
var size = new kakao . maps . Size ( 56 , 78 );
Parameters width
Number height
Number Methods equals(size) 사이즈 객체가 가지고 있는 크기와 같은 크기를 가지고 있는 객체인지 비교한다.
var s = new kakao . maps . Size ( 1 , 1 ),
s1 = new kakao . maps . Size ( 1 , 1 ),
s2 = new kakao . maps . Size ( 2 , 2 );
s . equals ( s1 ); // true
s . equals ( s2 ); // false
Parameters Returns toString() 사이즈 객체가 가지고 있는 크기를 문자열로 반환한다.
var s = new kakao . maps . Size ( 480 , 960 );
s . toString (); // "(480, 960)"
Returns 지도 객체의 이벤트 관련 함수를 담은 네임스페이스
Static Methods addListener(target, type, handler) 다음 지도 API 객체에 이벤트를 등록한다.
kakao . maps . event . addListener ( map , 'idle' , function () {
alert ( 'nothing to do' );
});
Parameters target
EventTarget : 이벤트를 지원하는 다음 지도 API 객체type
String : 이벤트 이름handler
Function : 이벤트를 처리할 함수removeListener(target, type, handler) 다음 지도 API 객체에 등록된 이벤트를 제거한다.
var clickHandler = function ( event ) {
alert ( 'click: ' + event . latLng . toString ());
};
kakao . maps . event . addListener ( map , 'click' , clickHandler );
kakao . maps . event . removeListener ( map , 'click' , clickHandler );
Parameters target
EventTarget : 이벤트를 지원하는 다음 지도 API 객체type
String : 이벤트 이름handler
Function : 이벤트를 처리하던 함수trigger(target, type, data) 다음 지도 API 객체에 등록된 이벤트를 발생시킨다.
// 마커 객체에 사용자 이벤트를 등록한다
kakao . maps . event . addListener ( marker , 'custom_action' , function ( data ){
console . log ( data + '가 발생했습니다.' );
});
// 마커 객체에 등록한 사용자 이벤트를 발생시킨다
kakao . maps . event . trigger ( marker , 'custom_action' , '사용자 이벤트' ); // 사용자 이벤트가 발생했습니다.
Parameters target
EventTarget : 이벤트를 지원하는 다음 지도 API 객체type
String : 이벤트 이름data
* : 이벤트를 처리하는 함수에 넘길 변수preventMap() 다음 Map 객체의 이벤트를 막는다. 보통 CustomOverlay의 content 혹은 외부 Element의 이벤트 핸들러에서 지도의 이벤트를 막고 싶을 경우 사용한다. 이벤트의 핸들러 내부에서 이 함수를 사용하며, 이벤트의 핸들링이 끝나면 Map 객체의 이벤트는 다시 정상 동작하게 된다.
kakao . maps . event . preventMap ();
MouseEvent 마우스 이벤트로 넘겨 받는 인자 직접 생성할 수는 없으며 이벤트 핸들러에서 내부적으로 생성된 객체를 parameter로 받아 사용한다.
Properties latLng 지도 좌표
kakao . maps . event . addListener ( map , 'click' , function ( mouseEvent ) {
alert ( mouseEvent . latLng instanceof kakao . maps . LatLng ); // true
});
Type point 화면 좌표
kakao . maps . event . addListener ( map , 'click' , function ( event ) {
alert ( event . point instanceof kakao . maps . Point ); // true
});
Type Constructor kakao.maps.Marker(options) 주어진 객체로 마커를 생성한다. 지도 뿐만 아니라 로드뷰 위에도 올릴 수 있다.마커 생성하기 샘플보기 로드뷰에 마커와 인포윈도우 올리기 샘플보기 마커의 고도와 반경 조절하기 샘플보기
var marker = new kakao . maps . Marker ({
map : map ,
position : new kakao . maps . LatLng ( 33.450701 , 126.570667 )
});
Parameters options
Object map
Map | Roadview : 마커가 올라갈 지도 또는 로드뷰position
LatLng | Viewpoint : 마커의 좌표 또는 로드뷰에서의 시점image
MarkerImage : 마커의 이미지title
String : 마커 엘리먼트의 타이틀 속성 값 (툴팁)draggable
Boolean : 드래그 가능한 마커, 로드뷰에 올릴 경우에는 유효하지 않다clickable
Boolean : 클릭 가능한 마커zIndex
Number : 마커 엘리먼트의 z-index 속성 값opacity
Number : 마커 투명도 (0-1)altitude
Number : 로드뷰에 올라있는 마커의 높이 값(m 단위)range
Number : 로드뷰 상에서 마커의 가시반경(m 단위), 두 지점 사이의 거리가 지정한 값보다 멀어지면 마커는 로드뷰에서 보이지 않게 된다Methods setMap(map_or_roadview) 지도 또는 로드뷰에 마커를 올린다. null 을 지정하면 마커를 제거한다.마커 생성하기 샘플보기 여러개 마커 제어하기 샘플보기
marker . setMap ( map ); // 지도에 올린다.
marker . setMap ( null ); // 지도에서 제거한다.
marker . setMap ( roadview ); // 로드뷰에 올린다.
Parameters getMap() 마커가 올라가있는 지도를 반환한다.
marker . getMap ();
Returns setImage(image) 마커에 새 MarkerImage를 지정한다.다른 이미지로 마커 생성하기 샘플보기
var markerImage = new kakao . maps . MarkerImage (
'https://i1.daumcdn.net/dmaps/apis/nlocalblit04.png' ,
new kakao . maps . Size ( 31 , 35 ), new kakao . maps . Point ( 13 , 34 ));
marker . setImage ( markerImage );
Parameters getImage() 마커의 MarkerImage를 반환한다.
marker . getImage (); // 지정했던 MarkerImage의 인스턴스를 리턴한다.
Returns setPosition(position) 마커의 좌표를 지정한다. 로드뷰의 특정 시점에 고정하기 위해서 Viewpoint 객체를 사용할 수도 있다. panoId를 지정한 Viewpoint 를 사용하면 panoId에 해당하는 로드뷰 위치에서만 보이게 된다.
// 지도 혹은 로드뷰에서 마커의 위치를 지정
marker . setPosition ( new kakao . maps . LatLng ( 33.450701 , 126.570667 ));
// 로드뷰에서 특정 시점에 고정된 마커의 위치를 지정
marker . setPosition ( new kakao . maps . Viewpoint ( 30 , - 10 ));
// 로드뷰에서 특정 시점 및 특정 panoId에서만 보이도록 고정된 마커의 위치를 지정
marker . setPosition ( new kakao . maps . Viewpoint ( 30 , - 10 , 0 , 1033283653 ));
Parameters getPosition() 마커의 좌표를 반환한다.
marker . getPosition ();
Returns setZIndex(zIndex) 마커의 z-index를 설정한다.
marker . setZIndex ( 3 );
Parameters getZIndex() 마커의 z-index를 반환한다.
var marker = new kakao . maps . Marker ({
zIndex : 4
});
marker . getZIndex (); // 4
Returns setVisible(visible) 마커의 표시 여부를 지정한다.
marker . setVisible ( false ); // 마커를 숨긴다.
Parameters getVisible() 마커의 표시 여부를 반환한다.
marker . setVisible ( true );
marker . getVisible (); // true
Returns setTitle(title) 마커의 툴팁을 설정한다.
marker . setTitle ( '타이틀' );
Parameters getTitle() 마커의 툴팁을 반환한다.
var marker = new kakao . maps . Marker ({
title : "마커 타이틀을 획득하셨습니다."
});
marker . getTitle (); // "마커 타이틀을 획득하셨습니다."
Returns setDraggable(draggable) 드래그 가능 여부를 지정한다. 로드뷰에 올라가 있을 경우에는 마커의 드래그 기능을 비활성화 되기 때문에 지도에 올라가 있을 경우에만 의미가 있다.
marker . setDraggable ( true ); // 드래그 가능하도록 설정
Parameters getDraggable() 드래그 가능 여부를 반환한다.
marker . getDraggable ();
Returns setClickable(clickable) 클릭 가능 여부를 지정한다. true 로 지정하게 되면 마커를 클릭 했을 때, 지도의 클릭 이벤트가 발생하지 않도록 막아준다.
marker . setClickable ( true );
Parameters getClickable() 클릭 가능 여부를 반환한다.
marker . getClickable ();
Returns setAltitude(altitude) 로드뷰상에서 마커의 높이(위치)를 지정한다. 단위는 m(미터)이며 현재 로드뷰의 바닥 높이를 기준으로 떨어져있는 높이를 말한다.
marker . setAltitude ( 10 );
Parameters 현재 보고있는 시점이 지면으로부터 약 1.7m 떨어져 있다고 가정하고 지면의 높이값을 0으로 계산한다. 때문에 높이값이 정확하지 않을 수 있다. 또한 로드뷰를 찍은 위치의 정보(해발 고도, 기울어짐)는 고려하지 않기 때문에 마커가 찍힌 위치가 어색하거나 부정확할 수 있다. 보통은 2층 이상에 존재하는 장소를 로드뷰에 대략적으로 표시하기 위해서 사용한다.
getAltitude() 마커의 높이(위치)를 반환한다. 단위는 m(미터).
var marker = new kakao . maps . Marker ({
altitude : 10
});
marker . getAltitude (); // 10
Returns setRange(range) 마커의 가시반경을 설정한다. 로드뷰의 위치와 마커의 위치 사이의 거리가 가시반경 이내일 경우에만 로드뷰상에 노출된다. 단위는 m(미터)이며 기본값은 500m이다.
marker . setRange ( 300 );
Parameters getRange() 마커의 가시반경을 반환한다. 단위는 m(미터).
var marker = new kakao . maps . Marker ({
range : 300
});
marker . getRange (); // 300
Returns setOpacity(opacity) 마커의 투명도를 설정한다.
marker . setOpacity ( 0.5 );
Parameters getOpacity() 마커의 투명도를 반환한다.
var marker = new kakao . maps . Marker ({
opacity : 0.5
});
marker . getOpacity (); // 0.5
Returns Events click 마커를 클릭하면 발생한다.마커에 클릭 이벤트 등록하기 샘플보기
kakao . maps . event . addListener ( marker , 'click' , function () {
alert ( 'marker click!' );
});
mouseover 마커에 마우스 커서를 올리면 발생한다.마커에 마우스 이벤트 등록하기 샘플보기
kakao . maps . event . addListener ( marker , 'mouseover' , function () {
alert ( 'marker mouseover!' );
});
mouseout 마우스 커서가 마커에서 벗어나면 발생한다.마커에 마우스 이벤트 등록하기 샘플보기
kakao . maps . event . addListener ( marker , 'mouseout' , function () {
alert ( 'marker mouseout!' );
});
rightclick 마커를 오른쪽 버튼으로 클릭하면 발생한다.
kakao . maps . event . addListener ( marker , 'rightclick' , function () {
alert ( 'marker rightclick!' );
});
dragstart 드래그를 시작하면 발생한다.draggable 마커 이벤트 적용하기 샘플보기
kakao . maps . event . addListener ( marker , 'dragstart' , function () {
alert ( 'marker dragstart!' );
});
dragend 드래그를 종료하면 발생한다.draggable 마커 이벤트 적용하기 샘플보기
kakao . maps . event . addListener ( marker , 'dragend' , function () {
alert ( 'marker dragend!' );
});
MarkerImage 기본 마커가 아닌, 별도의 이미지를 이용하여 마커를 만들기 위한 이미지 생성 객체다른 이미지로 마커 생성하기 샘플보기 다양한 이미지 마커 표시하기 샘플보기
Constructor kakao.maps.MarkerImage(src, size[, options]) 마커에 사용할 이미지를 생성한다. 세 번째 파라메터로 offset을 사용할 경우 네 번째 파라메터로 shape, 다섯 번째 파라메터로 coords를 넣을 수 있다.
// 세 번째 파라메터로 options를 사용.
var icon = new kakao . maps . MarkerImage (
'https://localimg.daum-img.net/localimages/07/2009/map/icon/blog_icon01_on.png' ,
new kakao . maps . Size ( 31 , 35 ),
{
offset : new kakao . maps . Point ( 16 , 34 ),
alt : "마커 이미지 예제" ,
shape : "poly" ,
coords : "1,20,1,9,5,2,10,0,21,0,27,3,30,9,30,20,17,33,14,33"
}
);
/*
아래와 같이 세번째 파라메터부터 순서대로 offset, shape, coords 값을 넣어주는 방식으로도 사용 가능하다.
var icon = new kakao.maps.MarkerImage(
'https://localimg.daum-img.net/localimages/07/2009/map/icon/blog_icon01_on.png',
new kakao.maps.Size(31, 35),
new kakao.maps.Point(16, 34),
"poly",
"1,20,1,9,5,2,10,0,21,0,27,3,30,9,30,20,17,33,14,33"
);
*/
new kakao . maps . Marker ({
position : new kakao . maps . LatLng ( 33.450701 , 126.570667 ),
image : icon
}). setMap ( map );
Parameters src
String : 이미지 주소size
Size : 마커의 크기options
Obejct alt
String : 마커 이미지의 alt 속성값을 정의한다.coords
String : 마커의 클릭 또는 마우스오버 가능한 영역을 표현하는 좌표값offset
Point : 마커의 좌표에 일치시킬 이미지 안의 좌표 (기본값: 이미지의 가운데 아래)shape
String : 마커의 클릭 또는 마우스오버 가능한 영역의 모양spriteOrigin
Point : 스프라이트 이미지 중 사용할 영역의 좌상단 좌표spriteSize
Size : 스프라이트 이미지의 전체 크기옵션으로 지정한 shape와 coords의 값은 각각 실제 HTML에서 <area>의 shape와 coords 속성에 대응한다. 예를 들어 설명하자면 아래와 같다.
아래의 이미지로 MarkerImage를 만들어 보자.
이미지의 크기는 31×35이다. 추가 옵션없이 생성해보자.var icon = new kakao . maps . MarkerImage (
'https://i1.daumcdn.net/dmaps/apis/n_local_blit_04.png' ,
new kakao . maps . Size ( 31 , 35 ));
이렇게 만들어진 MarkerImage의 HTML 마크업을 단순화하면 다음과 같다. // Result
< img width = "31" height = "35" src = "https://i1.daumcdn.net/dmaps/apis/n_local_blit_04.png" alt = "" >
이 MarkerImage로 생성한 Marker에 클릭 이벤트를 등록하면 이미지 크기에 해당하는 영역 전체에서 클릭 이벤트가 발생한다.
다음과 같은 특정 영역에서만 클릭 이벤트가 발생하도록 해 보자.
옵션으로 shape와 coords값을 주어 MarkerImage를 만든다.var icon = new kakao . maps . MarkerImage (
'https://i1.daumcdn.net/dmaps/apis/n_local_blit_04.png' ,
new kakao . maps . Size ( 31 , 35 ),
{
shape : 'poly' ,
coords : '16,0,20,2,24,6,26,10,26,16,23,22,17,25,14,35,13,35,9,25,6,24,2,20,0,16,0,10,2,6,6,2,10,0'
});
위의 코드로 만들어진 HTML 마크업의 대략적인 구조는 다음과 같다. // Result
< img width = "31" height = "35" src = "https://i1.daumcdn.net/dmaps/apis/n_local_blit_04.png" alt = "" usemap = "#Marker" >
< map name = "Marker" >
< area alt = "" shape = "poly" coords = "16,0,20,2,24,6,26,10,26,16,23,22,17,25,14,35,13,35,9,25,6,24,2,20,0,16,0,10,2,6,6,2,10,0" >
</ map >
위와 같이 생성된 Marker는 아래 그림에서 보이는 푸른색 영역에서만 클릭 이벤트가 발생한다.
자세한 내용은 Image Maps 관련 W3C 문서 를 참조한다.
인포윈도우 객체
Constructor kakao.maps.InfoWindow(options) 주어진 객체로 인포윈도우를 생성한다. 지도 뿐만 아니라 로드뷰 위에도 올릴 수 있다.인포윈도우 생성하기 샘플보기 로드뷰에 마커와 인포윈도우 올리기 샘플보기 마커의 고도와 반경 조절하기 샘플보기
var infowindow = new kakao . maps . InfoWindow ({
map : map ,
position : new kakao . maps . LatLng ( 33.450701 , 126.570667 ),
content : 'I am InfoWindow'
});
Parameters options
Object content
Node | String : 엘리먼트 또는 HTML 문자열 형태의 내용disableAutoPan
Boolean : 인포윈도우를 열 때 지도가 자동으로 패닝하지 않을지의 여부 (기본값: false)map
Map | Roadview : 인포윈도우가 올라갈 지도 또는 로드뷰position
LatLng : 인포윈도우의 좌표removable
Boolean : 삭제 가능한 인포윈도우zIndex
Number : 인포윈도우 엘리먼트의 z-index 속성 값altitude
Number : 로드뷰에 올라있는 인포윈도우의 높이 값(m 단위)range
Number : 로드뷰 상에서 인포윈도우의 가시반경(m 단위), 두 지점 사이의 거리가 지정한 값보다 멀어지면 인포윈도우는 보이지 않게 된다Methods open(map_or_roadview [, marker]) 지도에 인포윈도우를 올린다. marker가 주어지면, 해당 마커에서 열린 효과를 낸다. 로드뷰에서도 같은 동작을 한다.마커에 인포윈도우 표시하기 샘플보기
var map = new kakao . maps . Map ( container , options );
var marker = new kakao . maps . Marker ( options );
var infowindow = new kakao . maps . InfoWindow ({
position : new kakao . maps . LatLng ( 33.450701 , 126.570667 ),
content : 'open me plz.'
});
infowindow . open ( map , marker );
Parameters close() 인포윈도우를 제거한다.
infowindow . close ();
getMap() 인포윈도우가 올라가있는 지도를 반환한다.
infowindow . getMap ();
Returns setPosition(position) 인포윈도우의 좌표를 지정한다. 로드뷰의 특정 시점에 고정하기 위해서 Viewpoint 객체를 사용할 수도 있다. panoId를 지정한 Viewpoint 를 사용하면 panoId에 해당하는 로드뷰 위치에서만 보이게 된다.
var position = new kakao . maps . LatLng ( 33.450701 , 126.570667 );
infowindow . setPosition ( position );
Parameters getPosition() 인포윈도우의 좌표를 반환한다.
infowindow . getPosition ();
Returns setContent(content) 인포윈도우의 내용을 지정한다. 엘리먼트 또는 HTML 문자열을 지정할 수 있다.
infowindow . setContent ( 'This is all for you' );
Parameters getContent() 인포윈도우의 내용을 지정했던 형태로 반환한다.
infowindow . getContent (); // "This is all for you"
Returns setZIndex(zIndex) 인포윈도우의 z-index를 설정한다.
infoWindow . setZIndex ( 3 );
Parameters getZIndex() 인포윈도우의 z-index를 반환한다.
var infoWindow = new kakao . maps . InfoWindow ({
zIndex : 4
});
infoWindow . getZIndex (); // 4
Returns setAltitude(altitude) 로드뷰상에서 인포윈도우의 높이(위치)를 지정한다. 단위는 m(미터)이며 현재 로드뷰의 바닥 높이를 기준으로 떨어져있는 높이를 말한다.
infoWindow . setAltitude ( 10 );
Parameters 현재 보고있는 시점이 지면으로부터 약 1.7m 떨어져 있다고 가정하고 지면의 높이값을 0으로 계산한다. 때문에 높이값이 정확하지 않을 수 있다. 또한 로드뷰를 찍은 위치의 정보(해발 고도, 기울어짐)는 고려하지 않기 때문에 인포윈도우가 찍힌 위치가 어색하거나 부정확할 수 있다. 보통은 로드뷰에 보이는 2층 이상의 장소정보를 대략적으로 표시하기 위해서 사용한다.
getAltitude() 인포윈도우의 높이(위치)를 반환한다. 단위는 m(미터).
var infoWindow = new kakao . maps . InfoWindow ({
altitude : 10
});
infoWindow . getAltitude (); // 10
Returns setRange(range) 인포윈도우의 가시반경을 설정한다. 로드뷰의 위치와 인포윈도우의 위치 사이의 거리가 가시반경 이내일 경우에만 로드뷰상에 노출된다. 단위는 m(미터)이며 기본값은 500m이다.
infoWindow . setRange ( 300 );
Parameters getRange() 인포윈도우의 가시반경을 반환한다. 단위는 m(미터).
var infoWindow = new kakao . maps . InfoWindow ({
range : 300
});
infoWindow . getRange (); // 300
Returns 커스텀한 엘리먼트를 담아 지도위에 올릴 수 있는 오버레이 객체.Infowindow 보다는 담을 수 있는 컨텐츠가 자유롭고 AbstractOverlay 보다 사용하기 쉽다는 장점이 있다.
Constructor kakao.maps.CustomOverlay(options) 주어진 객체로 커스텀 오버레이를 생성한다. 지도 뿐만 아니라 로드뷰 위에도 올릴 수 있다.커스텀 오버레이 생성하기1 샘플보기 커스텀 오버레이 생성하기2 샘플보기 로드뷰에 커스텀 오버레이 올리기 샘플보기 로드뷰에 이미지 올리기 샘플보기 커스텀오버레이를 드래그 하기 샘플보기
var customOverlay = new kakao . maps . CustomOverlay ({
map : map ,
clickable : true ,
content : '<div class="customOverlay"><a href="#">Chart</a></div>' ,
position : new kakao . maps . LatLng ( 33.450701 , 126.570667 ),
xAnchor : 0.5 ,
yAnchor : 1 ,
zIndex : 3
});
Parameters options
Object clickable
Boolean : true 로 설정하면 컨텐츠 영역을 클릭했을 경우 지도 이벤트를 막아준다.content
Node | String : 엘리먼트 또는 HTML 문자열 형태의 내용map
Map | Roadview : 커스텀 오버레이가 올라갈 지도 또는 로드뷰position
LatLng | Viewpoint : 커스텀 오버레이의 좌표 또는 로드뷰에서의 시점xAnchor
Number : 컨텐츠의 x축 위치. 0_1 사이의 값을 가진다. 기본값은 0.5yAnchor
Number : 컨텐츠의 y축 위치. 0_1 사이의 값을 가진다. 기본값은 0.5zIndex
Number : 커스텀 오버레이의 z-indexMethods setMap(map_or_roadview) 지도 또는 로드뷰에 커스텀 오버레이를 올린다. null 을 지정하면 오버레이를 제거한다.
customOverlay . setMap ( map ); // 지도에 올린다.
customOverlay . setMap ( null ); // 지도에서 제거한다.
customOverlay . setMap ( roadview ); // 로드뷰에 올린다.
Parameters getMap() 커스텀 오버레이가 올라가있는 지도를 반환한다.
customOverlay . getMap ();
Returns setPosition(position) 커스텀 오버레이의 좌표를 지정한다. 로드뷰의 특정 시점에 고정하기 위해서 Viewpoint 객체를 사용할 수도 있다. panoId를 지정한 Viewpoint 를 사용하면 panoId에 해당하는 로드뷰 위치에서만 보이게 된다.
Parameters getPosition() 커스텀 오버레이의 좌표를 반환한다.
Returns setContent(content) 커스텀 오버레이의 내용을 지정한다. 엘리먼트 또는 HTML 문자열을 지정할 수 있다.
Parameters getContent() 커스텀 오버레이의 내용을 지정했던 형태로 반환한다.
Returns setVisible(visible) 커스텀 오버레이의 표시 여부를 지정한다.
Parameters getVisible() 커스텀 오버레이의 표시 여부를 반환한다.
Returns setZIndex(zIndex) 커스텀 오버레이의 z-index를 설정한다.
Parameters getZIndex() 커스텀 오버레이의 z-index를 반환한다.
Returns setAltitude(altitude) 로드뷰상에서 커스텀 오버레이의 높이(위치)를 지정한다. 단위는 m(미터)이며 현재 로드뷰의 바닥 높이를 기준으로 떨어져있는 높이를 말한다.
customOverlay . setAltitude ( 10 );
Parameters 현재 보고있는 시점이 지면으로부터 약 1.7m 떨어져 있다고 가정하고 지면의 높이값을 0으로 계산한다. 때문에 높이값이 정확하지 않을 수 있다. 또한 로드뷰를 찍은 위치의 정보(해발 고도, 기울어짐)는 고려하지 않기 때문에 커스텀 오버레이가 찍힌 위치가 어색하거나 부정확할 수 있다. 보통은 2층 이상에 존재하는 장소를 로드뷰에 대략적으로 표시하기 위해서 사용한다.
getAltitude() 커스텀 오버레이의 높이(위치)를 반환한다. 단위는 m(미터).
var customOverlay = new kakao . maps . CustomOverlay ({
altitude : 10
});
customOverlay . getAltitude (); // 10
Returns setRange(range) 커스텀 오버레이의 가시반경을 설정한다. 로드뷰의 위치와 커스텀 오버레이의 위치 사이의 거리가 가시반경 이내일 경우에만 로드뷰상에 노출된다. 단위는 m(미터)이며 기본값은 500m이다.
customOverlay . setRange ( 300 );
Parameters getRange() 커스텀 오버레이의 가시반경을 반환한다. 단위는 m(미터).
var customOverlay = new kakao . maps . CustomOverlay ({
range : 300
});
customOverlay . getRange (); // 300
Returns AbstractOverlay Methods Constructor kakao.maps.AbstractOverlay() API 사용자가 직접 정의할 수 있는 오버레이. AbstractOverlay를 상속 받아 사용할 객체를 생성하고 prototype을 연결해 준다. 온전히 동작하는 오버레이를 만들고자 한다면 3가지 인터페이스 메소드( onAdd , draw , onRemove )를 구현해야 한다.지도 영역 밖의 마커위치 추적하기 샘플보기
// 간단한 텍스트를 지도에 올리는 예제
// 생성자에서 엘리먼트를 생성한다.
function SimpleTextMarker ( position , text ) {
this . position = position ;
this . node = document . createElement ( 'div' );
this . node . style . position = 'absolute' ;
this . node . style . whiteSpace = 'nowrap' ;
this . node . appendChild ( document . createTextNode ( text ));
}
// "AbstractOverlay":#AbstractOverlay 상속. 프로토타입 체인을 연결한다..
SimpleTextMarker . prototype = new kakao . maps . AbstractOverlay ;
// 필수 구현 메소드.
// AbstractOverlay의 getPanels() 메소드로 MapPanel 객체를 가져오고
// 거기에서 오버레이 레이어를 얻어 생성자에서 만든 엘리먼트를 자식 노드로 넣어준다.
SimpleTextMarker . prototype . onAdd = function () {
var panel = this . getPanels (). overlayLayer ;
panel . appendChild ( this . node );
};
// 필수 구현 메소드.
// 생성자에서 만든 엘리먼트를 오버레이 레이어에서 제거한다.
SimpleTextMarker . prototype . onRemove = function () {
this . node . parentNode . removeChild ( this . node );
};
// 필수 구현 메소드.
// 지도의 속성 값들이 변화할 때마다 호출된다. (zoom, center, mapType)
// 엘리먼트의 위치를 재조정 해 주어야 한다.
SimpleTextMarker . prototype . draw = function () {
var projection = this . getProjection ();
var point = projection . pointFromCoords ( this . position );
var width = this . node . offsetWidth ;
var height = this . node . offsetHeight ;
this . node . style . left = ( point . x - width / 2 ) + "px" ;
this . node . style . top = ( point . y - height / 2 ) + "px" ;
};
var marker = new SimpleTextMarker ( map . getCenter (), 'You just activated my trap card!' );
marker . setMap ( map );
Methods draw() 위치를 재조정할 필요가 있을 때 호출된다. 이 함수 내에서 엘리먼트의 위치를 잡아주어야 한다.
onAdd() 지도에 올릴 때 호출된다. setMap(map) 을 실행하면 이 함수가 실행된다. 이 함수 내에서 생성된 DOM 객체를 MapPanels에 자식 노드로 넣어주도록 한다.
onRemove() 지도에서 제거할 때 호출된다. setMap(null) 을 실행하면 이 함수가 실행된다. 이 함수 내에서 MapPanels에 자식 노드로 넣어준 엘리먼트를 제거하도록 한다.
setMap(map) 지도에 사용자 오버레이를 올린다. null 을 지정하면 오버레이를 제거한다.
Parameters getMap() 사용자 오버레이가 올라가있는 지도를 반환한다.
Returns getPanels() 붙어있는 지도의 패널을 반환한다.
Returns getProjection() 붙어있는 지도의 좌표 변환 객체를 반환한다.
Returns MapPanels 지도의 패널을 담당하는 객체.
Properties overlayLayer 오버레이를 올릴 수 있는 HTML 엘리먼트
지도와 화면 사이의 좌표 변환을 담당한다. 지도 또는 지도에 올라온 오버레이 객체가 가진 getProjection() 메소드로 얻을 수 있다. 별도의 생성자는 제공하지 않는다.
Methods pointFromCoords(latlng) 지도 좌표에 해당하는 위치 좌표(pixel)를 반환한다. 해당 위치 좌표는 지도 엘리먼트 내부의 레이어 위치를 반영한 좌표이다.지도 영역 밖의 마커위치 추적하기 샘플보기
var mapProjection = map . getProjection (),
latlng = new kakao . maps . LatLng ( 33.450701 , 126.570667 );
mapProjection . pointFromCoords ( latlng ); // 지도 좌표에 해당하는 위치 좌표
Parameters Returns coordsFromPoint(point) 위치 좌표(pixel)에 해당하는 지도 좌표를 반환한다. 해당 위치 좌표는 지도 엘리먼트 내부의 타일 레이어 위치를 반영한 좌표이다.지도 영역 밖의 마커위치 추적하기 샘플보기
var mapProjection = map . getProjection (),
point = new kakao . maps . Point ( 200 , 100 );
mapProjection . coordsFromPoint ( point ); // 위치 좌표에 해당하는 지도 좌표
Parameters Returns containerPointFromCoords(latlng) 지도 좌표에 해당하는 화면 좌표(pixel)를 반환한다. 해당 화면 좌표는 지도 엘리먼트의 좌상단을 기준으로 한 좌표이다.커스텀오버레이를 드래그 하기 샘플보기
var mapProjection = map . getProjection (),
latlng = new kakao . maps . LatLng ( 33.450701 , 126.570667 );
mapProjection . containerPointFromCoords ( latlng ); // 지도 좌표에 해당하는 화면 좌표
Parameters Returns coordsFromContainerPoint(point) 화면 좌표(pixel)에 해당하는 지도 좌표를 반환한다. 해당 화면 좌표는 지도 엘리먼트의 좌상단을 기준으로 한 좌표이다.커스텀오버레이를 드래그 하기 샘플보기
var mapProjection = map . getProjection (),
point = new kakao . maps . Point ( 200 , 100 );
mapProjection . coordsFromContainerPoint ( point ); // 화면 좌표에 해당하는 지도 좌표
Parameters Returns 폴리라인 객체
Constructor kakao.maps.Polyline(options) 주어진 객체로 폴리라인을 생성한다.원, 선, 사각형, 다각형 표시하기 샘플보기
var polyline = new kakao . maps . Polyline ({
map : map ,
path : [
new kakao . maps . LatLng ( 33.452344169439975 , 126.56878163224233 ),
new kakao . maps . LatLng ( 33.452739313807456 , 126.5709308145358 ),
new kakao . maps . LatLng ( 33.45178067090639 , 126.5726886938753 )
],
strokeWeight : 2 ,
strokeColor : '#FF00FF' ,
strokeOpacity : 0.8 ,
strokeStyle : 'dashed'
});
Parameters options
Object endArrow
Boolean : 화살표 여부path
Array.< LatLng > | Array.<Array.< LatLng >> : 폴리라인을 구성하는 좌표의 배열 또는 좌표 배열의 배열strokeWeight
Number : 픽셀 단위의 선 두께 (기본값: 3)strokeColor
String : #xxxxxx 형태의 선 색 (기본값: ‘#F10000’)strokeOpacity
Number : 선 불투명도 (0-1) (기본값: 0.6)strokeStyle
String : 선 스타일 (기본값: ‘solid’)zIndex
Number : 선의 z-index 속성 값Methods setMap(map) 지도에 폴리라인을 올린다. null 을 지정하면 폴리라인을 제거한다.
polyline . setMap ( map ); // 지도에 올린다.
polyline . setMap ( null ); // 지도에서 제거한다.
Parameters getMap() 폴리라인이 올라가있는 지도를 반환한다.
polyline . getMap (); // kakao.maps.Map
Returns setOptions(options) 폴리라인의 옵션을 설정한다.
polyline . setOptions ({
strokeWeight : 2 ,
strokeColor : '#FF00FF' ,
strokeOpacity : 0.8 ,
strokeStyle : 'dashed'
});
Parameters setPath(path) 폴리라인의 경로를 지정한다. 경로는 좌표의 배열로 표현한다.
var newpath = [
new kakao . maps . LatLng ( 33.452344169439975 , 126.56878163224233 ),
new kakao . maps . LatLng ( 33.452739313807456 , 126.5709308145358 ),
new kakao . maps . LatLng ( 33.45178067090639 , 126.5726886938753 )
];
polyline . setPath ( newpath );
Parameters path : Array.< LatLng > : 좌표의 배열 getPath() 폴리라인의 경로를 반환한다.
polyline . getPath (); // 경로정보가 배열로 반환된다.
Returns getLength() 폴리라인의 총 길이를 m(미터)단위로 반환한다.선의 거리 계산하기 샘플보기
polyline . getLength ();
Returns setZIndex() 폴리라인의 z-index를 설정한다.
polyline . setZIndex ( 3 );
Parameters getZIndex() 폴리라인의 z-index를 반환한다.
var polyline = new kakao . maps . Polyline ({
zIndex : 4
});
polyline . getZIndex (); // 4
Returns Events 안드로이드 2.3버전 이하에서는 Event를 지원하지 않습니다.
mouseover 폴리라인에 마우스 커서를 올리면 발생한다.
kakao . maps . event . addListener ( polyline , 'mouseover' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mouseout 마우스 커서가 폴리라인에서 벗어나면 발생한다.
kakao . maps . event . addListener ( polyline , 'mouseout' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mousemove 폴리라인에서 마우스가 움직이면 발생한다.
kakao . maps . event . addListener ( polyline , 'mousemove' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mousedown 폴리라인에서 마우스 버튼을 누르면 발생한다.
kakao . maps . event . addListener ( polyline , 'mousedown' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments click 폴리라인을 클릭하면 발생한다
kakao . maps . event . addListener ( polyline , 'click' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments 다각형 객체
Constructor kakao.maps.Polygon(polygonOptions) 주어진 객체로 다각형을 생성한다.원, 선, 사각형, 다각형 표시하기 샘플보기 구멍난 다각형 만들기 샘플보기
var polygon = new kakao . maps . Polygon ({
map : map ,
path : [
new kakao . maps . LatLng ( 33.452344169439975 , 126.56878163224233 ),
new kakao . maps . LatLng ( 33.452739313807456 , 126.5709308145358 ),
new kakao . maps . LatLng ( 33.45178067090639 , 126.5726886938753 )
],
strokeWeight : 2 ,
strokeColor : '#FF00FF' ,
strokeOpacity : 0.8 ,
strokeStyle : 'dashed' ,
fillColor : '#00EEEE' ,
fillOpacity : 0.5
});
Parameters options
Object fillColor
String : #xxxxxx 형태의 채움 색 (기본값: ‘#F10000’)fillOpacity
Number : 채움 불투명도 (0-1) (기본값: 0)path
Array.< LatLng > | Array.<Array.< LatLng >> : 다각형을 구성하는 좌표의 배열 혹은 좌표 배열의 배열strokeWeight
Number : 픽셀 단위의 선 두께 (기본값: 3)strokeColor
String : #xxxxxx 형태의 선 색 (기본값: ‘#F10000’)strokeOpacity
Number : 선 불투명도 (0-1) (기본값: 0.6)strokeStyle
String : 선 스타일 (기본값: ‘solid’)zIndex
Number : 다각형의 z-index 속성 값Methods setMap(map) 지도에 다각형을 올린다. null 을 지정하면 다각형을 제거한다.
polygon . setMap ( map ); // 지도에 올린다.
polygon . setMap ( null ); // 지도에서 제거한다.
Parameters getMap() 다각형이 올라가있는 지도를 반환한다.
polygon . getMap ();
Returns setOptions(options) 다각형의 옵션을 설정한다.
polygon . setOptions ({
strokeWeight : 2 ,
strokeColor : '#FF00FF' ,
strokeOpacity : 0.8 ,
strokeStyle : 'dashed' ,
fillColor : '#00EEEE' ,
fillOpacity : 0.5
});
Parameters setPath(path) 다각형의 경로를 지정한다. 경로는 좌표의 배열로 표현한다.
polygon . setPath ([
new kakao . maps . LatLng ( 33.452344169439975 , 126.56878163224233 ),
new kakao . maps . LatLng ( 33.452739313807456 , 126.5709308145358 ),
new kakao . maps . LatLng ( 33.45178067090639 , 126.5726886938753 )
]);
Parameters path
Array.< LatLng > : 좌표의 배열getPath() 다각형의 경로를 반환한다.
polygon . getPath (); // 경로정보가 배열로 반환된다.
Returns getLength() 다각형의 총 길이를 m(미터)단위로 반환한다.
polygon . getLength ();
Returns getArea() 다각형으로 둘러싸인 영역의 넓이를 ㎡(제곱미터)단위로 반환한다.
polygon . getArea ();
Returns setZIndex() 다각형의 z-index를 설정한다.
polygon . setZIndex ( 3 );
Parameters getZIndex() 다각형의 z-index를 반환한다.
var polygon = new kakao . maps . Polygon ({
zIndex : 4
});
polygon . getZIndex (); // 4
Returns Events 안드로이드 2.3버전 이하에서는 Event를 지원하지 않습니다.
mouseover 다각형에 마우스 커서를 올리면 발생한다.다각형에 이벤트 등록하기1 샘플보기 다각형에 이벤트 등록하기2 샘플보기
kakao . maps . event . addListener ( polygon , 'mouseover' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mouseout 마우스 커서가 다각형에서 벗어나면 발생한다.다각형에 이벤트 등록하기1 샘플보기 다각형에 이벤트 등록하기2 샘플보기
kakao . maps . event . addListener ( polygon , 'mouseout' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mousemove 다각형에서 마우스를 움직이면 발생한다.다각형에 이벤트 등록하기2 샘플보기
kakao . maps . event . addListener ( polygon , 'mousemove' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mousedown 다각형에서 마우스 버튼을 누르면 발생한다.다각형에 이벤트 등록하기1 샘플보기 다각형에 이벤트 등록하기2 샘플보기
kakao . maps . event . addListener ( polygon , 'mousedown' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments click 다각형을 클릭하면 발생한다.다각형에 이벤트 등록하기2 샘플보기
kakao . maps . event . addListener ( polygon , 'click' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments 원 객체
Constructor kakao.maps.Circle(options) 주어진 객체로 원을 생성한다.원, 선, 사각형, 다각형 표시하기 샘플보기
var circle = new kakao . maps . Circle ({
map : map ,
center : new kakao . maps . LatLng ( 33.450701 , 126.570667 ),
radius : 50 ,
strokeWeight : 2 ,
strokeColor : '#FF00FF' ,
strokeOpacity : 0.8 ,
strokeStyle : 'dashed' ,
fillColor : '#00EEEE' ,
fillOpacity : 0.5
});
Parameters options
Object center
LatLng : 중심 좌표fillColor
String : #xxxxxx 형태의 채움 색 (기본값: ‘#F10000’)fillOpacity
Number : 채움 불투명도 (0-1) (기본값: 0)radius
Number : 미터 단위의 반지름strokeWeight
Number : 픽셀 단위의 선 두께 (기본값: 3)strokeColor
String : #xxxxxx 형태의 선 색 (기본값: ‘#F10000’)strokeOpacity
Number : 선 불투명도 (0-1) (기본값: 0.6)strokeStyle
String : 선 스타일 (기본값: ‘solid’)zIndex
Number : 원의 z-index 속성 값Methods setMap(map) 지도에 원을 올린다. null 을 지정하면 원을 제거한다.
circle . setMap ( map ); // 지도에 올린다.
circle . setMap ( null ); // 지도에서 제거한다.
Parameters getMap() 원이 올라가있는 지도를 반환한다.
circle . getMap ();
Returns setOptions(options) 원의 옵션을 설정한다.
circle . setOptions ({
radius : 20 ,
strokeWeight : 2 ,
strokeColor : '#FF00FF' ,
strokeOpacity : 0.8 ,
strokeStyle : 'dashed'
});
Parameters setPosition(position) 원의 중심 좌표를 지정한다.
var position = new kakao . maps . LatLng ( 33.450701 , 126.570667 );
circle . setPosition ( position );
Parameters getPosition() 원 중심의 좌표를 반환한다.
circle . getPosition (). toString ();
Returns setRadius(radius) 원의 반지름을 m(미터)단위로 지정한다.
circle . setRadius ( 200 );
Parameters getRadius() 원의 반지름을 반환한다.
circle . getRadius (); // 200
Returns getBounds() 원을 포함하는 최소의 사각형 영역을 구한다.
circle . getBounds ();
Returns setZIndex() 원의 z-index를 설정한다.
circle . setZIndex ( 3 );
Parameters getZIndex() 원의 z-index를 반환한다.
var circle = new kakao . maps . Circle ({
zIndex : 4
});
circle . getZIndex (); // 4
Returns Events 안드로이드 2.3버전 이하에서는 Event를 지원하지 않습니다.
mouseover 원에 마우스 커서를 올리면 발생한다.
kakao . maps . event . addListener ( circle , 'mouseover' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mouseout 마우스 커서가 원에서 벗어나면 발생한다.
kakao . maps . event . addListener ( circle , 'mouseout' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mousemove 원에서 마우스를 움직이면 발생한다.
kakao . maps . event . addListener ( circle , 'mousemove' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mousedown 원에서 마우스 버튼을 누르면 발생한다.
kakao . maps . event . addListener ( circle , 'mousedown' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments click 원을 클릭하면 발생한다.
kakao . maps . event . addListener ( circle , 'click' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments 타원 객체
Constructor kakao.maps.Ellipse(options) 주어진 객체로 타원을 생성한다.
var ellipse = new kakao . maps . Ellipse ({
map : map ,
center : new kakao . maps . LatLng ( 33.450701 , 126.570667 ),
rx : 50 ,
ry : 100 ,
strokeWeight : 2 ,
strokeColor : '#FF00FF' ,
strokeOpacity : 0.8 ,
strokeStyle : 'dashed' ,
fillColor : '#00EEEE' ,
fillOpacity : 0.5
});
Parameters options
Object center
LatLng : 중심 좌표fillColor
String : #xxxxxx 형태의 채움 색 (기본값: ‘#F10000’)fillOpacity
Number : 채움 불투명도 (0-1) (기본값: 0)rx
Number : 미터 단위의 x축 반지름ry
Number : 미터 단위의 y축 반지름strokeWeight
Number : 픽셀 단위의 선 두께 (기본값: 3)strokeColor
String : #xxxxxx 형태의 선 색 (기본값: ‘#F10000’)strokeOpacity
Number : 선 불투명도 (0-1) (기본값: 0.6)strokeStyle
String : 선 스타일 (기본값: ‘solid’)zIndex
Number : 타원의 z-index 속성 값Methods setMap(map) 지도에 타원을 올린다. null 을 지정하면 타원을 제거한다.
ellipse . setMap ( map ); // 지도에 올린다.
ellipse . setMap ( null ); // 지도에서 제거한다.
Parameters getMap() 타원이 올라가있는 지도를 반환한다.
ellipse . getMap ( map );
Returns setOptions(options) 타원의 옵션을 설정한다.
ellipse . setOptions ({
strokeWeight : 2 ,
strokeColor : '#FF00FF' ,
strokeOpacity : 0.8 ,
strokeStyle : 'dashed' ,
fillColor : '#00EEEE' ,
fillOpacity : 0.5
});
Parameters setPosition(position) 타원의 중심 좌표를 지정한다.
ellipse . setPosition ( new kakao . maps . LatLng ( 33.450701 , 126.570667 ));
Parameters getPosition() 타원 중심의 좌표를 반환한다.
ellipse . getPosition (). toString ();
Returns setRadius(rx, ry) 타원의 반지름을 m(미터)단위로 지정한다.
ellipse . setRadius ( 600 , 1000 );
Parameters getRadius() 타원의 x, y축 반지름을 반환한다.
ellipse . getRadius (); // { rx: 600, ry: 1000 }
Returns Objectrx
Number : x축 반지름ry
Number : y축 반지름 getRadiusX() 타원의 x축 반지름을 반환한다.
ellipse . getRadiusX (); // 600
Returns getRadiusY() 타원의 y축 반지름을 반환한다.
ellipse . getRadiusY (); // 1000
Returns getBounds() 타원을 포함하는 최소의 사각형 영역을 구한다.
ellipse . getBounds ();
Returns setZIndex() 타원의 z-index를 설정한다.
ellipse . setZIndex ( 3 );
Parameters getZIndex() 타원의 z-index를 반환한다.
var ellipse = new kakao . maps . Ellipse ({
zIndex : 4
});
ellipse . getZIndex (); // 4
Returns Events 안드로이드 2.3버전 이하에서는 Event를 지원하지 않습니다.
mouseover 타원에 마우스 커서를 올리면 발생한다.
kakao . maps . event . addListener ( ellipse , 'mouseover' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mouseout 마우스 커서가 타원에서 벗어나면 발생한다.
kakao . maps . event . addListener ( ellipse , 'mouseout' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mousemove 타원에서 마우스를 움직이면 발생한다.
kakao . maps . event . addListener ( ellipse , 'mousemove' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mousedown 타원에서 마우스 버튼을 누르면 발생한다.
kakao . maps . event . addListener ( ellipse , 'mousedown' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments click 타원을 클릭하면 발생한다.
kakao . maps . event . addListener ( ellipse , 'click' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments 사각형 객체
Constructor kakao.maps.Rectangle(options) 주어진 객체로 사각형를 생성한다.원, 선, 사각형, 다각형 표시하기 샘플보기
var rectangle = new kakao . maps . Rectangle ({
map : map ,
bounds : new kakao . maps . LatLngBounds (
new kakao . maps . LatLng ( 33.450701 , 126.570667 ),
new kakao . maps . LatLng ( 33.452513 , 126.57280 )
),
strokeWeight : 4 ,
strokeColor : '#FF00FF' ,
strokeOpacity : 0.8 ,
strokeStyle : 'dashed' ,
fillColor : '#00EEEE' ,
fillOpacity : 0.5
});
Parameters options
Object bounds
LatLngBounds : 사각형의 영역fillColor
String : #xxxxxx 형태의 채움 색 (기본값: ‘#F10000’)fillOpacity
Number : 채움 불투명도 (0-1) (기본값: 0)strokeWeight
Number : 픽셀 단위의 선 두께 (기본값: 3)strokeColor
String : #xxxxxx 형태의 선 색 (기본값: ‘#F10000’)strokeOpacity
Number : 선 불투명도 (0-1) (기본값: 0.6)strokeStyle
String : 선 스타일 (기본값: ‘solid’)zIndex
Number : 사각형의 z-index 속성 값Methods setMap(map) 지도에 사각형을 올린다. null 을 지정하면 사각형을 제거한다.
rectangle . setMap ( map ); // 지도에 올린다.
rectangle . setMap ( null ); // 지도에서 제거한다.
Parameters getMap() 사각형이 올라가있는 지도를 반환한다.
rectangle . getMap ();
Returns setOptions(options) 사각형의 옵션을 설정한다.
rectangle . setOptions ({
strokeWeight : 4 ,
strokeColor : '#FF00FF' ,
strokeOpacity : 0.8 ,
strokeStyle : 'dashed' ,
fillColor : '#00EEEE' ,
fillOpacity : 0.5
});
Parameters setBounds(bounds) 사각형의 영역을 지정한다.
rectangle . setBounds (
new kakao . maps . LatLngBounds (
new kakao . maps . LatLng ( 33.450701 , 126.560667 ),
new kakao . maps . LatLng ( 33.452213 , 126.57080 )
)
);
Parameters getBounds() 사각형의 영역을 반환한다.
rectangle . getBounds ();
Returns setZIndex() 사각형의 z-index를 설정한다.
rectangle . setZIndex ( 3 );
Parameters getZIndex() 사각형의 z-index를 반환한다.
var rectangle = new kakao . maps . Rectangle ({
zIndex : 4
});
rectangle . getZIndex (); // 4
Returns Events 안드로이드 2.3버전 이하에서는 Event를 지원하지 않습니다.
mouseover 사각형에 마우스 커서를 올리면 발생한다.
kakao . maps . event . addListener ( rectangle , 'mouseover' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mouseout 마우스 커서가 사각형에서 벗어나면 발생한다.
kakao . maps . event . addListener ( rectangle , 'mouseout' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mousemove 사각형에서 마우스를 움직이면 발생한다.
kakao . maps . event . addListener ( rectangle , 'mousemove' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments mousedown 사각형에서 마우스 버튼을 누르면 발생한다.
kakao . maps . event . addListener ( rectangle , 'mousedown' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments click 사각형을 클릭하면 발생한다.
kakao . maps . event . addListener ( rectangle , 'click' , function ( mouseEvent ) {
var latlng = mouseEvent . latLng ;
console . log ( latlng . toString ());
});
Arguments services services 라이브러리 네임스페이스. 장소 검색 및 주소-좌표 간 변환 서비스를 포함하고 있다. 라이브러리를 사용하기 위해서는 반드시 별도 로드 해야 한다.
Constant kakao.maps.services.Status.STATUS
응답 코드가 상수로 정의되어 있다.STATUS
값으로 사용 가능한 목록은 다음과 같다.
OK
: 검색 결과 있음ZERO_RESULT
: 정상적으로 응답 받았으나 검색 결과는 없음ERROR
: 서버 응답에 문제가 있는 경우kakao.maps.services.SortBy.SORT_BY
정렬을 위한 옵션 값이 상수로 정의되어 있다. 장소 검색( keywordSearch , categorySearch )에서 결과의 정렬을 위해 사용한다.SORT_BY
값으로 사용 가능한 목록은 다음과 같다.
ACCURACY
: 정확도 순DISTANCE
: 거리 순이 중, DISTANCE
을 사용하기 위해서는 또 다른 옵션 중 하나인 location
이 함께 지정되어 있어야 한다.
kakao.maps.services.Coords.COORDS
좌표 변환을 지원하는 좌표계가 상수로 정의되어 있다. 좌표 변환( transCoord )에서 변환을 위해, 좌표→주소 변환( coord2RegionCode , coord2Address )에서 입력한 좌표의 좌표계를 지정하거나 또는 받을 출력 좌표계를 지정하기 위해 사용한다.Coords
값으로 사용 가능한 목록은 다음과 같다.
WGS84
: WGS84 좌표계WCONGNAMUL
: WCONGNAMUL 좌표계CONGNAMUL
: CONGNAMUL 좌표계WTM
: WTM 좌표계TM
: TM 좌표계kakao.maps.services.AnalyzeType.ANALYZE_TYPE
주소-좌표 검색( addressSearch )에서 검색 방식을 지정하기 위해 사용한다.ANALYZE_TYPE
값으로 사용 가능한 목록은 다음과 같다.
SIMILAR
: 건물명이 일부 매칭될 경우에도 검색 결과를 사용EXACT
: 정확한 주소 패턴일 경우에만 검색 결과를 사용services.Places Methods 장소 검색 서비스.
Constructor kakao.maps.services.Places([map]) 장소 검색 서비스 객체를 생성한다. 지도 객체를 인자로 넣을경우, 검색에 필요한 옵션들 중 location
이 자동으로 현재 지도의 중심 좌표로 설정되어 검색을 시도한다. 필요에 따라서는 useMapBounds
옵션을 통해 현재 지도에 보여지는 영역을 자동 지정할 수 있다.
var places = new kakao . maps . services . Places ();
Parameters Methods setMap(map) 지도 객체를 설정한다. 이미 설정되어 있는 지도는 setMap(null)
로 해제 가능하다.
var places = new kakao . maps . services . Places ();
places . setMap ( map );
Parameters keywordSearch(keyword, callback, options) 입력한 키워드로 검색한다.
var places = new kakao . maps . services . Places ();
var callback = function ( result , status ) {
if ( status === kakao . maps . services . Status . OK ) {
console . log ( result );
}
};
places . keywordSearch ( '판교 치킨' , callback );
Parameters keyword
String : 검색할 키워드callback
Function : 검색 결과를 받을 콜백함수options
Object category_group_code
String : 키워드 필터링을 위한 카테고리 코드location
LatLng : 중심 좌표. 특정 지역을 기준으로 검색한다.x
Number : x 좌표, longitude, location
값이 있으면 무시된다.y
Number : y 좌표, latitude, location
값이 있으면 무시된다.radius
Number : 중심 좌표로부터의 거리(반경) 필터링 값. location
/ x
, y
/ useMapCenter
중 하나와 같이 써야 의미가 있음. 미터(m) 단위. 기본값은 5000, 0~20000까지 가능bounds
LatLngBounds : 검색할 사각형 영역rect
String : 사각 영역. 좌x,좌y,우x,우y 형태를 가짐. bounds
값이 있으면 무시된다.size
Number : 한 페이지에 보여질 목록 개수. 기본값은 15, 1~15까지 가능page
Number : 검색할 페이지. 기본값은 1, size
값에 따라 1~45까지 가능sort
SortBy : 정렬 옵션. DISTANCE
일 경우 지정한 좌표값에 기반하여 동작함. 기본값은 ACCURACY
(정확도 순)useMapCenter
Boolean : 지정한 Map 객체의 중심 좌표를 사용할지의 여부. 참일 경우, location
속성은 무시된다. 기본값은 falseuseMapBounds
Boolean : 지정한 Map 객체의 영역을 사용할지의 여부. 참일 경우, bounds
속성은 무시된다. 기본값은 falseCallback Arguments categorySearch(code, callback, options) 주어진 카테고리 코드로 검색한다. 카테고리 검색은 영역 검색이 기본이므로 옵션에 명세된 x
, y
또는 rect
를 직접 지정하거나,location
또는 bounds
값을 넣어 주어야 한다. 아니면 지정한 Map 객체를 이용하는 옵션인 useMapCenter
또는 useMapBounds
을 참으로 설정하여 지도의 영역이 자동으로 관련 값에 할당되도록 해도 된다.
var places = new kakao . maps . services . Places ();
var callback = function ( result , status ) {
if ( status === kakao . maps . services . Status . OK ) {
console . log ( result );
}
};
// 공공기관 코드 검색
places . categorySearch ( 'PO3' , callback , {
// Map 객체를 지정하지 않았으므로 좌표객체를 생성하여 넘겨준다.
location : new kakao . maps . LatLng ( 37.564968 , 126.939909 )
});
Parameters code
String : 검색할 카테고리 코드callback
Function : 검색 결과를 받을 콜백함수options
Object location
LatLng : 중심 좌표. 특정 지역을 기준으로 검색한다. 카테고리 검색에서는 필수.x
Number : x 좌표, longitude, location
값이 있으면 무시된다.y
Number : y 좌표, latitude, location
값이 있으면 무시된다.radius
Number : 중심 좌표로부터의 거리(반경) 필터링 값. location
/ x
, y
/ useMapCenter
중 하나와 같이 써야 의미가 있음. 미터(m) 단위. 기본값은 5000, 0~20000까지 가능bounds
LatLngBounds : 검색할 사각형 영역rect
String : 사각 영역. 좌x,좌y,우x,우y 형태를 가짐. bounds
값이 있으면 무시된다.size
Number : 한 페이지에 보여질 목록 개수. 기본값은 15, 1~15까지 가능page
Number : 검색할 페이지. 기본값은 1, size
값에 따라 1~45까지 가능sort
SortBy : 정렬 옵션. DISTANCE
일 경우 지정한 좌표값에 기반하여 동작함. 기본값은 ACCURACY
(정확도 순)useMapCenter
Boolean : 지정한 Map 객체의 중심 좌표를 사용할지의 여부. 참일 경우, location
속성은 무시된다. 기본값은 falseuseMapBounds
Boolean : 지정한 Map 객체의 영역을 사용할지의 여부. 참일 경우, bounds
속성은 무시된다. 기본값은 falseCallback Arguments services.Geocoder Methods Constructor kakao.maps.services.Geocoder() 주소-좌표간 변환 서비스 객체를 생성한다.
var geocoder = new kakao . maps . services . Geocoder ();
Methods addressSearch(addr, callback, options) 주소 정보에 해당하는 좌표값을 요청한다.
var geocoder = new kakao . maps . services . Geocoder ();
var callback = function ( result , status ) {
if ( status === kakao . maps . services . Status . OK ) {
console . log ( result );
}
};
geocoder . addressSearch ( '해남군 송지면' , callback );
Parameters addr
String : 변환할 주소명callback
Function : 검색 결과를 받을 콜백함수options
Object page
Number : 검색할 페이지. 기본값은 1size
Number : 검색할 페이지. 기본값은 10, 1~30 까지 가능analyze_type
AnalyzeType : 검색어 매칭 방식 선택 옵션. SIMILAR
일 경우 입력한 것과 유사한 검색어도 검색결과에 포함시킨다. EXACT
일 경우 입력한 주소 문자열과 정확하게 매칭되는 주소만을 찾아준다. 기본값은 SIMILAR
Callback Arguments coord2Address(x, y, callback, options) 좌표 값에 해당하는 구 주소와 도로명 주소 정보를 요청한다. 도로명 주소는 좌표에 따라서 표출되지 않을 수 있다.
var geocoder = new kakao . maps . services . Geocoder ();
var coord = new kakao . maps . LatLng ( 37.56496830314491 , 126.93990862062978 );
var callback = function ( result , status ) {
if ( status === kakao . maps . services . Status . OK ) {
console . log ( '그런 너를 마주칠까 ' + result [ 0 ]. address . address_name + '을 못가' );
}
};
geocoder . coord2Address ( coord . getLng (), coord . getLat (), callback );
Parameters x
Number : x 좌표, 경위도인 경우 longitudey
Number : y 좌표, 경위도인 경우 latitudecallback
Function : 검색 결과를 받을 콜백함수options
Object input_coord
Coords : 입력 좌표 체계. 기본값은 WGS84Callback Arguments result
Array : 결과 목록status
Status : 응답 코드coord2RegionCode(x, y, callback, options) 좌표 값에 해당하는 행정동, 법정동 정보를 얻는다.
var geocoder = new kakao . maps . services . Geocoder ();
var callback = function ( result , status ) {
if ( status === kakao . maps . services . Status . OK ) {
console . log ( '지역 명칭 : ' + result [ 0 ]. address_name );
console . log ( '행정구역 코드 : ' + result [ 0 ]. code );
}
};
geocoder . coord2RegionCode ( 126.9786567 , 37.566826 , callback );
Parameters x
Number : x 좌표, 경위도인 경우 longitudey
Number : y 좌표, 경위도인 경우 latitudecallback
Function : 검색 결과를 받을 콜백함수options
Object input_coord
Coords : 입력 좌표 체계. 기본값은 WGS84output_coord
Coords : 출력 좌표 체계. 기본값은 WGS84Callback Arguments result
Array : 결과 목록status
Status : 응답 코드transCoord(x, y, callback, options) 입력한 좌표를 다른 좌표계의 좌표로 변환한다.
var geocoder = new kakao . maps . services . Geocoder (),
wtmX = 160082.538257218 ,
wtmY = - 4680.975749087054 ;
var callback = function ( result , status ) {
if ( status === kakao . maps . services . Status . OK ) {
console . log ( result [ 0 ]. x ); // 126.570667
console . log ( result [ 0 ]. y ); // 33.45070100000001
}
};
// WTM 좌표를 WGS84 좌표계의 좌표로 변환한다
geocoder . transCoord ( wtmX , wtmY , callback , {
input_coord : kakao . maps . services . Coords . WTM ,
output_coord : kakao . maps . services . Coords . WGS84
});
Parameters x
Number : 변환할 x 좌표y
Number : 변환할 y 좌표callback
Function : 변환 결과를 받을 콜백함수options
Object input_coord
Coords : 입력 좌표 체계. 기본값은 WGS84output_coord
Coords : 출력 좌표 체계. 기본값은 WGS84Callback Arguments result
Array : 변환된 좌표 결과status
Status : 응답 코드검색 결과의 페이징을 담당하는 클래스. 하나의 검색 결과에 대해 페이지 이동을 쉽게 할 수 있도록 도와준다. 직접 선언은 불가능하며 검색 결과를 다루는 콜백함수의 인자로 인스턴스가 생성되어 넘어온다.
var places = new kakao . maps . services . Places ();
// callback의 세 번째 인자로 Pagination의 인스턴스가 넘어온다.
var callback = function ( result , status , pagination ) {
if ( status === kakao . maps . services . Status . OK ) {
// do something
// 특정 엘리먼트를 클릭했을 경우 다음 페이지 검색을 시도하는 예제
var nextBtn = document . getElementById ( 'nextBtn' );
nextBtn . click ( function () {
// 속성 값으로 다음 페이지가 있는지 확인하고
if ( pagination . hasNextPage ) {
// 있으면 다음 페이지를 검색한다.
pagination . nextPage ();
}
});
}
};
places . keywordSearch ( '판교 치킨' , callback );
다음 페이지를 검색한다.
이 전 페이지를 검색한다.
저장한 페이지를 검색한다.
Parameters 가장 처음 페이지를 검색한다.
가장 마지막 페이지를 검색한다.
Properties 현재 검색의 결과 목록의 총 갯수
현재 검색 결과 기준, 다음 페이지가 있는지 여부
현재 검색 결과 기준, 이 전 페이지가 있는지 여부
현재 페이지 번호
마커 클러스터링을 담당하는 객체.clusterer 라이브러리를 별도 로드 해야 사용 가능하다.마커 클러스터러 사용하기 샘플보기
Constructor kakao.maps.MarkerClusterer(options) 마커 클러스터링을 담당하는 객체를 생성한다.
var clusterer = new kakao . maps . MarkerClusterer ({
map : map ,
markers : markers ,
gridSize : 35 ,
averageCenter : true ,
minLevel : 6 ,
disableClickZoom : true ,
styles : [{
width : '53px' , height : '52px' ,
background : 'url(cluster.png) no-repeat' ,
color : '#fff' ,
textAlign : 'center' ,
lineHeight : '54px'
}]
});
Parameters options
Object map
Map : 클러스터링 마커를 표시할 지도 객체markers
Array.< Marker > : 클러스터링 할 마커 배열gridSize
Number : 클러스터의 격자 크기. 화면 픽셀 단위이며 해당 격자 영역 안에 마커가 포함되면 클러스터에 포함시킨다 (default : 60)averageCenter
Boolean : 마커들의 좌표 평균을 클러스터 좌표 설정 여부 (default : false)minLevel
Number : 클러스터링 할 지도의 최소 레벨 값. 지정한 숫자에 해당하는 레벨 미만에서는 클러스터링 하지 않는다 (default : 0)minClusterSize
Number : 클러스터링 할 최소 마커 수 (default: 2)styles
Array.< Object > : 클러스터의 스타일. 여러개를 선언하면 calculator 로 구분된 사이즈 구간마다 서로 다른 스타일을 적용시킬 수 있다texts
Array.< String > | Function : 클러스터에 표시할 문자열 또는 문자열 생성 함수. (default : 클러스터에 포함된 숫자)calculator
Array.< Number > | Function : 클러스터 크기를 구분하는 값을 가진 배열 또는 구분값 생성함수 (default : [10, 100, 1000, 10000])disableClickZoom
Boolean : 클러스터 클릭 시 지도 확대 여부. true로 설정하면 클러스터 클릭 시 확대 되지 않는다 (default: false)clickable
Boolean : 클러스터 클릭 가능 여부 지정 옵션. false일 경우 클러스터의 clusterclick , clusterdblclick , clusterrightclick 이벤트가 발생하지 않으며, 커서가 변경되지 않는다. (default: true)hoverable
Boolean : 클러스터에 마우스 over/out 가능 여부 지정 옵션. false일 경우 클러스터의 clusterover , clusterout 이벤트가 발생하지 않는다. (default: true)Methods addMarker(marker[, nodraw]) 클러스터에 마커 하나를 추가한다.
var marker = new kakao . maps . Marker ({
position : new kakao . maps . LatLng ( 37.23 , 126.67 )
});
clusterer . addMarker ( marker );
Parameters marker
Marker : 추가할 마커nodraw
Boolean : 클러스터 redraw 여부. true인 경우 클러스터를 다시 그리지 않는다.removeMarker(marker[, nodraw]) 클러스터에 추가된 마커 중 하나를 삭제한다.
clusterer . removeMarker ( marker );
Parameters marker
Marker : 삭제할 마커nodraw
Boolean : 클러스터 redraw 여부. true인 경우 클러스터를 다시 그리지 않는다.addMarkers(markers[, nodraw]) 여러개의 마커를 추가한다.
var markers = [ marker1 , marker2 , marker3 , ... ];
clusterer . addMarkers ( markers );
Parameters markers
Array.< Marker > : 추가할 마커 객체 배열nodraw
Boolean : 클러스터 redraw 여부. true인 경우 클러스터를 다시 그리지 않는다.removeMarkers(markers[, nodraw]) 추가된 마커 중 여러개의 마커를 삭제한다.
// markers = [ marker1, marker2, marker3, ... ];
clusterer . removeMarkers ( markers );
Parameters markers
Array.< Marker > : 삭제할 마커 객체 배열nodraw
Boolean : 클러스터 redraw 여부. true인 경우 클러스터를 다시 그리지 않는다.clear() 추가된 모든 마커를 삭제한다.
clusterer . clear ();
redraw() 클러스터를 다시 그린다. 주로 옵션을 변경한 이후 클러스터를 다시 그릴 때 사용한다.
clusterer . redraw ();
getGridSize() 클러스터의 격자 크기를 반환한다.
clusterer . getGridSize ();
Returns setGridSize(size) 클러스터의 격자 크기를 설정한다. (단위 : 화면픽셀)
// 각 마커를 중심으로 상하좌우 80픽셀 이내(160 x 160)에 다른 마커가 존재하면 클러스터를 구성하게 된다.
clusterer . setGridSize ( 80 );
Parameters getMinClusterSize() 클러스터를 만들기 위해 필요한 최소 마커 개수를 반환한다.
clusterer . getMinClusterSize ();
Returns setMinClusterSize(size) 클러스터를 만들기 위해 필요한 최소 마커 개수를 설정한다.
clusterer . setMinClusterSize ( 3 );
Parameters getAverageCenter() 현재 설정되어있는 클러스터 마커의 위치 결정 방식을 반환한다. 반환 값이 true
일 경우 클러스터가 포함하는 마커들의 위치 평균값을 사용하고 있음을 의미하고false
일 경우에는 기준이 되는 특정 마커의 위치를 사용하고 있음을 의미한다.
clusterer . getAverageCenter ();
Returns setAverageCenter(bool) 현재 설정되어있는 클러스터 마커의 위치 결정 방식을 설정한다.true
로 설정하면 클러스터가 포함하는 마커들의 위치 평균값을 사용하여 클러스터 마커의 위치를 결정하고false
로 설정하면 기준이 되는 특정 마커의 위치를 클러스터 마커의 위치로 결정한다.
// 클러스터 마커의 위치를, 해당 클러스터에 포함된 마커들의 위치의 평균값으로 설정한다.
clusterer . setAverageCenter ( true );
Parameters getMinLevel() 클러스터링 할 지도의 최소 레벨 값을 반환한다.
clusterer . getMinLevel ();
Returns setMinLevel(level) 클러스터링 할 지도의 최소 레벨 값을 설정한다.
clusterer . setMinLevel ( 7 );
Parameters getTexts() 클러스터 내부에 표시할 문자열의 배열 또는 문자열 생성 합수를 반환한다.
clusterer . getTexts ();
Returns Array.< String > | Function setTexts(texts) 클러스터 내부에 표시할 문자열 배열 또는 문자열 생성 함수를 설정한다.클러스터 마커에 텍스트 표시하기 샘플보기
// 클러스터 크기에 따른 삽입 문구를 배열 형태로 넣을 수 있다.
clusterer . setTexts ([ '적음' , '보통' , '많음' ]);
// 또는
// 문구를 반환하는 함수를 지정할 수 있다.
// 함수 인자로는 클러스터가 포함하는 마커의 개수가 넘어온다.
clusterer . setTexts ( function ( size ) {
var text = '' ;
// 클러스터에 포함된 마커 개수가 50개 미만이면 '적음' 으로 표시한다
if ( size < 50 ) {
text = '적음' ;
} else if ( size < 100 ) {
text = '보통' ;
} else {
text = '많음' ;
}
return text ;
});
Parameters texts
Array.< String > | Function : 클러스터 내부에 표시할 문자열 배열 또는 문자열 생성 함수getCalculator() 클러스터 크기를 구분하는 값을 가진 배열 혹은 구분값 생성 함수를 반환한다.
clusterer . getCalculator ();
Returns Array.< Number > | Function setCalculator(calculator) 클러스터 크기를 구분하는 값을 가진 배열 혹은 구분값 생성 함수를 설정한다. 별도로 지정하지 않으면 기본값은 [10, 100, 1000, 10000] 이다. 배열로 지정할 경우에는 반드시 오름차순으로 정렬해야 하며, 생성함수로 지정할 경우에는 클러스터의 스타일 배열 인덱스 또는 텍스트(texts) 배열의 인덱스를 반환해야 한다.클러스터 마커에 텍스트 표시하기 샘플보기
// 클러스터 크기를 구분하는 값을 배열로 지정한다.
// 아래와 같이 구분값을 2개 지정하면 클러스터는
// 50보다 작은경우, 50보다 크거나 같고 100보다 작은경우, 100보다 크거나 같은경우, 이렇게 3개의 크기로 구분된다.
clusterer . setCalculator ([ 50 , 100 ]);
// 또는
// 클러스터 크기를 구분하는 값을 반환하는 함수를 지정할 수 있다.
// 함수 인자로는 클러스터가 포함하는 마커의 개수가 넘어온다.
// 반환값은 클러스터 사이즈 별 스타일 혹은 문구 배열의 인덱스 값이어야 한다.
clusterer . setCalculator ( function ( size ) {
var index ;
// 클러스터에 포함된 마커의 개수가 50개 미만이면 리턴할 index값을 0으로 설정한다.
if ( size < 50 ) {
index = 0 ;
} else if ( size < 100 ) {
index = 1 ;
} else {
index = 2 ;
}
return index ;
});
Parameters calculator
Array.< Number > | Function : 클러스터의 크기를 구분하는 값의 배열 또는 구분값을 생성하는 함수getStyles() 클러스터 마커에 설정된 스타일 배열을 반환한다.
clusterer . getStyles ();
Returns setStyles(styles) 클러스터 마커에 스타일을 설정한다. 여러개를 선언하면 calculator 로 구분된 사이즈 구간마다 서로 다른 스타일을 적용시킬 수 있다
var styles = [{
width : '53px' , height : '52px' ,
background : 'url(cluster_small.png) no-repeat' ,
color : '#fff' ,
textAlign : 'center' ,
lineHeight : '54px'
}, {
width : '73px' , height : '72px' ,
background : 'url(cluster_large.png) no-repeat' ,
color : '#fff' ,
textAlign : 'center' ,
lineHeight : '74px'
}
];
clusterer . setStyles ( styles );
Parameters styles
Array.< Object > : 클러스터 마커에 설정할 스타일 배열Events clusterclick 클러스터 마커를 클릭 했을 때 발생한다. 이벤트 핸들러 함수 인자로는 Cluster 객체가 넘어온다. 클러스터 마커 클릭 시 지도가 줌인 되는 경우 원하는 Cluster 객체를 얻지 못할 수도 있다. 때문에 MarkerClusterer 를 생성할 때 disableClickZoom
옵션을 true로 설정하여 클러스터 마커를 클릭했을 때 지도가 줌인되지 않도록 설정 후 사용한다.마커 클러스터러에 클릭이벤트 추가하기 샘플보기
kakao . maps . event . addListener ( clusterer , 'clusterclick' , function ( cluster ) {
console . log ( cluster . getCenter () );
});
Arguments clusterover 클러스터 마커를 마우스 오버 했을 때 발생한다 이벤트 핸들러 함수 인자로는 마우스 오버한 Cluster 객체가 넘어온다.
kakao . maps . event . addListener ( clusterer , 'clusterover' , function ( cluster ) {
console . log ( cluster . getBounds () );
});
Arguments clusterout 클러스터 마커를 마우스 아웃 했을 때 발생한다 이벤트 핸들러 함수 인자로는 마우스 아웃된 Cluster 객체가 넘어온다.
kakao . maps . event . addListener ( clusterer , 'clusterout' , function ( cluster ) {
console . log ( cluster . getSize () );
});
Arguments clusterdblclick 클러스터 마커를 더블클릭 했을 때 발생한다 이벤트 핸들러 함수 인자로는 더블클릭한 Cluster 객체가 넘어온다.MarkerClusterer 를 생성할 때 disableClickZoom
옵션을 true로 설정해야만 이벤트가 발생한다.
kakao . maps . event . addListener ( clusterer , 'clusterdblclick' , function ( cluster ) {
console . log ( cluster . getMarkers () );
});
Arguments clusterrightclick 클러스터 마커를 오른쪽 클릭 했을 때 발생한다 이벤트 핸들러 함수 인자로는 오른쪽 클릭한 Cluster 객체가 넘어온다.
kakao . maps . event . addListener ( clusterer , 'clusterrightclick' , function ( cluster ) {
console . log ( cluster . getClusterMarker () );
});
Arguments clustered 클러스터링이 완료됐을 때 발생한다. 이벤트 핸들러 함수 인자로는 생성된 Cluster 객체 전체가 배열로 넘어온다.
kakao . maps . event . addListener ( clusterer , 'clustered' , function ( clusters ) {
console . log ( clusters . length );
});
Arguments 클러스터 객체. 클러스터링 된 마커들과 클러스터 오버레이의 정보를 가지고 있다. 직접 선언은 불가능하며 MarkerClusterer 의 이벤트 핸들러의 인자로 인스턴스가 생성되어 넘어온다.
Methods getCenter() 클러스터의 좌표를 반환한다.
kakao . maps . event . addListener ( clusterer , 'clusterclick' , function ( cluster ) {
console . log ( cluster . getCenter () );
});
Returns getBounds() 클러스터의 영역을 반환한다.
kakao . maps . event . addListener ( clusterer , 'clusterclick' , function ( cluster ) {
console . log ( cluster . getBounds () );
});
Returns getSize() 클러스터에 포함된 마커의 개수를 반환한다.
kakao . maps . event . addListener ( clusterer , 'clusterclick' , function ( cluster ) {
console . log ( cluster . getSize () );
});
Returns getMarkers() 클러스터에 포함된 마커들을 배열로 반환한다.
kakao . maps . event . addListener ( clusterer , 'clusterclick' , function ( cluster ) {
console . log ( cluster . getMarkers () );
});
Returns getClusterMarker() 클러스터 오버레이를 반환한다. 리턴값은 CustomOverlay 이다.
kakao . maps . event . addListener ( clusterer , 'clusterclick' , function ( cluster ) {
console . log ( cluster . getClusterMarker () );
});
Returns drawing drawing 라이브러리 네임스페이스. 지도 API의 마커객체와 그리기 요소를 쉽게 지도 위에 그릴 수 있도록 기능을 제공한다 라이브러리를 사용하기 위해서는 반드시 별도 로드 해야 한다.
Constant kakao.maps.drawing.OverlayType.OverlayType
drawing 라이브러리로 그리기를 제공할 오버레이 타입이 상수로 정의되어 있다.OverlayType
값으로 사용 가능한 목록은 다음과 같다.
MARKER
: 마커RECTANGLE
: 사각형CIRCLE
: 원ELLIPSE
: 타원POLYLINE
: 선ARROW
: 끝점에 화살표가 표시된 선POLYGON
: 다각형Constructor kakao.maps.drawing.DrawingManager(options) 그리기 관리자 객체를 생성한다.drawing Library 사용하기 샘플보기 drawing Library에서 데이터 얻기 샘플보기
var container = document . getElementById ( 'map' ),
map = new kakao . maps . Map ( container , {
center : new kakao . maps . LatLng ( 33.450701 , 126.570667 )
});
var options = {
map : map , // drawing manager로 그리기 요소를 그릴 map 객체
drawingMode : [ // drawing manager로 제공할 그리기 요소 모드
kakao . maps . drawing . OverlayType . MARKER ,
kakao . maps . drawing . OverlayType . POLYLINE ,
kakao . maps . drawing . OverlayType . RECTANGLE ,
kakao . maps . drawing . OverlayType . CIRCLE ,
kakao . maps . drawing . OverlayType . POLYGON
],
guideTooltip : [ 'draw' , 'drag' , 'edit' ], // 사용자에게 제공할 그리기 가이드 툴팁
markerOptions : {
draggable : true , // 마커를 그리고 나서 드래그 가능하게 한다
removable : true // 마커를 삭제 할 수 있도록 x 버튼이 표시된다
},
polylineOptions : {
draggable : true , // 그린 후 드래그가 가능하며 guideTooltip옵션에 'drag'가 포함된 경우 툴팁이 표시된다
removable : true , // 그린 후 삭제 할 수 있도록 x 버튼이 표시된다
editable : true , // 그린 후 수정할 수 있도록 작은 사각형이 표시되며 guideTooltip옵션에 'edit'가 포함된 경우 툴팁이 표시된다
strokeColor : '#39f' , // 선 색
hintStrokeStyle : 'dash' , // 그리중 마우스를 따라다니는 보조선의 선 스타일
hintStrokeOpacity : 0.5 // 그리중 마우스를 따라다니는 보조선의 투명도
},
rectangleOptions : {
draggable : true ,
removable : true ,
editable : true ,
strokeColor : '#39f' , // 외곽선 색
fillColor : '#39f' , // 채우기 색
fillOpacity : 0.5 // 채우기색 투명도
},
circleOptions : {
draggable : true ,
removable : true ,
editable : true ,
strokeColor : '#39f' ,
fillColor : '#39f' ,
fillOpacity : 0.5
},
polygonOptions : {
draggable : true ,
removable : true ,
editable : true ,
strokeColor : '#39f' ,
fillColor : '#39f' ,
fillOpacity : 0.5 ,
hintStrokeStyle : 'dash' ,
hintStrokeOpacity : 0.5
}
};
var manager = new kakao . maps . drawing . DrawingManager ( options );
Parameters options
Object map
Map : 마커와 그리기 요소를 그릴 지도 객체guideTooltip
Array.<String> : 마우스 오버 시 가이드 툴팁 표시 여부. ‘draw’, ‘drag’, ‘edit’ 3가지를 지정할 수 있다 (기본값: 모두 표시 안함) 예를들어 [‘draw’]로 설정하면 객체를 그릴때 가이드 툴팁이 표시된다drawingMode
Array.< OverlayType > : 사용할 그리기 요소 지정한다 (기본값: 모든 그리기 요소)markerOptions
Object : 마커 그리기 옵션rectangleOptions
Object : 사각형 그리기 옵션circleOptions
Object : 원 그리기 옵션ellipseOptions
Object : 타원 그리기 옵션polylineOptions
Object : 선 그리기 옵션arrowOptions
Object : 화살표 선 그리기 옵션polygonOptions
Object : 다각형 그리기 옵션MarkerOptions DrawingManager 의 생성자 옵션에서 마커의 그리기 옵션인 markerOptions
에 설정 가능한 항목들을 설명한다.
var map = new kakao . maps . Map ( container , options ),
manager = new kakao . maps . drawing . DrawingManager ({
map : map ,
drawingMode : [
kakao . maps . drawing . OverlayType . MARKER
],
markerOptions : {
draggable : true ,
removable : true ,
markerImages : [
null , // API에서 제공하는 기본 마커 이미지
{
src : 'https://t1.daumcdn.net/localimg/localimages/07/2009/map/icon/ico_mn_13.png' ,
width : 31 ,
height : 35 ,
shape : 'rect' ,
coords : '0,0,31,35' ,
hoverImage : {
src : 'https://t1.daumcdn.net/localimg/localimages/07/2012/img/marker_normal.png' ,
width : 33 ,
height : 36 ,
offsetX : 12 ,
offsetY : 36 ,
spriteWidth : 644 ,
spriteHeight : 946 ,
spriteOriginX : 10 ,
spriteOriginY : 10
},
dragImage : {
src : 'https://t1.daumcdn.net/localimg/localimages/07/2012/attach/pc_img/ico_comm.png' ,
width : 20 , // 마커 크기
height : 20 , // 마커 크기
offsetX : 10 , // 지도에 고정시킬 이미지 내 위치 좌표
offsetY : 20 , // 지도에 고정시킬 이미지 내 위치 좌표
spriteWidth : 118 , // 이미지 전체 크기
spriteHeight : 111 , // 이미지 전체 크기
spriteOriginX : 0 , // 이미지 중 마커로 사용할 위치
spriteOriginY : 90 // 이미지 중 마커로 사용할 위치
}
}
]
}
});
draggable
Boolean : 드래그 가능한 마커removable
Boolean : 삭제가 가능한 마커 (true로 설정하면 마우스 오버 시 삭제할 수 있는 X 버튼이 표시된다)markerImages
Array.< Object > : 그릴 마커의 이미지를 설정한다 (기본값: API 기본 마커 이미지)MarkerImageOptions 마커 그리기 옵션인 markerOptions 객체에 마커 마커 이미지를 설정하는 markerImages
에 설정 가능한 항목들을 설명한다.
src
String : 마커 이미지 URL width
Number : 마커의 너비height
Number : 마커의 높이offsetX
Number : 마커의 좌표에 일치시킬 이미지 안의 X 좌표offsetY
Number : 마커의 좌표에 일치시킬 이미지 안의 Y 좌표spriteWidth
Number : 스프라이트 이미지의 전체 너비spriteHeight
Number : 스프라이트 이미지의 전체 높이spriteOriginX
Number : 스프라이트 이미지에서 사용할 영역의 좌측 좌표spriteOriginY
Number : 스프라이트 이미지에서 사용할 영역의 상단 좌표shape
String : 마커의 클릭 또는 마우스오버 가능한 영역의 모양coords
String : 마커의 클릭 또는 마우스오버 가능한 영역을 표현하는 좌표값hoverImage
Object : 위에 설명된 항목들로 구성된다 (src, width, offsetX, offsetY, …)dragImage
Object : 위에 설명된 항목들로 구성된다 (src, width, offsetX, offsetY, …)RectangleOptions DrawingManager 의 생성자 옵션에서 마커의 그리기 옵션인 rectangleOptions
에 설정 가능한 항목들을 설명한다.
var map = new kakao . maps . Map ( container , options ),
manager = new kakao . maps . drawing . DrawingManager ({
map : map ,
drawingMode : [
kakao . maps . drawing . OverlayType . RECTANGLE
],
rectangleOptions : {
draggable : true ,
removable : true ,
editable : true ,
strokeWeight : 3 ,
strokeOpacity : 1.0 ,
strokeColor : '#000000' ,
strokeStyle : 'shortdash' ,
fillColor : '#00FF00' ,
fillOpacity : 0.4
}
});
draggable
Boolean : 드래그 가능한 사각형removable
Boolean : 삭제 가능한 사각형 (true로 설정하면 마우스 오버 시 삭제할 수 있는 X 버튼이 표시된다)editable
Boolean : 수정 가능한 사각형 (true로 설정하면 마우스 오버 시 수정할 수 있는 작은 사각형이 표시된다)strokeWeight
Number : 외각선의 두께 (기본값: 3)strokeColor
String : #xxxxxx 형태의 외곽선 색 (기본값: ‘#F10000’)strokeOpacity
Number : 외곽선의 불투명도 (0-1, 기본값: 1.0)strokeStyle
String : 외곽선선 스타일 (기본값: ‘solid’)fillColor
String : #xxxxxx 형태의 채우기 색 (기본값: ‘#F10000’)fillOpacity
Number : 채우기 불토명도 (0-1, 기본값: 0)CircleOptions DrawingManager 의 생성자 옵션에서 마커의 그리기 옵션인 circleOptions
에 설정 가능한 항목들을 설명한다.
var map = new kakao . maps . Map ( container , options ),
manager = new kakao . maps . drawing . DrawingManager ({
map : map ,
drawingMode : [
kakao . maps . drawing . OverlayType . CIRCLE
],
circleOptions : {
draggable : true ,
removable : true ,
editable : true ,
strokeWeight : 2 ,
strokeOpacity : 0.8 ,
strokeColor : '#0000ff' ,
strokeStyle : 'longdash' ,
fillColor : '#ff00ff' ,
fillOpacity : 0.3
}
});
draggable
Boolean : 드래그 가능한 원removable
Boolean : 삭제 가능한 원 (true로 설정하면 마우스 오버 시 삭제할 수 있는 X 버튼이 표시된다)editable
Boolean : 수정 가능한 원 (true로 설정하면 마우스 오버 시 수정할 수 있는 작은 사각형이 표시된다)strokeWeight
Number : 외각선의 두께 (기본값: 3)strokeColor
String : #xxxxxx 형태의 외곽선 색 (기본값: ‘#F10000’)strokeOpacity
Number : 외곽선의 불투명도 (0-1, 기본값: 1.0)strokeStyle
String : 외곽선 스타일 (기본값: ‘solid’)fillColor
String : #xxxxxx 형태의 채우기 색 (기본값: ‘#F10000’)fillOpacity
Number : 채우기 불토명도 (0-1, 기본값: 0)EllipseOptions DrawingManager 의 생성자 옵션에서 마커의 그리기 옵션인 ellipseOptions
에 설정 가능한 항목들을 설명한다.
var map = new kakao . maps . Map ( container , options ),
manager = new kakao . maps . drawing . DrawingManager ({
map : map ,
drawingMode : [
kakao . maps . drawing . OverlayType . ELLIPSE
],
ellipseOptions : {
draggable : true ,
removable : true ,
editable : true ,
strokeWeight : 2 ,
strokeOpacity : 0.8 ,
strokeColor : '#0000ff' ,
strokeStyle : 'longdash' ,
fillColor : '#ff00ff' ,
fillOpacity : 0.3
}
});
draggable
Boolean : 드래그 가능한 타원removable
Boolean : 삭제 가능한 타원 (true로 설정하면 마우스 오버 시 삭제할 수 있는 X 버튼이 표시된다)editable
Boolean : 수정 가능한 타원 (true로 설정하면 마우스 오버 시 수정할 수 있는 작은 사각형이 표시된다)strokeWeight
Number : 외각선의 두께 (기본값: 3)strokeColor
String : #xxxxxx 형태의 외곽선 색 (기본값: ‘#F10000’)strokeOpacity
Number : 외곽선의 불투명도 (0-1, 기본값: 1.0)strokeStyle
String : 외곽선 스타일 (기본값: ‘solid’)fillColor
String : #xxxxxx 형태의 채우기 색 (기본값: ‘#F10000’)fillOpacity
Number : 채우기 불토명도 (0-1, 기본값: 0)PolylineOptions DrawingManager 의 생성자 옵션에서 마커의 그리기 옵션인 polylineOptions
에 설정 가능한 항목들을 설명한다.
var map = new kakao . maps . Map ( container , options ),
manager = new kakao . maps . drawing . DrawingManager ({
map : map ,
drawingMode : [
kakao . maps . drawing . OverlayType . POLYLINE
],
polylineOptions : {
draggable : true ,
removable : true ,
editable : true ,
strokeWeight : 3 ,
strokeOpacity : 0.8 ,
strokeColor : '#00ff00' ,
strokeStyle : 'solid' ,
hintStrokeStyle : 'dashdot' ,
hintStrokeOpacity : 0.3
}
});
draggable
Boolean : 드래그 가능한 선removable
Boolean : 삭제 가능한 선 (true로 설정하면 마우스 오버 시 삭제할 수 있는 X 버튼이 표시된다)editable
Boolean : 수정 가능한 선 (true로 설정하면 마우스 오버 시 수정할 수 있는 작은 사각형이 표시된다)strokeWeight
Number : 선의 두께 (기본값: 3)strokeColor
String : #xxxxxx 형태의 선 색 (기본값: ‘#F10000’)strokeOpacity
Number : 선의 불투명도 (0-1, 기본값: 1.0)strokeStyle
String : 선 스타일 (기본값: ‘solid’)hintStrokeStyle
String : 그리기 중, 마우스를 따라다니는 보조선의 스타일 (기본값: ‘solid’)hintStrokeOpacity
Number : 그리기 중, 마우스를 따라다니는 보조선의 투명도. (기본값: 0.5)ArrowOptions DrawingManager 의 생성자 옵션에서 마커의 그리기 옵션인 arrowOptions
에 설정 가능한 항목들을 설명한다.
var map = new kakao . maps . Map ( container , options ),
manager = new kakao . maps . drawing . DrawingManager ({
map : map ,
drawingMode : [
kakao . maps . drawing . OverlayType . ARROW
],
arrowOptions : {
draggable : true ,
removable : true ,
editable : true ,
strokeWeight : 3 ,
strokeOpacity : 0.8 ,
strokeColor : '#00ff00' ,
strokeStyle : 'solid' ,
hintStrokeStyle : 'dashdot' ,
hintStrokeOpacity : 0.3 ,
startArrow : true
}
});
draggable
Boolean : 드래그 가능한 화살표 선removable
Boolean : 삭제 가능한 화살표 선 (true로 설정하면 마우스 오버 시 삭제할 수 있는 X 버튼이 표시된다)editable
Boolean : 수정 가능한 화살표 선 (true로 설정하면 마우스 오버 시 수정할 수 있는 작은 사각형이 표시된다)strokeWeight
Number : 화살표 선의 두께 (기본값: 3)strokeColor
String : #xxxxxx 형태의 화살표 선 색 (기본값: ‘#F10000’)strokeOpacity
Number : 화살표 선의 불투명도 (0-1, 기본값: 1.0)strokeStyle
String : 화살표 선 스타일 (기본값: ‘solid’)hintStrokeStyle
String : 그리기 중, 마우스를 따라다니는 보조선의 스타일 (기본값: ‘solid’)hintStrokeOpacity
Number : 그리기 중, 마우스를 따라다니는 보조선의 투명도. (기본값: 0.5)startArrow
Boolean : 시작점의 화살표 표시 여부 (기본값: false)PolygonOptions DrawingManager 의 생성자 옵션에서 마커의 그리기 옵션인 polygonOptions
에 설정 가능한 항목들을 설명한다.
var map = new kakao . maps . Map ( container , options ),
manager = new kakao . maps . drawing . DrawingManager ({
map : map ,
drawingMode : [
kakao . maps . drawing . OverlayType . POLYGON
],
polygonOptions : {
draggable : true ,
removable : true ,
editable : true , `
strokeWeight: 3,
strokeOpacity: 0.8,
strokeColor: '#00ff00',
strokeStyle: 'solid',
fillColor: '#ff44ff',
fillOpacity: 0.3,
hintStrokeStyle: 'dashdot',
hintStrokeOpacity: 0.3
}
});
draggable
Boolean : 드래그 가능한 다각형removable
Boolean : 삭제 가능한 다각형 (true로 설정하면 마우스 오버 시 삭제할 수 있는 X 버튼이 표시된다)editable
Boolean : 수정 가능한 다각형 (true로 설정하면 마우스 오버 시 수정할 수 있는 작은 사각형이 표시된다)strokeWeight
Number : 외각선의 두께 (기본값: 3)strokeColor
String : #xxxxxx 형태의 외곽선 색 (기본값: ‘#F10000’)strokeOpacity
Number : 외곽선의 불투명도 (0-1, 기본값: 1.0)strokeStyle
String : 외곽선 스타일 (기본값: ‘solid’)fillColor
String : #xxxxxx 형태의 채우기 색 (기본값: ‘#F10000’)fillOpacity
Number : 채우기 불토명도 (0-1, 기본값: 0)Methods setStyle(type, prop, value) 특정 그리기 요소의 스타일 속성을 설정한다.// 다각형의 채우기 색을 빨간색으로 바꾼다
manager . setStyle ( kakao . maps . drawing . OverlayType . POLYGON , 'fillColor' , '#f00' );
Parameters type
OverlayType : 속성을 설정할 그리기 요소 타입prop
String : 설정할 속성 이름value
String | Number : 설정할 속성 값setStrokeWeight(strokeWeight) 선을 사용하는 모든 그리기 요소들의 선 굵기를 설정한다.
manager . setStrokeWeight ( 4 );
Parameters strokeWeight
Number : 선의 두께setStrokeColor(strokeColor) 선을 사용하는 모든 그리기 요소들의 선 색을 설정한다.
manager . setStrokeColor ( '#ff00ff' );
Parameters strokeColor
String : #xxxxxx 형태의 선 색select(type [, index]) 그리기 요소를 선택한다. 이미 선택한 상태에서 다시 호출하면 이 전 선택된 요소는 취소된다. 여러개의 마커 이미지를 선언했을 경우, 두 번째 파라메터로 해당 마커 이미지의 인덱스 값을 넣는다. 인덱스 값은 0 부터 시작한다.
// 마커의 2번째 이미지를 선택한다.
manager . select ( kakao . maps . drawing . OverlayType . Marker , 1 );
// 마커를 취소하고 폴리라인을 선택.
manager . select ( kakao . maps . drawing . OverlayType . Polyline );
Parameters type
OverlayType : 선택할 그리기 요소 타입index
Number : 마커 이미지의 인덱스cancel() 현재 그리기 요소로 선택한 것을 취소한다.
// 그리기 요소로 마커를 선택한다
manager . select ( kakao . maps . drawing . OverlayType . Marker );
// 그리기 취소
manager . cancel ();
undo() 그리기 요소를 이전 상태로 되돌린다. 그리기 요소의 생성/수정/이동/삭제 동작을 되돌릴 수 있고 여러번 호출이 가능하다. 그리기 요소의 상태는 최대 20개 까지 저장된다.
// 이전 상태로 되돌림
// 예를 들어 마커를 마우스 드래그로 이동시켰다면 이동하기 전 위치로 되돌린다
manager . undo ();
redo() 이전 상태로 되돌린 상태를 취소한다. 여러번의 undo 호출 이후에 DrawingManager 객체에 그리기 요소에 대한 새로운 상태가 추가되지 않으면 되돌리기 이전 상태까지 실행할 수 있다.
// 이전 상태로 되돌린 상태를 취소
manager . redo ();
undoable() 그리기 요소를 이전 상태로 되돌릴 수 있는지 여부를 반환한다.
Returns // 되돌릴 수 있다면
if ( manager . undoable ()) {
// 이전 상태로 되돌림
manager . undo ();
}
redoable() 이전으로 되돌린 상태를 취소할 수 있는지 여부를 반환한다.
Returns // 취소할 수 있다면
if ( manager . redoable ()) {
// 이전 상태로 되돌린 상태를 취소
manager . redo ();
}
getData([types]) 지도에 그려진 요소들 중 선택한 요소의 데이터를 반환한다. 요소를 지정하지 않으면 그려진 모든 요소의 데이터를 반환한다.drawing Library에서 데이터 얻기 샘플보기
manager . getData ();
/*
{
"marker": [
{
"type": "marker",
"x": 126.88719971427524,
"y": 37.58574717919368,
"coordinate": "wgs84",
"zIndex": 0,
"content": ""
}
],
"arrow": [],
"polyline": [
{
"type": "polyline",
"points": [
{
"x": 126.88637492748487,
"y": 37.584620147338065
},
{
"x": 126.88836564122495,
"y": 37.58590145634537
},
{
"x": 126.88764361111481,
"y": 37.58418888521569
},
{
"x": 126.8897024258663,
"y": 37.585362117466
}
],
"coordinate": "wgs84",
"options": {
"strokeColor": "#39f",
"strokeWeight": 3,
"strokeStyle": "solid",
"strokeOpacity": 1
}
}
],
"rectangle": [
{
"type": "rectangle",
"sPoint": {
"x": 126.88928471867291,
"y": 37.58455083299234
},
"ePoint": {
"x": 126.89109409366988,
"y": 37.58599410446675
},
"coordinate": "wgs84",
"options": {
"strokeColor": "#39f",
"strokeWeight": 3,
"strokeStyle": "solid",
"strokeOpacity": 1,
"fillColor": "#cce6ff",
"fillOpacity": 0.5
}
}
],
"circle": [
{
"type": "circle",
"sPoint": {
"x": 126.88638492923441,
"y": 37.58366289638329
},
"ePoint": {
"x": 126.88767958950255,
"y": 37.58469568361937
},
"center": {
"x": 126.88703225489702,
"y": 37.58417929179167
},
"coordinate": "wgs84",
"options": {
"strokeColor": "#39f",
"strokeWeight": 3,
"strokeStyle": "solid",
"strokeOpacity": 1,
"fillColor": "#cce6ff",
"fillOpacity": 0.5
},
"radius": 57.245087125476545
}
],
"ellipse": [],
"polygon": [
{
"type": "polygon",
"points": [
{
"x": 126.88840108658137,
"y": 37.5849103979806
},
{
"x": 126.88933237967719,
"y": 37.58294711035892
},
{
"x": 126.89056473245061,
"y": 37.58410153022704
},
{
"x": 126.89140041430196,
"y": 37.585561910246575
}
],
"coordinate": "wgs84",
"options": {
"strokeColor": "#39f",
"strokeWeight": 3,
"strokeStyle": "solid",
"strokeOpacity": 1,
"fillColor": "#cce6ff",
"fillOpacity": 0.5
}
}
]
}
*/
Parameters Returns getOverlays([types]) 지도에 그려진 요소들 중 선택한 요소의 객체를 반환한다. 요소를 지정하지 않으면 그려진 모든 요소의 객체를 반환한다.
// 그려진 마커 객체와 원 객체만 가져온다
manager . getOverlays ([ kakao . maps . drawing . OverlayType . MARKER , kakao . maps . drawing . OverlayType . CIRCLE ]);
// 그려진 모든 요소의 객체를 가져온다
manager . getOverlays ();
Parameters Returns put(overlayType, param1[, param2]) 그리기 관리자 객체에 그리기 요소를 넣는다. 각 요소들의 스타일은 그리기 관리자에 이미 설정된 값을 따른다.
var position = new kakao . maps . LatLng ( 33.450701 , 126.570667 );
var center = new kakao . maps . LatLng ( 33.450701 , 126.570667 );
var sw = new kakao . maps . LatLng ( 33.448842 , 126.570379 );
var ne = new kakao . maps . LatLng ( 33.450026 , 126.568556 );
var bounds = new kakao . maps . LatLngBounds ( sw , ne );
var path = [
new kakao . maps . LatLng ( 33.452344169439975 , 126.56878163224233 ),
new kakao . maps . LatLng ( 33.452739313807456 , 126.5709308145358 ),
new kakao . maps . LatLng ( 33.45178067090639 , 126.5726886938753 )
];
// 그리기 관리자에 마커를 추가한다 마커 이미지의 index는 1로 정한다
manager . put ( kakao . maps . drawing . OverlayType . MARKER , position , 1 );
// 그리기 관리자에 사각형을 추가한다
manager . put ( kakao . maps . drawing . OverlayType . RECTANGLE , bounds );
// 그리기 관리자에 원을 추가한다. 반지름은 50으로 정한다
manager . put ( kakao . maps . drawing . OverlayType . CIRCLE , center , 50 );
// 그리기 관리자에 polyline을 추가한다
manager . put ( kakao . maps . drawing . OverlayType . POLYLINE , path );
Parameters overlayType
OverlayType : 그리기 관리자에 추가할 오버레이 타입param1
LatLng | LatLngBounds | Array.< LatLng > | Array.<Array.< LatLng >> : 추가할 그리기 요소가 마커/원인 경우 LatLng를, 타원/사각형인 경우는 LatLngBounds를, 선, 화살표선, 다각형인 경우는 좌표의 배열 또는 좌표 배열의 배열을 받는다param2
Number : 추가할 그리기 요소가 마커인경우 사용할 마커 이미지의 인덱스를, 원인 경우 원의 반지름을 파라미터로 받는다remove(overlay) 이미 그린 그리기 요소를 삭제한다.
manager . addListener ( 'drawend' , function ( data ) {
// data.target 에 그려진 오버레이 객체가 넘어온다.
manager . remove ( data . target );
});
Parameters overlay
ExtendsOverlay : 그리기 관리자에서 생성한 확장 오버레이 객체Events select 그리기 요소를 선택하면 발생한다.
manager . addListener ( 'select' , function ( e ) {
console . log ( e . overlayType );
});
Arguments ObjectoverlayType : 선택된 그리기 요소 타입 drawstart 그리기를 시작하면 발생한다.
manager . addListener ( 'drawstart' , function ( data ) {
console . log ( 'drawstart' , data );
});
Arguments draw 그리기 시작 후, 마우스를 이동하면 발생한다.
manager . addListener ( 'draw' , function ( data ) {
console . log ( 'draw' , data );
});
Arguments drawend 그리기가 끝나면 발생한다.
manager . addListener ( 'drawend' , function ( data ) {
console . log ( 'drawend' , data );
});
Arguments drawnext 다음 단계 그리기를 하면 발생한다. (Polyline, Polygon, Arrow 한정)
manager . addListener ( 'drawnext' , function ( data ) {
console . log ( 'drawnext' , data );
});
Arguments cancel 그리기를 취소하면 발생한다.
manager . addListener ( 'cancel' , function ( e ) {
console . log ( e . overlayType );
});
Arguments ObjectoverlayType : 취소된 그리기 요소 타입 remove 그리기 요소를 삭제하면 발생한다.
manager . addListener ( 'remove' , function ( e ) {
console . log ( e . overlayType );
});
Arguments ObjectoverlayType : 삭제된 그리기 요소 타입 state_changed 그리기 요소들의 상태가 변경되면 발생한다. 각 요소의 생성/수정/이동/삭제 동작과 undo 또는 redo 함수 호출이 이에 해당한다.
manager . addListener ( 'state_changed' , function () {
// do something...
});
Constructor kakao.maps.drawing.Toolbox(options) 그리기 툴박스를 생성한다. 툴박스 생성 시 DrawingManager 객체를 설정해야만 DrawingManager 에 설정된 그리기 모드를 버튼형식으로 제공한다.
// 생성한 manager 객체를 toolbox의 DrawingManager로 설정한다
var toolbox = new kakao . maps . drawing . Toolbox ({ drawingManager : manager });
// 지도에 toolbox를 표시한다
map . addControl ( toolbox . getElement (), kakao . maps . ControlPosition . TOP );
Parameters 툴박스 엘리먼트를 반환한다. 지도 위에 툴박스를 표시해야 할 때 사용한다.
// 지도에 toolbox를 표시한다
map . addControl ( toolbox . getElement (), kakao . maps . ControlPosition . TOP );
MouseEvent drawing.DrawingManager에 마우스와 관련된 이벤트(drawstart, draw, drawend, drawnext)에 등록한 이벤트 핸들러로 넘겨받는 인자 직접 생성할 수는 없으며 이벤트 핸들러에서 내부적으로 생성된 객체를 parameter로 받아 사용한다.
Properties overlayType 그리기 요소
manager . addListener ( 'drawstart' , function ( mouseEvent ) {
console . log ( 'drawstart' , mouseEvent . overlayType );
});
type coords 그리기 요소의 지도 좌표
manager . addListener ( 'drawstart' , function ( mouseEvent ) {
console . log ( 'drawstart' , mouseEvent . coords );
});
type point 그리기 요소의 화면 좌표
manager . addListener ( 'drawstart' , function ( mouseEvent ) {
console . log ( 'drawstart' , mouseEvent . point );
});
type target 그리기 요소의 인스턴스. drawend 이벤트에서만 존재한다.
manager . addListener ( 'drawend' , function ( mouseEvent ) {
console . log ( 'drawend' , mouseEvent . target );
});
type