ยูทิลิตี Android GeoJSON ของ Google Maps

เลือกแพลตฟอร์ม Android iOS JavaScript
  1. บทนำ
  2. เพิ่ม GeoJsonLayer ลงในแผนที่
  3. นำ GeoJsonLayer
  4. เพิ่มและนำ GeoJsonFeature
  5. เข้าถึง GeoJsonFeatures และพร็อพเพอร์ตี้
  6. จัดรูปแบบ GeoJsonLayer และ GeoJsonFeatures
  7. ดูแอปเดโม

บทนำ

GeoJSON เป็นส่วนขยายของข้อมูล JSON และแสดงถึงข้อมูลทางภูมิศาสตร์ เมื่อใช้ยูทิลิตีนี้ คุณสามารถจัดเก็บ ลักษณะทางภูมิศาสตร์ในรูปแบบ GeoJSON และแสดงเป็นเลเยอร์ที่ด้านบนของ แผนที่ หากต้องการเพิ่มและนำข้อมูล GeoJSON ของคุณออกจากแผนที่ ให้โทร addLayerToMap() และ removeLayerFromMap() ตามลำดับ คล้ายกัน คุณสามารถเพิ่มและนำคุณลักษณะแต่ละรายการออก โดยการโทร addFeature() และ removeFeature() และกำลังผ่านใน ออบเจ็กต์ GeoJsonFeature รายการ หากต้องการเข้าถึงฟีเจอร์ต่างๆ คุณ สามารถเรียก getFeatures() เพื่อหาออบเจ็กต์ GeoJsonFeature ทั้งหมดที่สามารถทำซ้ำได้ที่เพิ่มลงในเลเยอร์

คุณยังกำหนดให้ใช้รูปแบบเริ่มต้นกับฟีเจอร์ก่อนที่จะนำไปใช้งานได้ด้วย ลงในเลเยอร์แล้ว โดยเรียก getDefaultPointStyle() getDefaultLineStringStyle()หรือ getDefaultPolygonStyle() และการตั้งค่าตัวเลือกรูปแบบในแต่ละรายการ อีกทางเลือกหนึ่งคือคุณสามารถตั้งค่ารูปแบบสำหรับ GeoJsonFeature โดยโทรไปที่ setPointStyle() setLineStringStyle() หรือ setPolygonStyle() บน แสดงและส่งผ่านในออบเจ็กต์รูปแบบที่เกี่ยวข้อง

เพิ่ม GeoJsonLayer ลงในแผนที่

หากต้องการเพิ่มเลเยอร์ GeoJson ลงในแผนที่ ให้สร้างอินสแตนซ์ของ GeoJsonLayer ก่อน การสร้าง GeoJsonLayer สามารถทำได้ 2 วิธี

หากต้องการนำเข้าจาก JSONObject คุณต้องมีสิ่งต่อไปนี้

  • ออบเจ็กต์ GoogleMap รายการที่จะแสดงเลเยอร์
  • JSONObject ที่มีข้อมูล GeoJSON ที่จะเพิ่มลงใน เลเยอร์

Kotlin



val geoJsonData: JSONObject? = // JSONObject containing the GeoJSON data
val layer = GeoJsonLayer(map, geoJsonData)

      

Java


JSONObject geoJsonData = // JSONObject containing the GeoJSON data
GeoJsonLayer layer = new GeoJsonLayer(map, geoJsonData);

      

หากต้องการนำเข้าจากไฟล์ GeoJSON ในเครื่อง คุณต้องมีสิ่งต่อไปนี้

  • ออบเจ็กต์ GoogleMap รายการที่จะแสดงเลเยอร์
  • ไฟล์ทรัพยากรในเครื่องที่มีข้อมูล GeoJSON
  • Context ซึ่งจำเป็นสำหรับการเปิดทรัพยากรในเครื่อง ไฟล์

Kotlin



val layer = GeoJsonLayer(map, R.raw.geojson_file, context)

      

Java


GeoJsonLayer layer = new GeoJsonLayer(map, R.raw.geojson_file, context);

      

หลังจากสร้าง GeoJsonLayer แล้ว ให้โทร addLayerToMap()เพื่อเพิ่มข้อมูลที่นำเข้าลงในแผนที่:

Kotlin



layer.addLayerToMap()

      

Java


layer.addLayerToMap();

      

ลบ GeoJsonLayer

สมมติว่าคุณได้เพิ่มเลเยอร์นี้

Kotlin



val geoJsonData: JSONObject? = // JSONObject containing the GeoJSON data
val layer = GeoJsonLayer(map, geoJsonData)

      

Java


JSONObject geoJsonData = // JSONObject containing the GeoJSON data
GeoJsonLayer layer = new GeoJsonLayer(map, geoJsonData);

      

หากต้องการล้าง GeoJsonLayer ให้โทรหา removeLayerFromMap()

Kotlin



layer.removeLayerFromMap()

      

Java


layer.removeLayerFromMap();

      

เพิ่มและนำ GeoJsonFeature ออก

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

คุณสามารถสร้างออบเจ็กต์ GeoJsonFeature รายการและเพิ่มออบเจ็กต์ทีละรายการได้ เป็น GeoJsonLayer

สมมติว่าคุณสร้างสถานที่ที่มีจุด 0, 0 ด้วย มีรายการเดียวในคุณสมบัติ และไม่มีกรอบล้อมรอบ

Kotlin



val point = GeoJsonPoint(LatLng(0.0, 0.0))
val properties = hashMapOf("Ocean" to "South Atlantic")
val pointFeature = GeoJsonFeature(point, "Origin", properties, null)

      

Java


GeoJsonPoint point = new GeoJsonPoint(new LatLng(0, 0));
HashMap<String, String> properties = new HashMap<>();
properties.put("Ocean", "South Atlantic");
GeoJsonFeature pointFeature = new GeoJsonFeature(point, "Origin", properties, null);

      

หากต้องการเพิ่มฟีเจอร์ลงในเลเยอร์ ให้โทรหา addFeature() แล้วส่งผ่าน คุณลักษณะที่จะเพิ่ม

Kotlin



layer.addFeature(pointFeature)

      

Java


layer.addFeature(pointFeature);

      

หากต้องการนำฟีเจอร์หนึ่งออกหลังจากเพิ่มลงในเลเยอร์แล้ว ให้เรียก removeFeature()และส่งผ่านฟีเจอร์เพื่อนำออก

Kotlin



layer.removeFeature(pointFeature)

      

Java


layer.removeFeature(pointFeature);

      

เข้าถึง GeoJsonFeatures และพร็อพเพอร์ตี้

หากต้องการเข้าถึง GeoJsonFeatures ทั้งหมดที่ถูกเพิ่มลงในเลเยอร์ คุณสามารถ โทรหา getFeatures() ที่GeoJsonLayer ที่คุณ ที่สร้าง การดำเนินการนี้จะแสดงผลลัพธ์เป็น GeoJsonFeatures ที่คุณสามารถเข้าถึงได้โดยใช้ลูปสำหรับแต่ละดังที่แสดงด้านล่าง

Kotlin



for (feature in layer.features) {
    // Do something to the feature
}

      

Java


for (GeoJsonFeature feature : layer.getFeatures()) {
    // Do something to the feature
}

      

ใช้เมธอด hasProperty() และ getProperty() ใน ใช้ร่วมกับเมธอด getFeatures() เพื่อตรวจสอบว่าแต่ละ ที่มีพร็อพเพอร์ตี้หนึ่งๆ และเข้าถึงได้ ถ้ามี

Kotlin



if (feature.hasProperty("Ocean")) {
    val oceanProperty = feature.getProperty("Ocean")
}

      

Java


if (feature.hasProperty("Ocean")) {
    String oceanProperty = feature.getProperty("Ocean");
}

      

กิจกรรมการคลิกเรขาคณิต GeoJSON

คุณสามารถใช้ GeoJsonLayer.OnFeatureClickListener() เพื่อตรวจจับกิจกรรมการคลิกบน ฟีเจอร์เรขาคณิตบนแผนที่ ตัวอย่างต่อไปนี้จะบันทึกชื่อของฟีเจอร์เมื่อผู้ใช้ คลิกฟีเจอร์:

Kotlin



// Set a listener for geometry clicked events.
layer.setOnFeatureClickListener { feature ->
    Log.i("GeoJsonClick", "Feature clicked: ${feature.getProperty("title")}")
}

      

Java


// Set a listener for geometry clicked events.
layer.setOnFeatureClickListener(new Layer.OnFeatureClickListener() {
    @Override
    public void onFeatureClick(Feature feature) {
        Log.i("GeoJsonClick", "Feature clicked: " + feature.getProperty("title"));
    }
});

      

จัดรูปแบบ GeoJsonLayer และ GeoJsonFeatures

คุณตั้งค่ารูปแบบเริ่มต้นสำหรับ GeoJsonLayer หรือจัดรูปแบบฟีเจอร์แต่ละรายการได้ ในเลเยอร์

รูปแบบเริ่มต้น

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

ขั้นตอนในการนำรูปแบบเริ่มต้นไปใช้มีดังนี้

  1. ดึงออบเจ็กต์รูปแบบเริ่มต้นที่เกี่ยวข้อง ค่านี้อาจเป็น GeoJsonPointStyle, GeoJsonLineStringStyle หรือ GeoJsonPolygonStyle
  2. ใช้ตัวเลือกที่ต้องการกับรูปแบบ

ตัวอย่างเช่น ตัวอย่างโค้ดต่อไปนี้แสดงวิธีแก้ไขจุดเริ่มต้น ซึ่งจะทำให้จุดลากได้ด้วยชื่อและตัวอย่าง

Kotlin



val pointStyle = layer.defaultPointStyle
pointStyle.isDraggable = true
pointStyle.title = "Hello, World!"
pointStyle.snippet = "I am a draggable marker"

      

Java


GeoJsonPointStyle pointStyle = layer.getDefaultPointStyle();
pointStyle.setDraggable(true);
pointStyle.setTitle("Hello, World!");
pointStyle.setSnippet("I am a draggable marker");

      

รูปแบบสำหรับ GeoJsonFeature โดยเฉพาะ

อีกทางเลือกหนึ่งคือ คุณสามารถจัดรูปแบบคุณลักษณะแต่ละรายการในเลเยอร์ได้ ขั้นตอนในการ ใช้รูปแบบใน GeoJsonFeature ดังนี้

  1. สร้างออบเจ็กต์รูปแบบที่เกี่ยวข้อง ซึ่งอาจเป็น GeoJsonPointStyle, GeoJsonLineStringStyleหรือGeoJsonPolygonStyle
  2. ใช้ตัวเลือกที่ต้องการกับรูปแบบ
  3. ส่งออบเจ็กต์รูปแบบไปยัง เมธอดที่เกี่ยวข้องใน GeoJsonFeature ซึ่งจะ setPointStyle(), setLineStringStyle() หรือ setPolygonStyle()

ตัวอย่างเช่น นี่คือวิธีปรับแต่งรูปแบบสตริงบรรทัดสำหรับ GeoJsonFeatureเพื่อให้สีเป็นสีแดง

Kotlin



// Create a new feature containing a linestring
val lineStringArray: MutableList<LatLng> = ArrayList()
lineStringArray.add(LatLng(0.0, 0.0))
lineStringArray.add(LatLng(50.0, 50.0))
val lineString = GeoJsonLineString(lineStringArray)
val lineStringFeature = GeoJsonFeature(lineString, null, null, null)

// Set the color of the linestring to red
val lineStringStyle = GeoJsonLineStringStyle()
lineStringStyle.color = Color.RED

// Set the style of the feature
lineStringFeature.lineStringStyle = lineStringStyle

      

Java


// Create a new feature containing a linestring
List<LatLng> lineStringArray = new ArrayList<LatLng>();
lineStringArray.add(new LatLng(0, 0));
lineStringArray.add(new LatLng(50, 50));
GeoJsonLineString lineString = new GeoJsonLineString(lineStringArray);
GeoJsonFeature lineStringFeature = new GeoJsonFeature(lineString, null, null, null);

// Set the color of the linestring to red
GeoJsonLineStringStyle lineStringStyle = new GeoJsonLineStringStyle();
lineStringStyle.setColor(Color.RED);

// Set the style of the feature
lineStringFeature.setLineStringStyle(lineStringStyle);

      

ดูแอปเดโม

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