我有一个纬度数组和另一个经度数组,我添加到CLLocationCoordinate2D类型的数组。然后我使用新数组来注释地图上的多个点。一些,或大多数,甚至所有注释都在地图上显示但是当我放大(是的,放大IN)时,一些注释消失,然后回来,或者不。关于如何让它们全部可见的任何想法?这是我在缩小时所期望的行为,而不是。
这是我用于上述内容的代码。
import UIKit
import MapKit
import CoreLocation
class MultiMapVC: UIViewController, CLLocationManagerDelegate {
@IBOutlet weak var multiEventMap: MKMapView!
var latDouble = Double()
var longDouble = Double()
let manager = CLLocationManager()
var receivedArrayOfLats = [Double]()
var receivedArrayOfLongs = [Double]()
var locations = [CLLocationCoordinate2D]()
func locationManager(_ manager: CLLocationManager, didUpdateLocations uLocation: [CLLocation]) {
let userLocation = uLocation[0]
let span:MKCoordinateSpan = MKCoordinateSpanMake(0.3, 0.3)
let usersLocation = userLocation.coordinate
let region:MKCoordinateRegion = MKCoordinateRegionMake(usersLocation, span)
multiEventMap.setRegion(region, animated: true)
manager.distanceFilter = 1000
self.multiEventMap.showsUserLocation = true
}
func multiPoint() {
var coordinateArray: [CLLocationCoordinate2D] = []
print ("Received Longitude Count = \(receivedArrayOfLongs.count)")
print ("Received Latitude Count = \(receivedArrayOfLats.count)")
if receivedArrayOfLats.count == receivedArrayOfLongs.count {
for i in 0 ..< receivedArrayOfLats.count {
let eventLocation = CLLocationCoordinate2DMake(receivedArrayOfLats[i], receivedArrayOfLongs[i])
coordinateArray.append(eventLocation)
print (coordinateArray.count)
}
}
for events in coordinateArray {
let annotation = MKPointAnnotation()
annotation.coordinate = CLLocationCoordinate2D(latitude: events.latitude, longitude: events.longitude)
multiEventMap.addAnnotation(annotation)
}
}
override func viewDidLoad() {
super.viewDidLoad()
manager.delegate = self
manager.desiredAccuracy = kCLLocationAccuracyBest
manager.requestWhenInUseAuthorization()
manager.startUpdatingLocation()
multiPoint()
}
override func viewDidDisappear(_ animated: Bool) {
super.viewDidDisappear(animated)
multiEventMap.removeFromSuperview()
self.multiEventMap = nil
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
}
NiltiakSivad的解决方案有效,但它恢复到旧的iOS 10外观。如果你想为iOS 11保留新的iOS 11气球标记,并且只使用旧的iOS版本,那么你可以实现如下的委托方法:
func mapView(_ mapView: MKMapView, viewFor annotation: MKAnnotation) -> MKAnnotationView? {
let reuseIdentifier = "annotationView"
var view = mapView.dequeueReusableAnnotationView(withIdentifier: reuseIdentifier)
if #available(iOS 11.0, *) {
if view == nil {
view = MKMarkerAnnotationView(annotation: annotation, reuseIdentifier: reuseIdentifier)
}
view?.displayPriority = .required
} else {
if view == nil {
view = MKPinAnnotationView(annotation: annotation, reuseIdentifier: reuseIdentifier)
}
}
view?.annotation = annotation
view?.canShowCallout = true
return view
}
我遇到了类似的问题。我最好的猜测是它与iOS 11如何检测针碰撞有关。实现自定义注释视图或恢复使用iOS 10引脚为我解决了问题。
例如,实现以下内容应修复您的代码:
class MultiMapVC: UIViewController, MKMapViewDelegate, CLLocationManagerDelegate {
override func viewDidLoad() {
super.viewDidLoad()
mapView.delegate = self
}
func mapView(_ mapView: MKMapView, viewFor annotation: MKAnnotation) -> MKAnnotationView? {
guard let annotation = annotation as? MKPointAnnotation else { return nil }
let identifier = "pin-marker"
var view: MKAnnotationView
if let dequeuedView = mapView.dequeueReusableAnnotationView(withIdentifier: identifier) as? MKPinAnnotationView {
dequeuedView.annotation = annotation
view = dequeuedView
} else {
view = MKPinAnnotationView(annotation: annotation, reuseIdentifier: identifier)
}
return view
}
}
如果这不起作用,有一个值得研究的displayPriority
属性,因为它有助于确定何时应该以不同的缩放级别隐藏/显示引脚。更多信息在https://developer.apple.com/documentation/mapkit/mkannotationview/2867298-displaypriority
希望这可以帮助。
Leszek Szary接受的答案是正确的。
但是有一些精美的印刷品。有时MKMarkerAnnotationView
s不会被渲染,即使
view.displayPriority = .required
已设定。
你所看到的是不同规则的组合。
MKAnnotationViews
从地图的顶部到底部渲染。 (无论北方在哪里都没关系)。MapKit
决定绘制重叠的MKAnnotationViews
,那么靠近底部的MKAnnotationView
被绘制在顶部(因为它稍后绘制)MKAnnotationViews
,在MKMArkerAnnotationViews
下面呈现的标题也需要空间。这些标题的渲染受到markerView.titleVisibility
的影响。如果markerView.titleVisibility
设置为.visible
(而不是默认的.adaptive
),则此标题比后来呈现的MarkerAnnotationView
更强,即使后来的MarkerAnnotationView
有displayPriority = .required
。靠近底部的MarkerAnnotationView
没有渲染。MarkerAnnotationView
具有低displayPriority
,甚至会发生这种情况。所以一个低MarkerAnnotationView
和displayPriority
的.titleVisibility = .visible
可以使MarkerAnnotationView
更接近底部,displayPriority = .required
消失。我不知道这种行为的文档。这是我在iOS 12上进行实验的结果。我的描述是简化的。
我只在首次分配MKMarkAnnotationView时才设置annotationView.displayPriority = .required
。通常这就是你应该做的所有事情,但每次重复使用单元格时设置它都会为我解决问题。