반응형
네이버 지도 api 종료에 따른 공지가 네이버에 올라왔네요.
네이버 지도 JS api v2 종료 안내 [2017년 12월 11일]
네이버 개발자센터 운영진입니다.
보다 나은 지도API를 제공하기 위해 최신 버전 지도API (현재 최신 지도 JS API 버전은 v3)품질 개선에 집중하고자 이며, 기존 버전인 지도 JS API v2는 오는 2017년 12월 11일(월)에 종료할 예정입니다.
지도 웹 API 사용하시는 분 들 중, 최신 API가 아닌 지도 JS API v2를 사용하고 계시다면 오는 2017년 12월 11일(월) 전에 마이그레이션 부탁드립니다.
이에 따른 마이그레이션 가이드를 아래와 같이 안내드립니다.
1. 지도API v2 사용자 종료 일정
: 2017년 12월 11일(월) 14:00
2. 대상: 지도API v2 사용자
(1) 확인 방법: API 호출 URL에 아래와 같이 v2가 포함된 URL을 호출하여 지도 API를 사용하고 계신 개발자들
(2) v2 사용자 예시
- v2 사용자 : http://openapi.map.naver.com/openapi/v2/maps.js?clientId=YOUR_CLIENT_ID
(3) 참고: v3 사용자는 아래와 같으며 마이그레이션 대상이 아닙니다.
- v3 사용자: http://openapi.map.naver.com/openapi/v3/maps.js?clientId=YOUR_CLIENT_ID
3. 마이그레이션 방법
(1) 호출 URL을 v2에서 v3로 변경
- v2: http://openapi.map.naver.com/openapi/v2/maps.js?clientId=YOUR_CLIENT_ID
- v3: http://openapi.map.naver.com/openapi/v3/maps.js?clientId=YOUR_CLIENT_ID
(2) 내부 메서드 변경
4. FAQ
(1) 제가 지도 v2 API 를 사용하고 있는지는 어디서 확인 가능한가요?
- 귀사의 웹사이트 소스보기에서 maps.js 를 호출하는 부분의 url이 http://openapi.map.naver.com/openapi/v2/maps.js?clientId=YOUR_CLIENT_ID 로 되어 있으면 해당됩니다.
(2) 제휴사용자일 경우 v3로 변경시 다시 제휴요청을 해야하나요?
- 제휴 신청을 다시하실 필요는 없습니다.
감사합니다.
네이버 개발자센터 운영진 드림
마이그레이션: v2에서 v3로 전환하기
이 문서는 NAVER 지도 API v2에서 v3로 전환하는 것을 돕기 위한 가이드입니다. NAVER 지도 API v2의 주요 인터페이스 중 v3에서 변경된 내용을 중심으로 설명합니다.
주요 변경 내용
줌 레벨 지원 범위
- v2: 1 ~ 14 레벨을 지원하고 있으며, 14 레벨이 최대 확대 레벨입니다.
- v3: v2와 동일한 줌 레벨 체계를 지원하며, 사용자 지도 유형을 활용하면 줌 레벨 체계를 사용자가 설정해 이용할 수 있습니다.
지도 유형 지원
- v2:
일반
,위성
,겹쳐보기
지도 유형을 지원합니다. - v3:
일반
,위성
,겹쳐보기
외에지형도
지도 유형을 지원하며, 사용자 지도 유형 역시 지원합니다.
오버레이, 컨트롤 추가/삭제 방법
- v2: 오버레이, 컨트롤을 추가/삭제할 때 Map 객체의 다음 메서드를 이용합니다.
addOverlay
removeOveraly
addControl
removeControl
- v3:
setMap
메서드를 이용해 오버레이, 컨트롤을 지도에 추가/삭제합니다.
주요 객체 대체표
NAVER 지도 API v2의 네임스페이스는 nhn.api.map
입니다. 그러나 v3의 네임스페이스는 naver.maps
이며, 축약해 N
네임스페이스를 사용할 수 있습니다.
v2 | v3 | 설명 |
---|---|---|
nhn.api.map.Map | naver.maps.Map | 지도 클래스 |
nhn.api.map.Size | naver.maps.Size | Size 클래스 |
nhn.api.map.LatLng | naver.maps.LatLng | 경/위도 좌표 클래스 |
nhn.api.map.TM128 | naver.maps.Point | Point 좌표 클래스 (TM128 투영 사용 시) |
nhn.api.map.UTMK | naver.maps.Point | Point 좌표 클래스 (UTMK 투영 사용 시) |
nhn.api.map.Icon | 없음 | |
nhn.api.map.SpriteIcon | 없음 | |
nhn.api.map.Map.attach/detach | naver.maps.Event | 이벤트 추가/삭제 객체 |
nhn.api.map.Marker | naver.maps.Marker | 마커 오버레이 클래스 |
nhn.api.map.SpriteMarker | naver.maps.Marker | 마커 오버레이 클래스 (icon 옵션의 size 와 origin 설정) |
nhn.api.map.DraggableMarker | naver.maps.Marker | 마커 오버레이 클래스 (draggable 옵션 사용) |
nhn.api.map.GroupOverlay | 없음 | 사용자 구현 |
nhn.api.map.MarkerLabel | 없음 | 사용자 구현 |
nhn.api.map.InfoWindow | naver.maps.InfoWindow | 정보 창 클래스 |
nhn.api.map.Polyline | naver.maps.Polyline | 폴리라인 오버레이 클래스 |
nhn.api.map.Polygon | naver.maps.Polygon | 폴리곤 오버레이 클래스 |
nhn.api.map.MultiPolygon | naver.maps.Polygon | 다중 폴리곤 오버레이 클래스 (다중 path 설정) |
nhn.api.map.Circle | naver.maps.Circle | 원 오버레이 클래스 |
없음 | naver.maps.Rectangle | 사각형 오버레이 클래스 |
nhn.api.map.ZoomControl | naver.maps.ZoomControl | 지도 확대/축소 컨트롤 |
nhn.api.map.MapTypeBtn | naver.maps.MapTypeControl | 지도 유형 컨트롤 |
nhn.api.map.TrafficMapBtn | 없음 | |
nhn.api.map.ThemeMapBtn | 없음 | |
nhn.api.map.TrafficGuide | 없음 | |
nhn.api.map.BicycleGuide | 없음 | |
nhn.api.map.CustomControl | naver.maps.CustomControl | 사용자 컨트롤 구현을 위한 추상 클래스 |
전환 방법
지도 초기화하기
v2
var map = new nhn.api.map.Map(mapContainer, {
size: new nhn.api.map.size(300, 400)
});
v3
var map = new naver.maps.Map('mapContainer', {
size: new naver.maps.Size(300, 400)
});
지도 이동하기
v2
var cityHall = new nhn.api.map.LatLng(37.5666805, 126.9784147);
map.setCenter(cityHall, 10);
var bounds = map.getBound();
map.setBound(bounds);
map.setCenterBy(15, -30);
v3
var cityHall = new naver.maps.LatLng(37.5666805, 126.9784147);
map.setCenter(cityHall);
map.setZoom(3);
var bounds = map.getBounds();
map.fitBounds(bounds);
map.panBy(new naver.maps.Point(15, -30));
지도 줌 레벨 설정하기
v2
map.setLevelBy(1);
map.setLevelBy(-1);
map.setMinMaxLevel(5, 10);
v3
map.setZoom(map.getZoom() + 1);
map.setZoom(map.getZoom() - 1);
map.setOptions("minZoom", 5);
map.setOptions("maxZoom", 10);
지도 인터랙션 옵션 조정하기
v2
map.enableDragPan(false);
map.enableDragPan(true);
map.enableWheelZoom(false);
map.enableWheelZoom(true);
v3
map.setOptions("draggable", false);
map.setOptions("draggable", true);
map.setOptions("scrollWheel", false);
map.setOptions("scrollWheel", true);
지도 이벤트 제어하기
v2
map.attach('move', onMove);
map.detach('move', onMove);
map.attach('dragstart', onDragStart);
map.detach('dragstart', onDragStart);
map.attach('dragend', onDragEnd);
map.detach('dragend', onDragEnd);
map.attach('click', onClick);
map.detach('click', onClick);
map.attach('dblclick', onDblClick);
map.detach('dblclick', onDblClick);
map.attach('mousemove', onMousemove);
map.detach('mousemove', onMousemove);
map.attach(map, 'zoom', onZoom);
map.detach(map, 'zoom', onZoom);
map.attach('redraw', onRedraw);
map.detach('redraw', onRedraw);
v3
var listeners = [
naver.maps.Event.addListener(map, 'center_changed', onMove),
naver.maps.Event.addListener(map, 'bounds_changed', onMove),
naver.maps.Event.addListener(map, 'drag', onDrag),
naver.maps.Event.addListener(map, 'dragstart', onDragStart),
naver.maps.Event.addListener(map, 'dragend', onDragEnd),
naver.maps.Event.addListener(map, 'click', onClick),
naver.maps.Event.addListener(map, 'dblclick', onDblClick),
naver.maps.Event.addListener(map, 'mousemove', onMousemove),
naver.maps.Event.addListener(map, 'zoom_changed', onZoom),
naver.maps.Event.addListener(map, 'idle', onRedraw)
];
naver.maps.Event.removeListener(listeners);
지도에 마커 추가/삭제하기
v2
var cityHall = new nhn.api.map.LatLng(37.5666805, 126.9784147);
var icon = new nhn.api.map.Icon('http://static.naver.net/maps/v3/pin_default.png',
new nhn.api.map.Size(22, 35), new nhn.api.map.Size(11, 35));
var marker = new nhn.api.map.Marker(icon, {
point: cityHall
});
map.addOverlay(marker);
map.removeOverlay(marker);
v3
var cityHall = new naver.maps.LatLng(37.5666805, 126.9784147);
var markerOptions = {
position: cityHall,
icon: {
url: 'http://static.naver.net/maps/v3/pin_default.png',
size: new naver.maps.Size(22, 35),
anchor: new naver.maps.Point(11, 35)
}
};
var marker = new naver.maps.Marker(markerOptions);
marker.setMap(map); // 추가
marker.setMap(null); // 삭제
정보 창 표시하기
v2
var infoWindow = new nhn.api.map.InfoWindow();
infoWindow.setContent('<div style="background-color:#fff;border:solid 1px #333;padding:5px;">NAVER Maps</div>');
infoWindow.setPoint(cityHall);
map.addOverlay(infoWindow);
infoWindow.setVisible(true);
window.setTimeout(function() {
infoWindow.setVisible(false);
}, 2000);
v3
var infoWindow = new naver.maps.InfoWindow({
content: 'NAVER Maps'
});
infoWindow.open(map, cityHall);
window.setTimeout(function() {
infoWindow.close();
}, 2000);
지도에 폴리라인 추가/삭제하기
v2
var points = [
new nhn.api.map.LatLng(37.5679109, 126.9778991),
new nhn.api.map.LatLng(37.5677989, 126.9795420),
new nhn.api.map.LatLng(37.5664412, 126.9798661),
new nhn.api.map.LatLng(37.5656713, 126.9794012),
new nhn.api.map.LatLng(37.5657751, 126.9778604),
new nhn.api.map.LatLng(37.5662818, 126.9770724),
new nhn.api.map.LatLng(37.5671805, 126.9767998)
];
var polyline = new nhn.api.map.Polyline(points, {
strokeWidth: 5,
strokeOpacity: 0.5,
strokeColor: "#0000ff"
});
map.addOverlay(polyline);
map.removeOverlay(polyline);
v3
var points = [
new naver.maps.LatLng(37.5679109, 126.9778991),
new naver.maps.LatLng(37.5677989, 126.9795420),
new naver.maps.LatLng(37.5664412, 126.9798661),
new naver.maps.LatLng(37.5656713, 126.9794012),
new naver.maps.LatLng(37.5657751, 126.9778604),
new naver.maps.LatLng(37.5662818, 126.9770724),
new naver.maps.LatLng(37.5671805, 126.9767998)
];
var polyline = new naver.maps.Polyline({
path: points,
strokeWeight: 5,
strokeColor: "#0000ff",
strokeOpacity: 0.5
});
polyline.setMap(map); // 추가
polyline.setMap(null); // 삭제
지도에 원 추가/삭제하기
v2
var circle = new nhn.api.map.Circle({
strokeColor: "#00ff00",
strokeWidth: 10,
strokeOpacity: 0.5,
fillColor: "#00ff00",
fillOpacity: 0.5
});
circle.setCenterPoint(cityHall);
circle.setRadius(100);
map.addOverlay(circle);
map.removeOverlay(circle);
v3
var circle = new naver.maps.Circle({
center: cityHall,
radius: 100,
strokeColor: "#00ff00",
strokeWeight: 10,
strokeOpacity: 0.5,
fillColor: "#00ff00",
fillOpacity: 0.5
});
circle.setMap(map); // 추가
circle.setMap(null); // 삭제
지도 확대/축소 컨트롤 표시하기
v2
var zoomControl = new nhn.api.map.ZoomControl();
map.addControl(zoomControl);
zoomControl.setPosition({
top: 10,
left: 10
});
v3
map.setOptions({
zoomControl: true,
zoomControlOptions: {
position: naver.maps.Position.TOP_LEFT
}
});
또는
var zoomControl = new naver.maps.ZoomControl({
position: naver.maps.Position.TOP_LEFT
});
zoomControl.setMap(zoomControl);
반응형
'Story > api/연동' 카테고리의 다른 글
고도몰 e나무 독립현 시즌4에서 게시판에 첨부한 이미지를 클릭시 확대 안뜨게 하기 (0) | 2018.01.17 |
---|---|
구글 애드워즈 Google AdWords 광고를 통해 들어온 기록을 확인하는방법 (0) | 2017.03.16 |
네이버 지식쇼핑 EP 3.0 (1) | 2016.12.12 |
hotmail.com 으로 메일 발송이 안될때 (0) | 2016.06.10 |
다음 api 를 이용한 지도 만들기 (사용자 이미지를 이용한 마커 / 컨크롤 올리기) (0) | 2015.10.13 |