
เครื่องหมายระบุตำแหน่งเดียวบนแผนที่
โดยค่าเริ่มต้น เครื่องหมายจะใช้ไอคอนมาตรฐานที่มีรูปลักษณ์และความรู้สึกของ Google Maps ทั่วไป หากต้องการปรับแต่งเครื่องหมาย คุณสามารถเปลี่ยนสีของเครื่องหมายเริ่มต้น หรือแทนที่รูปภาพเครื่องหมายด้วยไอคอนที่กำหนดเอง หรือเปลี่ยนคุณสมบัติอื่นๆ ของเครื่องหมาย
คุณสามารถเปิดหน้าต่างข้อมูลเพื่อตอบสนองต่อเหตุการณ์การคลิกบนเครื่องหมายได้ หน้าต่างข้อมูลจะแสดงข้อความหรือรูปภาพในหน้าต่างโต้ตอบเหนือเครื่องหมาย คุณสามารถใช้กรอบข้อมูลเริ่มต้นเพื่อแสดงข้อความ หรือสร้างกรอบข้อมูลที่กำหนดเองเพื่อควบคุมเนื้อหาได้อย่างสมบูรณ์
การเพิ่มเครื่องหมาย
หากต้องการเพิ่มเครื่องหมาย ให้สร้างออบเจ็กต์ GMSMarker ที่มี position และ title แล้วตั้งค่า map
ตัวอย่างต่อไปนี้แสดงวิธีเพิ่มเครื่องหมายลงในออบเจ็กต์ GMSMapView ที่มีอยู่ ระบบจะสร้างเครื่องหมายที่พิกัด 10,10 และแสดงสตริง "Hello World" ในหน้าต่างข้อมูลเมื่อมีการคลิก
Swift
let position = CLLocationCoordinate2D(latitude: 10, longitude: 10) let marker = GMSMarker(position: position) marker.title = "Hello World" marker.map = mapView
Objective-C
CLLocationCoordinate2D position = CLLocationCoordinate2DMake(10, 10); GMSMarker *marker = [GMSMarker markerWithPosition:position]; marker.title = @"Hello World"; marker.map = mapView;
คุณสร้างภาพเคลื่อนไหวของการเพิ่มเครื่องหมายใหม่ลงในแผนที่ได้โดยการตั้งค่าพร็อพเพอร์ตี้ marker.appearAnimation เป็นค่าต่อไปนี้
kGMSMarkerAnimationPopเพื่อทำให้เครื่องหมายปรากฏจากgroundAnchorเมื่อเพิ่มkGMSMarkerAnimationFadeInเพื่อทําให้เครื่องหมายค่อยๆ ปรากฏขึ้นเมื่อเพิ่ม
นำเครื่องหมายออก
คุณนำเครื่องหมายออกจากแผนที่ได้โดยการตั้งค่าพร็อพเพอร์ตี้ map ของ
GMSMarker เป็น nil หรือจะนําการวางซ้อนทั้งหมด (รวมถึงเครื่องหมาย) ที่แสดงอยู่ในแผนที่ออกโดยเรียกใช้เมธอด GMSMapView clear ก็ได้
Swift
let camera = GMSCameraPosition.camera( withLatitude: -33.8683, longitude: 151.2086, zoom: 6 ) let mapView = GMSMapView.map(withFrame: .zero, camera: camera) // ... mapView.clear()
Objective-C
GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:-33.8683 longitude:151.2086 zoom:6]; mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera]; // ... [mapView clear];
หากต้องการแก้ไขเครื่องหมายหลังจากที่เพิ่มลงในแผนที่แล้ว ให้จับวัตถุ GMSMarker ไว้ คุณจะแก้ไขเครื่องหมายได้ภายหลังโดยทำการเปลี่ยนแปลงออบเจ็กต์นี้
Swift
let position = CLLocationCoordinate2D(latitude: 10, longitude: 10) let marker = GMSMarker(position: position) marker.map = mapView // ... marker.map = nil
Objective-C
CLLocationCoordinate2D position = CLLocationCoordinate2DMake(10, 10); GMSMarker *marker = [GMSMarker markerWithPosition:position]; marker.map = mapView; // ... marker.map = nil;
การเปลี่ยนสีเครื่องหมาย
คุณสามารถปรับแต่งสีของรูปภาพเครื่องหมายเริ่มต้นได้โดยขอไอคอนเริ่มต้นเวอร์ชันที่มีสีด้วย markerImageWithColor: และส่งรูปภาพที่ได้ไปยังพร็อพเพอร์ตี้ไอคอนของ GMSMarker
Swift
marker.icon = GMSMarker.markerImage(with: .black)
Objective-C
marker.icon = [GMSMarker markerImageWithColor:[UIColor blackColor]];
การปรับแต่งรูปภาพเครื่องหมาย
หากต้องการเปลี่ยนรูปภาพเครื่องหมายเริ่มต้น คุณสามารถตั้งค่าไอคอนที่กำหนดเองได้โดยใช้พร็อพเพอร์ตี้ icon หรือ iconView ของเครื่องหมาย หากตั้งค่าเป็น iconView API จะละเว้นพร็อพเพอร์ตี้ icon
การใช้พร็อพเพอร์ตี้ icon ของเครื่องหมาย
ข้อมูลโค้ดต่อไปนี้สร้างเครื่องหมายที่มีไอคอนที่กำหนดเองซึ่งระบุเป็น UIImage ในพร็อพเพอร์ตี้ icon ไอคอนจะอยู่ที่กึ่งกลางของลอนดอน ประเทศอังกฤษ ข้อมูลโค้ดจะถือว่าแอปพลิเคชันของคุณมีรูปภาพชื่อ "house.png"
Swift
let positionLondon = CLLocationCoordinate2D(latitude: 51.5, longitude: -0.127) let london = GMSMarker(position: positionLondon) london.title = "London" london.icon = UIImage(named: "house") london.map = mapView
Objective-C
CLLocationCoordinate2D positionLondon = CLLocationCoordinate2DMake(51.5, -0.127); GMSMarker *london = [GMSMarker markerWithPosition:positionLondon]; london.title = @"London"; london.icon = [UIImage imageNamed:@"house"]; london.map = mapView;
หากสร้างเครื่องหมายหลายรายการที่มีรูปภาพเดียวกัน ให้ใช้อินสแตนซ์ UIImage เดียวกันสำหรับเครื่องหมายแต่ละรายการ ซึ่งจะช่วยปรับปรุงประสิทธิภาพของแอปพลิเคชันเมื่อแสดงเครื่องหมายจำนวนมาก
รูปภาพนี้อาจมีหลายเฟรม นอกจากนี้ ระบบจะพิจารณาพร็อพเพอร์ตี้ alignmentRectInsets ด้วย ซึ่งมีประโยชน์ในกรณีที่เครื่องหมายมีเงาหรือภูมิภาคอื่นๆ ที่ใช้ไม่ได้
การใช้พร็อพเพอร์ตี้ iconView ของเครื่องหมาย
ข้อมูลโค้ดต่อไปนี้จะสร้างเครื่องหมายที่มีไอคอนที่กำหนดเองโดยการตั้งค่าพร็อพเพอร์ตี้ iconView ของเครื่องหมาย และแสดงภาพเคลื่อนไหวการเปลี่ยนแปลงสีของเครื่องหมาย
ข้อมูลโค้ดจะถือว่าแอปพลิเคชันของคุณมีรูปภาพชื่อ "house.png"
Swift
import CoreLocation import GoogleMaps class MarkerViewController: UIViewController, GMSMapViewDelegate { var mapView: GMSMapView! var london: GMSMarker? var londonView: UIImageView? override func viewDidLoad() { super.viewDidLoad() let camera = GMSCameraPosition.camera( withLatitude: 51.5, longitude: -0.127, zoom: 14 ) let mapView = GMSMapView.map(withFrame: .zero, camera: camera) view = mapView mapView.delegate = self let house = UIImage(named: "House")!.withRenderingMode(.alwaysTemplate) let markerView = UIImageView(image: house) markerView.tintColor = .red londonView = markerView let position = CLLocationCoordinate2D(latitude: 51.5, longitude: -0.127) let marker = GMSMarker(position: position) marker.title = "London" marker.iconView = markerView marker.tracksViewChanges = true marker.map = mapView london = marker } func mapView(_ mapView: GMSMapView, idleAt position: GMSCameraPosition) { UIView.animate(withDuration: 5.0, animations: { () -> Void in self.londonView?.tintColor = .blue }, completion: {(finished) in // Stop tracking view changes to allow CPU to idle. self.london?.tracksViewChanges = false }) } }
Objective-C
@import CoreLocation; @import GoogleMaps; @interface MarkerViewController : UIViewController <GMSMapViewDelegate> @property (strong, nonatomic) GMSMapView *mapView; @end @implementation MarkerViewController { GMSMarker *_london; UIImageView *_londonView; } - (void)viewDidLoad { [super viewDidLoad]; GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:51.5 longitude:-0.127 zoom:14]; _mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera]; self.view = _mapView; _mapView.delegate = self; UIImage *house = [UIImage imageNamed:@"House"]; house = [house imageWithRenderingMode:UIImageRenderingModeAlwaysTemplate]; _londonView = [[UIImageView alloc] initWithImage:house]; _londonView.tintColor = [UIColor redColor]; CLLocationCoordinate2D position = CLLocationCoordinate2DMake(51.5, -0.127); _london = [GMSMarker markerWithPosition:position]; _london.title = @"London"; _london.iconView = _londonView; _london.tracksViewChanges = YES; _london.map = self.mapView; } - (void)mapView:(GMSMapView *)mapView idleAtCameraPosition:(GMSCameraPosition *)position { [UIView animateWithDuration:5.0 animations:^{ self->_londonView.tintColor = [UIColor blueColor]; } completion:^(BOOL finished) { // Stop tracking view changes to allow CPU to idle. self->_london.tracksViewChanges = NO; }]; } @end
เนื่องจาก iconView ยอมรับ UIView คุณจึงมีลําดับชั้นของการควบคุม UI มาตรฐานที่กําหนดเครื่องหมายได้ โดยแต่ละมุมมองจะมีชุดความสามารถภาพเคลื่อนไหวมาตรฐาน คุณสามารถรวมการเปลี่ยนแปลงขนาด สี และระดับอัลฟาของตัวทำเครื่องหมาย รวมถึงใช้การเปลี่ยนรูปแบบแบบกำหนดเองได้ พร็อพเพอร์ตี้ iconViewรองรับภาพเคลื่อนไหวของพร็อพเพอร์ตี้ทั้งหมดที่เคลื่อนไหวได้ของ UIView ยกเว้น frame และ center
โปรดคำนึงถึงข้อควรพิจารณาต่อไปนี้เมื่อใช้ iconView
UIViewอาจใช้ทรัพยากรมากเมื่อตั้งค่าtracksViewChangesเป็นYESซึ่งอาจส่งผลให้ใช้แบตเตอรี่มากขึ้น ในทางกลับกัน เฟรมเดี่ยวUIImageจะเป็นแบบคงที่และไม่จำเป็นต้องแสดงผลอีกครั้ง- อุปกรณ์บางรุ่นอาจแสดงผลแผนที่ได้ยากหากคุณมีเครื่องหมายบนหน้าจอหลายรายการ โดยแต่ละเครื่องหมายมี
UIViewเป็นของตัวเอง และเครื่องหมายทั้งหมดติดตามการเปลี่ยนแปลงพร้อมกัน iconViewไม่ตอบสนองต่อการโต้ตอบของผู้ใช้ เนื่องจากเป็นภาพรวมของมุมมอง- มุมมองจะทํางานราวกับว่ามีการกําหนด
clipsToBoundsเป็นYESโดยไม่คำนึงถึงค่าจริง คุณใช้การเปลี่ยนรูปแบบที่ทำงานนอกขอบเขตได้ แต่วัตถุที่คุณวาดต้องอยู่ภายในขอบเขตของวัตถุ ระบบจะตรวจสอบและนําการเปลี่ยนรูปแบบ/การเปลี่ยนทั้งหมดไปใช้ กล่าวโดยย่อคือ มุมมองย่อยต้องอยู่ภายในมุมมอง - หากต้องการใช้
-copyWithZone:ในGMSMarkerคุณต้องคัดลอกGMSMarkerก่อน จากนั้นตั้งค่าอินสแตนซ์ใหม่ของiconViewในรายการที่คัดลอกUIViewไม่รองรับNSCopyingจึงคัดลอกiconViewไม่ได้
หากต้องการตัดสินใจว่าควรตั้งค่าพร็อพเพอร์ตี้ tracksViewChanges เมื่อใด คุณควรพิจารณาถึงข้อควรพิจารณาด้านประสิทธิภาพเทียบกับข้อดีของการวาดเครื่องหมายใหม่โดยอัตโนมัติ เช่น
- หากต้องการเปลี่ยนแปลงหลายรายการ ให้เปลี่ยนพร็อพเพอร์ตี้เป็น
YESแล้วเปลี่ยนกลับเป็นNO - เมื่อภาพเคลื่อนไหวทำงานอยู่หรือระบบกำลังโหลดเนื้อหาแบบไม่ประสานเวลา คุณควรตั้งค่าพร็อพเพอร์ตี้เป็น
YESต่อไปจนกว่าการดำเนินการจะเสร็จสมบูรณ์
การเปลี่ยนความทึบแสงของเครื่องหมาย
คุณควบคุมระดับความทึบของมาร์กเกอร์ได้ด้วยพร็อพเพอร์ตี้ opacity คุณควรระบุความทึบแสงเป็นค่าลอยระหว่าง 0.0 ถึง 1.0 โดยที่ 0 คือโปร่งแสงทั้งหมด และ 1 คือทึบแสงทั้งหมด
Swift
marker.opacity = 0.6
Objective-C
marker.opacity = 0.6;
คุณทำให้ความทึบของหมุดเคลื่อนไหวได้ด้วย Core Animation โดยใช้ GMSMarkerLayer
การผสานเครื่องหมาย
โดยปกติแล้ว ไอคอนเครื่องหมายจะวาดขึ้นโดยวางแนวตามหน้าจอของอุปกรณ์ ไม่ใช่พื้นผิวของแผนที่ ดังนั้นการหมุน การเอียง หรือการซูมแผนที่จึงไม่ได้เปลี่ยนการวางแนวของเครื่องหมายเสมอไป
คุณสามารถตั้งค่าการวางแนวของเครื่องหมายให้วางราบกับพื้นโลกได้ เครื่องหมายบนพื้นผิวจะหมุนเมื่อแผนที่หมุน และเปลี่ยนมุมมองเมื่อแผนที่เอียง เครื่องหมายแบนจะคงขนาดไว้เมื่อซูมแผนที่เข้าหรือออก เช่นเดียวกับเครื่องหมายทั่วไป
หากต้องการเปลี่ยนการวางแนวของเครื่องหมาย ให้ตั้งค่าพร็อพเพอร์ตี้ flat ของเครื่องหมายเป็น YES หรือ true
Swift
let positionLondon = CLLocationCoordinate2D(latitude: 51.5, longitude: -0.127) let londonMarker = GMSMarker(position: positionLondon) londonMarker.isFlat = true londonMarker.map = mapView
Objective-C
CLLocationCoordinate2D positionLondon = CLLocationCoordinate2DMake(51.5, -0.127); GMSMarker *londonMarker = [GMSMarker markerWithPosition:positionLondon]; londonMarker.flat = YES; londonMarker.map = mapView;
การหมุนเครื่องหมาย
คุณสามารถหมุนเครื่องหมายรอบจุดยึดได้โดยการตั้งค่าพร็อพเพอร์ตี้ rotation
ระบุการหมุนเป็นประเภท CLLocationDegrees ซึ่งวัดเป็นองศาตามเข็มนาฬิกาจากตำแหน่งเริ่มต้น เมื่อเครื่องหมายวางราบบนแผนที่ ตำแหน่งเริ่มต้นคือทิศเหนือ
ตัวอย่างต่อไปนี้จะหมุนเครื่องหมาย 90° การตั้งค่าพร็อพเพอร์ตี้ groundAnchor เป็น 0.5,0.5 จะทำให้เครื่องหมายหมุนรอบจุดศูนย์กลางแทนฐาน
Swift
let degrees = 90.0 londonMarker.groundAnchor = CGPoint(x: 0.5, y: 0.5) londonMarker.rotation = degrees londonMarker.map = mapView
Objective-C
CLLocationDegrees degrees = 90; londonMarker.groundAnchor = CGPointMake(0.5, 0.5); londonMarker.rotation = degrees; londonMarker.map = mapView;
การจัดการเหตุการณ์บนเครื่องหมาย
คุณสามารถฟังเหตุการณ์ที่เกิดขึ้นบนแผนที่ เช่น เมื่อผู้ใช้แตะเครื่องหมาย หากต้องการตรวจสอบเหตุการณ์ คุณต้องติดตั้งใช้งานโปรโตคอล GMSMapViewDelegate ดูวิธีจัดการเหตุการณ์เครื่องหมายที่เฉพาะเจาะจงได้ที่เหตุการณ์เครื่องหมายและท่าทางสัมผัส คู่มือเกี่ยวกับเหตุการณ์ยังมีรายการเมธอดใน GMSMapViewDelegate ด้วย สำหรับกิจกรรม Street View โปรดดู
GMSPanoramaViewDelegate