데이터 기반 스타일 지정을 통해 실시간으로 데이터 보기

이 문서에서는 Maps JavaScript API를 사용하여 Google 경계의 동적 데이터 기반 스타일 지정을 구현하는 이유와 방법을 설명합니다. 이는 다양한 업종과 부문에서 다양한 사용 사례에 유용합니다.

우편번호별 뉴욕 택시 수
우편번호 경계별 뉴욕시 택시 수 애니메이션 (시뮬레이션, 타임랩스):
우편번호별 뉴욕 택시 수 (타임랩스) 지도 범례

데이터 기반 스타일 지정은 Google Maps Platform 기능으로, Google의 행정 경계 다각형을 활용하고, 지도에 표시하기 위해 이러한 다각형에 스타일을 적용하고, 자체 데이터를 결합하여 시각적 분석 및 데이터 이해도 향상에 사용할 수 있는 다양한 맞춤 지도를 만들 수 있습니다. 이 문서에서는 동적 데이터 피드를 통합하여 데이터 기반 스타일 지정을 통해 지도의 데이터를 거의 실시간으로 시각화할 수 있는 이유와 방법을 설명하는 몇 가지 사용 사례를 설명합니다.

데이터 기반 스타일 지정을 사용하면 데이터의 지리적 분포를 보여주는 지도를 만들고, 다각형 스타일을 동적으로 맞춤설정하고, 클릭 이벤트를 통해 데이터와 상호작용할 수 있습니다. 이러한 기능을 사용하면 다양한 사용 사례와 업종에 유용한 정보를 제공하고 흥미로운 지도를 만들 수 있습니다.

다음은 데이터 기반 스타일 지정에서 동적 데이터 업데이트를 표시하는 지도에 적용할 수 있는 사용 사례의 몇 가지 예입니다.

  • 차량 공유: 실시간 업데이트를 사용하여 수요가 많은 지역을 파악할 수 있습니다. 이 경우 일부 제공업체는 할증 요금을 적용할 수 있습니다.
  • 교통: 실시간 업데이트를 사용하여 정체 지역을 파악할 수 있습니다. 이는 최적의 대체 경로를 결정하는 데 도움이 됩니다.
  • 선거: 선거 당일에는 실시간 데이터 여론조사 데이터를 사용하여 결과가 발생하는 대로 시각화할 수 있습니다.
  • 작업자 안전: 실시간 업데이트를 사용하여 실시간으로 전개되는 이벤트를 추적하고, 위험도가 높은 지역을 파악하고, 현장의 대응자에게 상황 인식을 제공할 수 있습니다.
  • 날씨: 실시간 업데이트를 사용하여 폭풍의 이동을 추적하고, 현재 위험을 파악하고, 경고 및 알림을 제공할 수 있습니다.
  • 환경: 실시간 업데이트를 사용하여 화산재 및 기타 오염물질의 이동을 추적하고, 환경 악화 지역을 파악하고, 인간 활동의 영향을 모니터링할 수 있습니다.

이러한 모든 상황에서 고객은 실시간 데이터 피드를 Google 경계와 결합하여 지도의 데이터를 빠르고 쉽게 시각화함으로써 추가 가치를 창출할 수 있습니다. 이를 통해 더 나은 의사 결정을 위한 거의 즉각적인 유용한 정보를 얻을 수 있습니다.

솔루션의 아키텍처 접근 방식

이제 데이터 기반 스타일 지정을 사용하여 동적 데이터를 시각화하는 지도를 빌드하는 방법을 살펴보겠습니다. 앞서 설명한 대로 사용 사례는 우편번호별로 시각화된 뉴욕 택시 수입니다. 이는 사용자가 택시를 얼마나 쉽게 잡을 수 있는지 파악하는 데 도움이 될 수 있습니다.

아키텍처
다음은 접근 방식의 애플리케이션 아키텍처 다이어그램입니다.
애플리케이션 아키텍처

동적 데이터 기반 스타일 지정 솔루션

이제 데이터 세트에 동적 데이터 기반 스타일 지정 등치 지역도를 구현하는 데 필요한 단계를 살펴보겠습니다.

이 솔루션을 사용하면 뉴욕시 주변의 실시간 택시 밀도에 대한 가상 데이터 세트를 우편번호별로 시각화할 수 있습니다. 실제 데이터는 아니지만 실제 애플리케이션이 있으며 데이터 기반 스타일 지정을 통해 지도에서 동적 데이터를 시각화하는 방법의 기능과 성능을 파악할 수 있습니다.

1단계: 시각화할 데이터를 선택하고 경계 장소 ID에 조인

첫 번째 단계는 표시할 데이터를 식별하고 Google 경계와 일치시킬 수 있는지 확인하는 것입니다. 각 postalCode에 대해 findPlaceFromQuery 콜백 메서드를 호출하여 클라이언트 측에서 이 일치를 수행할 수 있습니다. 미국의 우편번호에는 고유한 이름이 있지만 다른 행정 수준에는 없습니다. 결과가 모호할 수 있는 경우 쿼리에 올바른 장소 ID를 선택해야 합니다.


const request = {
    query: postalCode,
    fields: ['place_id'],
};
 
function findPlaceId() {
   placesService.findPlaceFromQuery(request, function (results, status) {
      if (status === google.maps.places.PlacesServiceStatus.OK) {
         console.log(results[0]);
      }
   });
}

데이터에 위도 및 경도 값이 있는 경우 구성요소 필터링과 함께 Geocoding API를 사용하여 이러한 위도/경도 값을 스타일을 지정하려는 지형지물 레이어의 장소 ID 값으로 변환할 수도 있습니다. 이 예에서는 POSTAL_CODE 지형지물 레이어의 스타일을 지정합니다.

2단계: 실시간 데이터에 연결

데이터 소스에 연결하는 방법은 다양하며 최적의 구현은 구체적인 니즈와 기술 인프라에 따라 달라집니다. 이 경우 데이터가 'zip_code' 및 'taxi_count'라는 두 개의 열이 있는 BigQuery 테이블에 있고 Firebase Cloud 함수를 통해 쿼리한다고 가정해 보겠습니다.

async function queryNycTaxis() {
   // Queries the NYC Taxis dataset.

   // Create a client
   const bigqueryClient = new BigQuery();
  
   // The SQL query to run
   const sqlQuery = 'SELECT zip_code, taxi_count
      FROM \'YOUR_DATASET_ID.TABLE\' LIMIT 100';
      
   const options = {
      query: sqlQuery,
      // Location must match that of the dataset(s)
      // referenced in the query.
      location: 'US',
   };
  
   // Run the query
   const [rows] = await bigqueryClient.query(options);
  
   rows.forEach(row => {
      const postalCode = row['zip_code'];
      const taxiCount = row['taxi_count'];
   });
}

다음으로 데이터의 최신성을 유지해야 합니다. 이를 수행하는 한 가지 방법은 웹 작업자를 사용하여 위의 쿼리를 호출하고 setInterval 함수를 사용하여 데이터를 새로고침하는 타이머를 설정하는 것입니다. 간격을 적절한 값으로 설정할 수 있습니다(예: 15초마다 지도 새로고침). 간격 시간이 지날 때마다 웹 작업자는 postalCode별로 업데이트된 taxiCount 값을 요청합니다.

이제 데이터를 쿼리하고 새로고침할 수 있으므로 지도 다각형의 모양이 이러한 변경사항을 반영하도록 하겠습니다.

3단계: 데이터 기반 스타일 지정을 사용하여 지도 스타일 지정

이제 Maps JavaScript 인스턴스의 우편번호 경계에 시각적 스타일을 JSON 객체로 만들고 적용하는 데 필요한 동적 데이터 값이 있으므로 등치 지역도로 스타일을 지정할 차례입니다.

이 예에서는 각 우편번호의 택시 수를 기준으로 지도의 스타일을 지정하여 사용자에게 해당 지역의 택시 밀도와 가용성을 제공합니다. 스타일은 택시 수 값에 따라 다릅니다. 택시 수가 가장 적은 지역에는 보라색 스타일이 적용되고 색상 그라데이션은 빨간색, 주황색을 거쳐 밀도가 가장 높은 지역의 뉴욕 택시 노란색으로 끝납니다. 이 색 구성표의 경우 이러한 색상 값을 fillColor 및 strokeColor에 적용합니다. fillOpacity를 0.5로 설정하면 사용자가 기본 지도를 볼 수 있고 strokeOpacity를 1.0으로 설정하면 동일한 색상의 다각형 경계를 구분할 수 있습니다.


const featureLayer = map.getFeatureLayer(
   google.maps.FeatureType.POSTAL_CODE
);
featureLayer.style = (featureStyleFunctionOptions) => {
   const placeFeature = featureStyleFunctionOptions.feature;
   // taxiCount per (postal_code) PlaceID 
   const taxiCount = zips[placeFeature.placeId];
   let fillColor;
   let strokeColor;
// Apply colors to features based on taxiCount values
if (taxiCount < 8) {
   fillColor = "#571845";  
   strokeColor = "#571845"; 
} else if (taxiCount < 13) {
   fillColor = "#900c3e";
   strokeColor = "#900c3e";
} else if (taxiCount < 21) {
   fillColor = "#c60039"; 
   strokeColor = "#c60039"; 
} else if (taxiCount < 34) {
   fillColor = "#fe5733";
   strokeColor = "#fe5733";
// keep else if or the whole map gets this style with else
} else if (taxiCount >= 34) { 
   fillColor = "#fec30f";
   strokeColor = "#fec30f";
}  
return {
   fillColor,
   strokeColor,
   fillOpacity: 0.5,
   strokeOpacity: 1.0,
};
 

결론

Google 경계에 대한 데이터 기반 스타일 지정을 사용하면 데이터를 사용하여 다양한 업종과 부문에 걸쳐 다양한 구현을 위해 지도의 스타일을 지정할 수 있습니다. 실시간 데이터에 연결하면 무엇 이 일어나고 있는지, 어디 에서 일어나고 있는지, 언제 일어나고 있는지를 전달할 수 있습니다. 이 기능을 사용하면 실시간 데이터의 가치를 창출하고 사용자가 실제 세계에서 실시간으로 데이터를 더 잘 이해할 수 있습니다.

다음 작업

참여자

주요 작성자:

짐 레플라 | Google Maps Platform 솔루션 엔지니어