ดูข้อมูลแบบเรียลไทม์ด้วยการจัดรูปแบบที่เป็นไปตามข้อมูล

เอกสารนี้อธิบายเหตุผลและวิธีใช้การจัดสไตล์ตามข้อมูลที่ขับเคลื่อนโดยข้อมูลแบบไดนามิกของขอบเขตของ Google โดยใช้ Maps JavaScript API ซึ่งมีประโยชน์สำหรับกรณีการใช้งานที่หลากหลายในอุตสาหกรรมและกลุ่มต่างๆ

จํานวนแท็กซี่ในนิวยอร์กซิตี้ตามรหัสไปรษณีย์
จํานวนแท็กซี่ที่เคลื่อนไหวในนิวยอร์กซิตี้ตามขอบเขตรหัสไปรษณีย์ (จําลองตามการหยุดเวลา)
จํานวนแท็กซี่ในนิวยอร์กซิตี้ตามรหัสไปรษณีย์ (ไทม์แลปส์) คำอธิบายแผนที่

การจัดสไตล์ตามข้อมูลเป็นความสามารถของ Google Maps Platform ที่ช่วยให้คุณใช้รูปหลายเหลี่ยมเขตแดนการปกครองของ Google, ใช้การจัดสไตล์กับรูปหลายเหลี่ยมเหล่านั้นเพื่อแสดงบนแผนที่ และรวมข้อมูลของคุณเองเพื่อสร้างแผนที่ที่ปรับแต่งได้และสมบูรณ์ซึ่งสามารถใช้สำหรับการวิเคราะห์ด้วยภาพและปรับปรุงความเข้าใจเกี่ยวกับข้อมูลของคุณ เอกสารนี้จะกล่าวถึงกรณีการใช้งานบางส่วนที่อธิบายเหตุผลและวิธีแสดงข้อมูลเป็นภาพด้วยการจัดสไตล์ตามข้อมูลบนแผนที่แบบเกือบเรียลไทม์โดยการผสานรวมฟีดข้อมูลแบบไดนามิก

การจัดสไตล์ตามข้อมูลช่วยให้คุณสร้างแผนที่ที่แสดงการกระจายข้อมูลทางภูมิศาสตร์ ปรับแต่งสไตล์รูปหลายเหลี่ยมแบบไดนามิก และโต้ตอบกับข้อมูลผ่านเหตุการณ์การคลิกได้ ฟีเจอร์เหล่านี้สามารถใช้สร้างแผนที่ที่ให้ข้อมูลและน่าสนใจสำหรับกรณีการใช้งานและอุตสาหกรรมต่างๆ

ต่อไปนี้คือตัวอย่างกรณีการใช้งานที่อาจใช้กับแผนที่ที่แสดงการอัปเดตข้อมูลแบบไดนามิกในการจัดสไตล์ตามข้อมูล

  • การแชร์รถ: สามารถใช้การอัปเดตแบบเรียลไทม์เพื่อระบุพื้นที่ที่มีดีมานด์สูง ซึ่งในกรณีนี้ผู้ให้บริการบางรายอาจขึ้นราคา
  • การขนส่ง: สามารถใช้ข้อมูลอัปเดตแบบเรียลไทม์เพื่อระบุพื้นที่ที่การจราจรคับคั่ง ซึ่งจะช่วยในการกำหนดเส้นทางอื่นที่ดีที่สุด
  • การเลือกตั้ง: ในคืนที่มีการเลือกตั้ง คุณสามารถใช้ข้อมูลแบบเรียลไทม์จากการสำรวจเพื่อแสดงผลลัพธ์เป็นภาพขณะที่เกิดขึ้น
  • ความปลอดภัยของเจ้าหน้าที่: ใช้การอัปเดตแบบเรียลไทม์เพื่อติดตามเหตุการณ์ที่เกิดขึ้นแบบเรียลไทม์ ระบุพื้นที่ที่มีความเสี่ยงสูง และแจ้งข้อมูลสถานการณ์ให้ผู้ตอบเหตุในสนามทราบ
  • สภาพอากาศ: คุณสามารถใช้ข้อมูลอัปเดตแบบเรียลไทม์เพื่อติดตามการเคลื่อนไหวของพายุ ระบุอันตรายที่เกิดขึ้นในปัจจุบัน รวมถึงออกคำเตือนและการแจ้งเตือน
  • สิ่งแวดล้อม: ใช้การอัปเดตแบบเรียลไทม์เพื่อติดตามการเคลื่อนไหวของขี้เถ้าภูเขาไฟและสารมลพิษอื่นๆ ระบุพื้นที่ที่มีการเสื่อมโทรมทางสิ่งแวดล้อม และตรวจสอบผลกระทบจากกิจกรรมของมนุษย์

ในทุกสถานการณ์เหล่านี้ ลูกค้าสามารถปลดล็อกคุณค่าเพิ่มเติมด้วยการรวมฟีดข้อมูลแบบเรียลไทม์เข้ากับขอบเขตของ Google เพื่อแสดงข้อมูลเป็นภาพบนแผนที่ได้อย่างรวดเร็วและง่ายดาย ซึ่งจะช่วยให้ลูกค้าได้รับข้อมูลเชิงลึกที่เกือบจะทันทีเพื่อการตัดสินใจอย่างมีข้อมูลที่ดียิ่งขึ้น

แนวทางสถาปัตยกรรมของโซลูชัน

ต่อไปมาลองสร้างแผนที่โดยใช้การจัดสไตล์ตามข้อมูลเพื่อแสดงข้อมูลแบบไดนามิกเป็นภาพกัน ดังที่แสดงไว้ก่อนหน้านี้ กรณีการใช้งานคือจํานวนแท็กซี่ในนิวยอร์กที่แสดงเป็นภาพตามรหัสไปรษณีย์ ซึ่งจะช่วยให้ผู้ใช้เข้าใจว่าเรียกแท็กซี่ได้ง่ายเพียงใด

สถาปัตยกรรม
แผนภาพสถาปัตยกรรมแอปพลิเคชันของแนวทางมีดังนี้
สถาปัตยกรรมแอปพลิเคชัน

โซลูชันการจัดสไตล์แบบไดนามิกโดยอิงตามข้อมูล

ต่อไปเราจะอธิบายขั้นตอนที่จำเป็นในการใช้แผนที่รูปแบบแผนภูมิภูมิศาสตร์แบบไดนามิกที่ขับเคลื่อนโดยข้อมูลสำหรับชุดข้อมูลของคุณ

โซลูชันนี้ช่วยให้คุณเห็นภาพชุดข้อมูลสมมติของความหนาแน่นแท็กซี่แบบเรียลไทม์รอบๆ นครนิวยอร์กตามรหัสไปรษณีย์ แม้ว่าข้อมูลนี้อาจไม่ใช่ข้อมูลในชีวิตจริง แต่ก็มีการใช้งานในชีวิตจริงและช่วยให้คุณเห็นถึงประสิทธิภาพและความสามารถของการแสดงข้อมูลแบบไดนามิกบนแผนที่ด้วยการจัดสไตล์ตามข้อมูล

ขั้นตอนที่ 1: เลือกข้อมูลเพื่อแสดงภาพและเข้าร่วมกับรหัสสถานที่ที่เป็นขอบเขต

ขั้นตอนแรกคือระบุข้อมูลที่ต้องการแสดงและตรวจสอบว่าข้อมูลดังกล่าวจับคู่กับขอบเขตของ Google ได้ คุณทำการจับคู่ฝั่งไคลเอ็นต์ได้โดยเรียกใช้เมธอดการเรียกกลับ findPlaceFromQuery สำหรับรหัสไปรษณีย์แต่ละรหัส โปรดทราบว่ารหัสไปรษณีย์ในสหรัฐอเมริกามีชื่อที่แตกต่างกัน แต่หน่วยบริหารระดับอื่นๆ ไม่มี โปรดตรวจสอบว่าคุณเลือกรหัสสถานที่ที่ถูกต้องสำหรับคำค้นหาในกรณีที่อาจได้ผลลัพธ์ที่ไม่ชัดเจน


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 ร่วมกับการกรองคอมโพเนนต์เพื่อแปลงค่าละติจูด/ลองจิจูดเหล่านั้นเป็นค่ารหัสสถานที่สำหรับเลเยอร์ฟีเจอร์ที่ต้องการจัดสไตล์ ในตัวอย่างนี้ คุณกําลังจัดรูปแบบเลเยอร์ฟีเจอร์ POSTAL_CODE

ขั้นตอนที่ 2: เชื่อมต่อกับข้อมูลแบบเรียลไทม์

การเชื่อมต่อกับแหล่งข้อมูลมีหลายวิธี และการใช้งานที่ดีที่สุดจะขึ้นอยู่กับความต้องการเฉพาะและโครงสร้างพื้นฐานทางเทคนิคของคุณ ในกรณีนี้ สมมติว่าข้อมูลของคุณอยู่ในตาราง BigQuery ที่มี 2 คอลัมน์ ได้แก่ "zip_code" และ "taxi_count" และคุณจะค้นหาข้อมูลผ่าน Firebase Cloud Function

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'];
   });
}

ถัดไป คุณต้องตรวจสอบว่าข้อมูลเป็นข้อมูลล่าสุด วิธีหนึ่งในการทำเช่นนี้คือการเรียกใช้การค้นหาข้างต้นโดยใช้ Web Worker และตั้งตัวจับเวลาเพื่อรีเฟรชข้อมูลโดยใช้ฟังก์ชัน setInterval คุณสามารถตั้งค่าช่วงเวลาเป็นค่าที่เหมาะสม เช่น รีเฟรชแผนที่ทุก 15 วินาที ทุกครั้งที่ช่วงเวลาผ่านไป เวิร์กเกอร์เว็บจะขอค่า taxiCount ที่อัปเดตแล้วตามรหัสไปรษณีย์

ตอนนี้เราค้นหาและรีเฟรชข้อมูลได้แล้ว มาดูกันว่ารูปลักษณ์ของรูปหลายเหลี่ยมบนแผนที่แสดงการเปลี่ยนแปลงเหล่านี้หรือไม่

ขั้นตอนที่ 3: จัดสไตล์แผนที่ด้วยการจัดสไตล์ตามข้อมูล

ตอนนี้คุณมีค่าข้อมูลแบบไดนามิกที่จำเป็นในการสร้างและใช้รูปแบบภาพกับขอบเขตรหัสไปรษณีย์ในอินสแตนซ์ JavaScript ของ Maps ในรูปแบบออบเจ็กต์ JSON แล้ว ก็ถึงเวลาแต่งสไตล์เป็นแผนที่ Choropleth

ในตัวอย่างนี้ คุณกําหนดสไตล์แผนที่ตามจํานวนแท็กซี่ในแต่ละรหัสไปรษณีย์ เพื่อให้ผู้ใช้ทราบความหนาแน่นและความพร้อมให้บริการของแท็กซี่ในพื้นที่ รูปแบบจะแตกต่างกันไปตามค่าจำนวนแท็กซี่ พื้นที่ที่มีแท็กซี่น้อยที่สุดจะมีการจัดสไตล์เป็นสีม่วง และไล่ระดับสีจากสีแดง สีส้ม และจบที่สีเหลืองของแท็กซี่ในนิวยอร์กสำหรับพื้นที่ที่มีแท็กซี่หนาแน่นที่สุด สำหรับรูปแบบสีนี้ คุณจะใช้ค่าสีเหล่านี้กับ 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 ช่วยให้คุณใช้ข้อมูลเพื่อจัดสไตล์แผนที่สําหรับการใช้งานที่หลากหลายในอุตสาหกรรมและกลุ่มต่างๆ ได้ การเชื่อมต่อกับข้อมูลแบบเรียลไทม์ช่วยให้คุณสื่อสารได้เกี่ยวกับสิ่งที่เกิดขึ้น ตำแหน่งที่เหตุการณ์เกิดขึ้น และขณะที่เหตุการณ์เกิดขึ้น ความสามารถนี้อาจช่วยปลดล็อกคุณค่าของข้อมูลแบบเรียลไทม์และช่วยให้ผู้ใช้เข้าใจข้อมูลดังกล่าวได้ดียิ่งขึ้นในแบบเรียลไทม์ในโลกแห่งความเป็นจริง

การดำเนินการถัดไป

ผู้ร่วมให้ข้อมูล

ผู้เขียนหลัก:

Jim Leflar | Google Maps Platform Solutions Engineer