我已经为以下内容导入了 JSON countries
:
Country.json(示例)
[
{
display_name: "France",
timezone: "placeholder",
longitude: 13.33,
latitude: 15.34
},
{
display_name: "California",
timezone: "EST",
longitude: 33.33,
latitude: 12.34
},
]
我有一个函数getAnnotated
可以遍历国家以制作AnnotatedItem
. 它用于Map
并循环通过item
以实际创建MapAnnotation
. 然后item
传递给辅助函数getCountry
。我过滤countries
以获取与 具有相同display_name
字段的国家/地区item
。
所需的行为是在每个国家/地区都有一个注释/标记,点击该注释将弹出一个提供国家信息的模式/表格。
我的问题是,如果我放大并且屏幕上只有一个注释/标记,则单击它时会显示正确的国家/地区。
如果我缩小地图并且有多个注释,我点击的每个注释都会为每个注释弹出相同的country
信息。我认为我循环的方式有问题。
var countries = Bundle.main.decode("Countries.json")
struct AnnotatedItem: Identifiable {
let id = UUID()
var name: String
var coordinate: CLLocationCoordinate2D
}
struct MapView: View {
@State var showSheet = false
@State private var region = MKCoordinateRegion(
center: CLLocationCoordinate2D(
latitude: 25.7617,
longitude: 80.1918
),
span: MKCoordinateSpan(
latitudeDelta: 10,
longitudeDelta: 10
)
)
func getAnnotated() -> [AnnotatedItem] {
var pointsOfInterest = [AnnotatedItem]()
for i in countries {
pointsOfInterest.append(AnnotatedItem(name: i.display_name, coordinate: .init(latitude: i.latitude, longitude: i.longitude)))
}
return pointsOfInterest
}
func getCountry(newItem: AnnotatedItem) -> Country {
let country = countries.filter{ $0.display_name == newItem.name }
return country[0]
}
var body: some View {
Map(coordinateRegion: $region, annotationItems: getAnnotated()) { item in
MapAnnotation(coordinate: item.coordinate) {
Button(action: {
showSheet.toggle()
}){
Image(systemName: "airplane")
.foregroundColor(.white)
.padding()
}
.background(Circle())
.foregroundColor(Color.green)
.sheet(isPresented: $showSheet) {
SheetView(country: getCountry(newItem: item))
}
}
}
}
}