การวางซ้อนพื้น

จัดทุกอย่างให้เป็นระเบียบอยู่เสมอด้วยคอลเล็กชัน บันทึกและจัดหมวดหมู่เนื้อหาตามค่ากำหนดของคุณ
เลือกแพลตฟอร์ม: Android iOS JavaScript

การวางซ้อนภาพพื้นดินคือการวางซ้อนบนแผนที่ที่เชื่อมโยงกับพิกัดละติจูด/ลองจิจูด ดังนั้นเราจะย้ายเมื่อคุณลากหรือซูมแผนที่

บทนำ

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

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

การเพิ่มการวางซ้อน

  1. สร้างอินสแตนซ์ออบเจ็กต์ GMSGroundOverlay ใหม่
  2. ตั้งค่าพร็อพเพอร์ตี้ icon เป็นอินสแตนซ์ UIImage
  3. ตั้งค่าพร็อพเพอร์ตี้ bounds เป็นอินสแตนซ์ GMSCoordinateBounds ขอบเขตนี้แสดงถึงทิศตะวันตกเฉียงใต้และมุมทิศตะวันออกเฉียงเหนือของรูปภาพ
  4. กําหนดพร็อพเพอร์ตี้ที่ไม่บังคับ เช่น bearing และ zoomLevel ตามที่ต้องการ
  5. ตั้งค่าพร็อพเพอร์ตี้ map โดยรูปภาพจะปรากฏในแผนที่

ตัวอย่างด้านล่างแสดงวิธีเพิ่มการวางซ้อนพื้นดินในออบเจ็กต์ GMSMapView ที่มีอยู่

Swift

let southWest = CLLocationCoordinate2D(latitude: 40.712216, longitude: -74.22655)
let northEast = CLLocationCoordinate2D(latitude: 40.773941, longitude: -74.12544)
let overlayBounds = GMSCoordinateBounds(coordinate: southWest, coordinate: northEast)

// Image from http://www.lib.utexas.edu/maps/historical/newark_nj_1922.jpg
let icon = UIImage(named: "newark_nj_1922")

let overlay = GMSGroundOverlay(bounds: overlayBounds, icon: icon)
overlay.bearing = 0
overlay.map = mapView
      

Objective-C

CLLocationCoordinate2D southWest = CLLocationCoordinate2DMake(40.712216,-74.22655);
CLLocationCoordinate2D northEast = CLLocationCoordinate2DMake(40.773941,-74.12544);
GMSCoordinateBounds *overlayBounds = [[GMSCoordinateBounds alloc] initWithCoordinate:southWest
                                                                        coordinate:northEast];

// Image from http://www.lib.utexas.edu/maps/historical/newark_nj_1922.jpg
UIImage *icon = [UIImage imageNamed:@"newark_nj_1922"];
GMSGroundOverlay *overlay = [GMSGroundOverlay groundOverlayWithBounds:overlayBounds icon:icon];
overlay.bearing = 0;
overlay.map = mapView;
      

การนําการวางซ้อนออก

คุณนําการวางซ้อนระดับพื้นออกจากแผนที่ได้โดยตั้งค่าพร็อพเพอร์ตี้ map ของ GMSGroundOverlay เป็น nil อีกวิธีหนึ่งคือนําการวางซ้อนทั้งหมดออก (รวมถึงการวางซ้อนพื้นบนแผนที่) โดยเรียกใช้เมธอด GMSMapView clear

Swift

mapView.clear()
      

Objective-C

[mapView clear];
      

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

Swift

let overlay = GMSGroundOverlay(bounds: overlayBounds, icon: icon)
overlay.bearing = 0
overlay.map = mapView

// ...

overlay.isTappable = true
      

Objective-C

GMSGroundOverlay *overlay = [GMSGroundOverlay groundOverlayWithBounds:overlayBounds icon:icon];
overlay.bearing = 0;
overlay.map = mapView;

// ...
overlay.tappable = YES;
      

กิจกรรม

คุณฟังเหตุการณ์ที่เกิดขึ้นบนแผนที่ได้ เช่น เมื่อผู้ใช้แตะการวางซ้อน หากต้องการฟังเหตุการณ์ คุณต้องใช้โปรโตคอล GMSMapViewDelegate ดูคําแนะนําเกี่ยวกับเหตุการณ์และรายการเมธอดใน GMSMapViewDelegate