MapViewModel.swift 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  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 zoome = cameraPosition.zoom / 10000
  42. let span = MKCoordinateSpan(latitudeDelta: zoome, longitudeDelta: zoome)
  43. currentRegion = MKCoordinateRegion(center: center, span: span)
  44. result(nil)
  45. }
  46. // 处理地图添加Marker
  47. func handleMapAddMarker(args: [[String: Any]]?, result: @escaping FlutterResult) {
  48. guard let args = args, let markers = [ATMapMarker].fromJson(json: args) else {
  49. result(paramsDecodeError)
  50. return
  51. }
  52. self.markers = markers
  53. result(nil)
  54. }
  55. // 处理地图清除Marker
  56. func handleMapClearMarkers(result: @escaping FlutterResult) {
  57. markers = []
  58. result(nil)
  59. }
  60. // 处理地图替换所有Marker
  61. func handleMapReplaceAllMarkers(args: [String: Any]?, result: @escaping FlutterResult) {
  62. defer {
  63. result(nil)
  64. }
  65. guard let args = args, let markers = args["markers"] as? [[String: Any]] else {
  66. result(paramsDecodeError)
  67. return
  68. }
  69. let mapMarkers = markers.compactMap({ ATMapMarker.fromJson(json: $0) })
  70. self.markers = mapMarkers
  71. }
  72. // 处理Marker点击事件
  73. func handleMarkerTap(marker: inout ATMapMarker) {
  74. toggleMarkerSelected(marker: &marker)
  75. methodChannel?.invokeMethod(ChannelMethods.methodMarkerOnTap.rawValue, arguments: marker.toJson())
  76. }
  77. // 处理地图添加Polyline
  78. func handleMapAddPolyline(args: [String: Any]?, result: @escaping FlutterResult) {
  79. guard let args = args, let polyline = ATMapPolyline.fromJson(json: args) else {
  80. result(paramsDecodeError)
  81. return
  82. }
  83. polylines.append(polyline)
  84. result(nil)
  85. }
  86. }
  87. // Propertie Action
  88. extension MapViewModel {
  89. func toggleMarkerSelected(marker: inout ATMapMarker) {
  90. marker.isSelected = !marker.isSelected
  91. }
  92. }