MapViewModel.swift 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. //
  2. // MapViewModel.swift
  3. // Runner
  4. //
  5. // Created by Groot on 2025/5/7.
  6. //
  7. import Flutter
  8. import Foundation
  9. import MapKit
  10. import CoreLocation
  11. import SwiftUI
  12. import Combine
  13. private let coordinates: [CLLocationCoordinate2D] = [
  14. CLLocationCoordinate2D(latitude: 39.90333, longitude: 116.39167), // 北京
  15. CLLocationCoordinate2D(latitude: 31.23170, longitude: 121.47264), // 上海
  16. CLLocationCoordinate2D(latitude: 22.54554, longitude: 114.05786), // 深圳
  17. CLLocationCoordinate2D(latitude: 23.12911, longitude: 113.26437), // 广州
  18. CLLocationCoordinate2D(latitude: 30.59276, longitude: 114.30525), // 武汉
  19. ]
  20. class MapViewModel: NSObject, ObservableObject, MapCapability {
  21. var paramsDecodeError: FlutterError? = FlutterError(code: "InvalidArguments", message: "Invalid arguments", details: nil)
  22. var methodChannel: FlutterMethodChannel?
  23. @Published var currentRegion: MKCoordinateRegion?
  24. // 记录用户位置
  25. @Published var userLocation: CLLocationCoordinate2D?
  26. // 地图Marker
  27. @Published var markers: [ATMapMarker] = []
  28. // 地图Polyline
  29. @Published var polylines: [ATMapPolyline] = []
  30. func initialize(args: [String: Any]?, result: @escaping FlutterResult) {
  31. result(true)
  32. return
  33. }
  34. // 处理地图移动
  35. func handleMapMoveCamera(args: [String: Any]?, result: @escaping FlutterResult) {
  36. guard let args = args, let cameraPosition = ATMapCameraPosition.fromJson(json: args) else {
  37. result(paramsDecodeError)
  38. return
  39. }
  40. let center = CLLocationCoordinate2D(latitude: cameraPosition.latitude, longitude: cameraPosition.longitude)
  41. let span = MKCoordinateSpan(latitudeDelta: cameraPosition.zoom, longitudeDelta: cameraPosition.zoom)
  42. currentRegion = MKCoordinateRegion(center: center, span: span)
  43. result(nil)
  44. }
  45. // 处理地图添加Marker
  46. func handleMapAddMarker(args: [String: Any]?, result: @escaping FlutterResult) {
  47. guard let args = args, let marker = ATMapMarker.fromJson(json: args) else {
  48. result(paramsDecodeError)
  49. return
  50. }
  51. // 检查是否已存在相同ID的标记,如果有则先移除
  52. if let index = markers.firstIndex(where: { $0.id == marker.id }) {
  53. markers.remove(at: index)
  54. }
  55. markers.append(marker)
  56. result(nil)
  57. }
  58. // 处理地图清除Marker
  59. func handleMapClearMarkers(result: @escaping FlutterResult) {
  60. markers = []
  61. result(nil)
  62. }
  63. // 处理地图替换所有Marker
  64. func handleMapReplaceAllMarkers(args: [String: Any]?, result: @escaping FlutterResult) {
  65. defer {
  66. result(nil)
  67. }
  68. guard let args = args, let markers = args["markers"] as? [[String: Any]] else {
  69. result(paramsDecodeError)
  70. return
  71. }
  72. let mapMarkers = markers.compactMap({ ATMapMarker.fromJson(json: $0) })
  73. self.markers = mapMarkers
  74. }
  75. // 处理Marker点击事件
  76. func handleMarkerTap(marker: inout ATMapMarker) {
  77. toggleMarkerSelected(marker: &marker)
  78. methodChannel?.invokeMethod(ChannelMethods.methodMarkerOnTap.rawValue, arguments: marker.toJson())
  79. }
  80. // 处理地图添加Polyline
  81. func handleMapAddPolyline(args: [String: Any]?, result: @escaping FlutterResult) {
  82. guard let args = args, let polyline = ATMapPolyline.fromJson(json: args) else {
  83. result(paramsDecodeError)
  84. return
  85. }
  86. polylines.append(polyline)
  87. result(nil)
  88. }
  89. }
  90. // Propertie Action
  91. extension MapViewModel {
  92. func toggleMarkerSelected(marker: inout ATMapMarker) {
  93. marker.isSelected = !marker.isSelected
  94. }
  95. }