React에서 지도 API 사용하기 – 기본 설정, Google Maps, Leaflet, Mapbox의 사용법 비교 및 환경 설정

최근 웹 애플리케이션에서 지도 기능은 꼭 필요한 요소로 자리 잡았습니다. 지도 API는 사용자가 위치 정보를 기반으로 다양한 데이터를 시각적으로 표현할 수 있게 해줍니다. 이번 글에서는 React를 사용하여 Google Maps, Leaflet, Mapbox 등의 지도 API를 설정하고 사용하는 방법을 비교해 보겠습니다.

1. React 환경 설정

먼저, React 프로젝트를 생성해야 합니다. Create React App을 사용하여 간단하게 React 환경을 구축할 수 있습니다.

npx create-react-app my-map-app

프로젝트 폴더로 이동 후, 필요한 패키지를 설치합니다.

cd my-map-app

2. Google Maps API 설정

Google Maps는 매우 강력한 지도 서비스로, 다양한 기능을 제공합니다. Google Maps API를 사용하기 위해서는 API 키가 필요합니다.

  1. Google Cloud Console에 접속하여 프로젝트를 생성합니다.
  2. API 및 서비스에서 ‘Maps JavaScript API’를 활성화합니다.
  3. API 키를 생성합니다.

이제 React 프로젝트에 Google Maps API를 추가하겠습니다.

npm install @react-google-maps/api

Google Maps 컴포넌트 만들기

다음은 Google Maps를 사용하는 간단한 컴포넌트입니다.


import React from 'react';
import { GoogleMap, LoadScript, Marker } from '@react-google-maps/api';

const mapContainerStyle = {
    height: "400px",
    width: "800px"
};

const center = {
    lat: 37.7749, // 위도
    lng: -122.4194 // 경도
};

const MyGoogleMap = () => {
    return (
        
            
                
            
        
    )
};

export default MyGoogleMap;
        

생성한 MyGoogleMap 컴포넌트를 앱에 추가합니다.


import React from 'react';
import MyGoogleMap from './MyGoogleMap'; // MyGoogleMap 경로에 맞게 조정

const App = () => {
    return (
        

Google Maps in React

); }; export default App;

3. Leaflet 설정

Leaflet은 오픈 소스 라이브러리로, 경량화된 지도 API입니다. 간단하고 사용하기 쉬운 API를 제공하며, 브라우저 호환성이 좋습니다.

Leaflet을 사용하기 위해 해당 라이브러리를 설치합니다.

npm install react-leaflet leaflet

Leaflet 컴포넌트 만들기

다음은 Leaflet을 사용하는 간단한 컴포넌트입니다.


import React from 'react';
import { MapContainer, TileLayer, Marker, Popup } from 'react-leaflet';
import 'leaflet/dist/leaflet.css';
import L from 'leaflet';

// Leaflet에서 마커 아이콘 설정
delete L.Icon.Default.prototype._getIconUrl;
L.Icon.Default.mergeOptions({
    iconRetinaUrl: require('leaflet/dist/images/marker-icon-2x.png'),
    iconUrl: require('leaflet/dist/images/marker-icon.png'),
    shadowUrl: require('leaflet/dist/images/marker-shadow.png')
});

const MyLeafletMap = () => {
    const position = [37.7749, -122.4194];
    
    return (
        
            
            
                나의 위치
            
        
    );
};

export default MyLeafletMap;
        

지금 생성한 MyLeafletMap 컴포넌트를 앱에서 사용해 보겠습니다.


import React from 'react';
import MyLeafletMap from './MyLeafletMap'; // MyLeafletMap 경로에 맞게 조정

const App = () => {
    return (
        

Leaflet in React

); }; export default App;

4. Mapbox 설정

Mapbox는 사용자 정의 지도 및 데이터 시각화 기능을 제공하는 유료 지도 API입니다. Mapbox를 사용하기 위해서는 Mapbox 계정이 필요하며, API 키를 발급받아야 합니다.

  1. Mapbox 공식 웹사이트에 가입하여 계정을 만듭니다.
  2. 대시보드에서 API 키를 생성합니다.

Mapbox를 React 프로젝트에 설치합니다.

npm install react-map-gl mapbox-gl

Mapbox 컴포넌트 만들기

아래는 Mapbox를 사용하는 예시 컴포넌트입니다.


import React from 'react';
import { StaticMap, MapContext } from 'react-map-gl';

const MyMapboxMap = () => {
    const mapboxApiKey = 'YOUR_MAPBOX_API_KEY';
    const viewport = {
        width: 800,
        height: 400,
        latitude: 37.7749,
        longitude: -122.4194,
        zoom: 10
    };

    return (
        
            
        
    );
};

export default MyMapboxMap;
        

생성한 MyMapboxMap 컴포넌트를 앱에 추가합니다.


import React from 'react';
import MyMapboxMap from './MyMapboxMap'; // MyMapboxMap 경로에 맞게 조정

const App = () => {
    return (
        

Mapbox in React

); }; export default App;

5. 지도 API 비교

세 가지 라이브러리인 Google Maps, Leaflet, Mapbox 각각 장단점이 있습니다. 각각의 라이브러리를 비교해보면 다음과 같습니다.

특징 Google Maps Leaflet Mapbox
사용 용이성 매우 쉬움 쉬움 약간 어려움
가격 유료 무료 유료
커스터마이징 제한적 높음 매우 높음
기능 다양함 기본 기능 데이터 시각화 강력함

6. 결론

이번 포스트에서는 React에서 지도 API를 사용하는 방법에 대해 알아보았습니다. Google Maps, Leaflet, Mapbox 각각의 장단점을 살펴보았으며, 각 API를 React에서 사용하는 방법을 구체적으로 살펴보았습니다. 프로젝트의 요구사항에 맞는 적절한 라이브러리를 선택하여 사용하시기 바랍니다.

7. 참고 링크