การวางซ้อนพื้นคือการวางซ้อนรูปภาพที่เชื่อมโยงกับพิกัดละติจูด/ลองจิจูด ดังนั้นการวางซ้อนพื้นจะเคลื่อนไหวเมื่อคุณลากหรือซูมแผนที่
ตัวอย่างโค้ด
ที่เก็บ ApiDemos ใน GitHub มีตัวอย่างที่แสดงการวางซ้อนพื้นดิน ดังนี้
- GroundOverlayDemoActivity - Java: ฟีเจอร์การวางซ้อนภาคพื้นดินและผู้ฟังใน Java
- GroundOverlayDemoActivity - Kotlin: ฟีเจอร์การวางซ้อนพื้นและผู้ฟังใน Kotlin
บทนำ
การวางซ้อนพื้นคือรูปภาพที่ยึดอยู่กับแผนที่ การซ้อนทับพื้นโลกแตกต่างจากเครื่องหมายตรงที่วางตัวเป็นพื้นผิวโลกมากกว่าจะเป็นหน้าจอ ดังนั้นการหมุน เอียง หรือซูมแผนที่จะเปลี่ยนการวางแนวของภาพ การวางซ้อนภาพพื้นดินมีประโยชน์เมื่อคุณต้องการแก้ไขรูปภาพเดียวในบริเวณหนึ่งบนแผนที่ หากต้องการเพิ่มภาพถ่ายที่ครอบคลุมพื้นที่ส่วนใหญ่ของแผนที่ คุณควรพิจารณาใช้การวางซ้อนไทล์
เพิ่มการวางซ้อน
หากต้องการเพิ่ม GroundOverlay
ให้สร้างออบเจ็กต์ GroundOverlayOptions
ที่กําหนดทั้งรูปภาพและตําแหน่ง คุณระบุการตั้งค่าเพิ่มเติมที่จะส่งผลต่อการวางตำแหน่งรูปภาพบนแผนที่ได้ เมื่อกําหนดตัวเลือกที่จําเป็นแล้ว ให้ส่งออบเจ็กต์ไปยังเมธอด GoogleMap.addGroundOverlay()
เพื่อเพิ่มรูปภาพลงในแผนที่ เมธอด addGroundOverlay()
จะแสดงผลออบเจ็กต์ GroundOverlay
คุณควรเก็บการอ้างอิงออบเจ็กต์นี้ไว้หากต้องการแก้ไขในภายหลัง
วิธีการ
- สร้างอินสแตนซ์ออบเจ็กต์
GroundOverlayOptions
ใหม่ - ระบุรูปภาพเป็น
BitmapDescriptor
- กำหนดตำแหน่งรูปภาพโดยใช้วิธีใดวิธีหนึ่งต่อไปนี้
position(LatLng location, float width, float height)
position(LatLng location, float width)
positionFromBounds(LatLngBounds bounds)
- ตั้งค่าพร็อพเพอร์ตี้ที่ไม่บังคับ เช่น
transparency
ตามต้องการ - โทรหา
GoogleMap.addGroundOverlay()
เพื่อเพิ่มรูปภาพลงในแผนที่
ตัวอย่างด้านล่างแสดงวิธีเพิ่มการวางซ้อนพื้นดินไปยังออบเจ็กต์ GoogleMap
ที่มีอยู่
Kotlin
val newarkLatLng = LatLng(40.714086, -74.228697) val newarkMap = GroundOverlayOptions() .image(BitmapDescriptorFactory.fromResource(R.drawable.newark_nj_1922)) .position(newarkLatLng, 8600f, 6500f) map.addGroundOverlay(newarkMap)
Java
LatLng newarkLatLng = new LatLng(40.714086, -74.228697); GroundOverlayOptions newarkMap = new GroundOverlayOptions() .image(BitmapDescriptorFactory.fromResource(R.drawable.newark_nj_1922)) .position(newarkLatLng, 8600f, 6500f); map.addGroundOverlay(newarkMap);
หากต้องการเปลี่ยนหรือนำพื้นวางซ้อนออกจากแผนที่หลังจากที่เพิ่มพื้นวางซ้อนแล้ว ให้จับวัตถุ GroundOverlay
ไว้ คุณสามารถแก้ไขการวางซ้อนในภายหลังได้โดยทำการเปลี่ยนแปลงออบเจ็กต์นี้
Kotlin
// Add an overlay to the map, retaining a handle to the GroundOverlay object. val imageOverlay = map.addGroundOverlay(newarkMap)
Java
// Add an overlay to the map, retaining a handle to the GroundOverlay object. GroundOverlay imageOverlay = map.addGroundOverlay(newarkMap);
นำการวางซ้อนออก
คุณนำพื้นดินที่วางซ้อนออกได้โดยใช้วิธี GroundOverlay.remove()
Kotlin
imageOverlay?.remove()
Java
imageOverlay.remove();
เปลี่ยนการวางซ้อน
คุณเปลี่ยนรูปภาพการวางซ้อนพื้นดินได้หลังจากที่เพิ่มลงในแผนที่ด้วยวิธีการ GroundOverlay.setImage(BitmapDescriptor)
Kotlin
// Update the GroundOverlay with a new image of the same dimension imageOverlay?.setImage(BitmapDescriptorFactory.fromResource(R.drawable.newark_nj_1922))
Java
// Update the GroundOverlay with a new image of the same dimension imageOverlay.setImage(BitmapDescriptorFactory.fromResource(R.drawable.newark_nj_1922));
เมธอด setImage()
จะแทนที่รูปภาพที่มีอยู่ด้วยรูปภาพอื่นที่มีขนาดเดียวกัน
วางตำแหน่งการวางซ้อนพื้น
การระบุตำแหน่งของการวางซ้อนพื้นมี 2 วิธีดังนี้
- ใช้
LatLng
เพื่อวางซ้อนไว้ตรงกลาง และระบุขนาดรูปภาพเป็นเมตร - ใช้
LatLngBounds
เพื่อระบุมุมตะวันออกเฉียงเหนือและตะวันตกเฉียงใต้ของรูปภาพ
คุณต้องระบุตำแหน่งของการวางซ้อนพื้นดินก่อนที่จะเพิ่มลงในแผนที่
ใช้ตำแหน่งเพื่อวางตำแหน่งรูปภาพ
เมื่อคุณเพิ่มรูปภาพ ให้ระบุละติจูดและลองจิจูดที่จุดยึดจะยึดอยู่กับที่
และความกว้างของภาพซ้อนทับ (มีเมตร) anchor
จะอยู่ที่กึ่งกลางของรูปภาพโดยค่าเริ่มต้น คุณสามารถระบุความสูงของภาพซ้อนทับ (หน่วยเป็นเมตร) หากไม่ได้ระบุความสูงของการวางซ้อน ระบบจะคำนวณความสูงโดยอัตโนมัติเพื่อรักษาสัดส่วนภาพของรูปภาพ
โค้ดด้านล่างจะวางรูปภาพไว้ที่ตําแหน่ง 40.714086, -74.228697
ที่มีความกว้าง 8.6 กม. และความสูง 6.5 กม. รูปภาพจะตรึงอยู่ที่ด้านซ้ายล่าง
Kotlin
val newarkMap = GroundOverlayOptions() .image(BitmapDescriptorFactory.fromResource(R.drawable.newark_nj_1922)) .anchor(0f, 1f) .position(LatLng(40.714086, -74.228697), 8600f, 6500f)
Java
GroundOverlayOptions newarkMap = new GroundOverlayOptions() .image(BitmapDescriptorFactory.fromResource(R.drawable.newark_nj_1922)) .anchor(0, 1) .position(new LatLng(40.714086, -74.228697), 8600f, 6500f);
ใช้ LatLngBounds เพื่อวางตำแหน่งรูปภาพ
คุณต้องระบุ LatLngBounds
ที่มีรูปภาพนั้น LatLngBounds
จะกำหนดมุมตะวันออกเฉียงเหนือและตะวันตกเฉียงใต้ของรูปภาพ เมื่อวาดรูปภาพบนแผนที่ ระบบจะหมุนรูปภาพให้พอดีกับขอบเขต หากขอบเขตไม่ตรงกับสัดส่วนภาพเดิม รูปภาพจะบิดเบี้ยว
โค้ดด้านล่างจะวางรูปภาพบนแผนที่โดยมุมด้านตะวันตกเฉียงใต้ของภาพเชื่อมกับ 40.712216,-74.22655
และมุมด้านตะวันออกเฉียงเหนือที่เชื่อมกับ 40.773941, -74.12544
Kotlin
val newarkBounds = LatLngBounds( LatLng(40.712216, -74.22655), // South west corner LatLng(40.773941, -74.12544) // North east corner ) val newarkMap = GroundOverlayOptions() .image(BitmapDescriptorFactory.fromResource(R.drawable.newark_nj_1922)) .positionFromBounds(newarkBounds)
Java
LatLngBounds newarkBounds = new LatLngBounds( new LatLng(40.712216, -74.22655), // South west corner new LatLng(40.773941, -74.12544)); // North east corner GroundOverlayOptions newarkMap = new GroundOverlayOptions() .image(BitmapDescriptorFactory.fromResource(R.drawable.newark_nj_1922)) .positionFromBounds(newarkBounds);
เชื่อมโยงข้อมูลกับการวางซ้อนภาพพื้น
คุณสามารถเรียกใช้ GroundOverlay.setTag()
เพื่อจัดเก็บออบเจกต์ข้อมูลแบบกำหนดเองที่มีการวางซ้อนพื้นดิน และเรียกข้อมูลออบเจกต์โดยใช้ GroundOverlay.getTag()
ตัวอย่างโค้ดต่อไปนี้จะจัดเก็บคำอธิบายสตริงที่มีการวางซ้อนพื้น
Kotlin
val sydneyGroundOverlay = map.addGroundOverlay( GroundOverlayOptions() .image(BitmapDescriptorFactory.fromResource(R.drawable.harbour_bridge)) .position(LatLng(-33.873, 151.206), 100f) .clickable(true) ) sydneyGroundOverlay?.tag = "Sydney"
Java
GroundOverlay sydneyGroundOverlay = map.addGroundOverlay(new GroundOverlayOptions() .image(BitmapDescriptorFactory.fromResource(R.drawable.harbour_bridge)) .position(new LatLng(-33.873, 151.206), 100) .clickable(true)); sydneyGroundOverlay.setTag("Sydney");
ตัวอย่างสถานการณ์ที่ควรจัดเก็บและเรียกข้อมูลด้วยการวางซ้อนภาพพื้นดินมีดังนี้
- แอปของคุณอาจให้บริการการวางซ้อนพื้นแบบต่างๆ และคุณต้องการดำเนินการแตกต่างกันเมื่อผู้ใช้คลิก
- คุณอาจกำลังติดต่อกับระบบที่มีตัวระบุระเบียนที่ไม่ซ้ำกัน ซึ่งโฆษณาซ้อนทับแทนบันทึกเฉพาะในระบบนั้น
- ข้อมูลการวางซ้อนอาจระบุลําดับความสําคัญเพื่อกําหนด z-index สําหรับการวางซ้อน
จัดการเหตุการณ์การวางซ้อนบนพื้น
การวางซ้อนพื้นดินจะคลิกไม่ได้โดยค่าเริ่มต้น คุณเปิดและปิดใช้ความสามารถในการคลิกได้โดยเรียกใช้
GroundOverlay.setClickable(boolean)
ใช้ OnGroundOverlayClickListener
เพื่อฟังเหตุการณ์คลิกบนการวางซ้อนพื้นดินที่คลิกได้ หากต้องการตั้งค่าโปรแกรมฟังเสียงนี้บนแผนที่ ให้โทรไปที่ GoogleMap.setOnGroundOverlayClickListener(OnGroundOverlayClickListener)
เมื่อผู้ใช้คลิกการวางซ้อนบนพื้นดิน คุณจะได้รับonGroundOverlayClick(GroundOverlay)
การติดต่อกลับ