大佬教程收集整理的这篇文章主要介绍了没有 UIViewRepresentable 的 SwiftUI 地图覆盖,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我尝试仅使用 iOS 14 SwiftUI 地图创建带有注释和叠加层的地图视图。我设法创建了注释,但由于缺少来自 MKMapVIEw 委托的 MKOverlayRenderer,我无法创建可见的叠加层。如何附加到 Map 视图委托以便它可以运行其方法
Map(coordinateRegion: $region,showsUserLOCATIOn: true,userTrackingMode: $userTrackingMode,AnnotationItems: Annotations)) { Annotation in
MapAnnotation(coordinate: CLLOCATIOnCoordinate2DMake(Annotation.latitude,Annotation.longitudE),anchorPoint: CGPoint(x: 0.5,y: 0.7)) {
Navigationlink(desTination: DetailsVIEw()) {
vstack {
Image(systemname: "mappin")
.Font(.titlE)
.foregroundcolor(.red)
Text(Annotation.name.split(separator: " ").joined(separator: "\n"))
.Font(.caption)
.bold()
.multilineTextAlignment(.center)
.foregroundcolor(.black)
.padding(2)
.BACkground(RoundedRectangle(cornerRadius: 4).fill(color.white.opacity(0.8)))
.layoutPriority(1)
}
}
}
}
.addOverlays(mapOverlays,delegate: mapDelegatE)
和地图扩展方法:
extension Map {
func addOverlays(_ overlays: [MKOverlay],delegate: MKMapVIEwDelegatE) -> some VIEw {
// MKMapVIEw.appearance().delegate = delegate // THIS DOES NOT WORK AT ALL
MKMapVIEw.appearance().addOverlays(overlays)
return self
}
}
和委托:
class MapDelegate: NSObject,MKMapVIEwDelegate {
func mapVIEw(_ mapVIEw: MKMapVIEw,rendererFor overlay: MKOverlay) -> MKOverlayRenderer {
if overlay is MKCircle {
let circle = MKCircleRenderer(overlay: overlay)
circle.strokecolor = .systemRed
circle.fillcolor = .systemRed
circle.Alpha = 0.2
circle.linewidth = 1
return circle
}
return MKOverlayRenderer()
}
}
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)
以上是大佬教程为你收集整理的没有 UIViewRepresentable 的 SwiftUI 地图覆盖全部内容,希望文章能够帮你解决没有 UIViewRepresentable 的 SwiftUI 地图覆盖所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。