为什么这个函数会循环?

时间:2015-11-02 04:40:13

标签: ios swift logic mapkit

func centerMapOnLocation(location: CLLocation) {
    let coordinateRegion = MKCoordinateRegionMakeWithDistance(location.coordinate,
        regionRadius * 2.0, regionRadius * 2.0)
    MapOutlet.setRegion(coordinateRegion, animated: true)
}

上面我的视图控制器中的这个函数继续运行,虽然我从来没有编写任何循环,有人可以帮助发现不正确的逻辑。这是视图控制器的其余部分

import UIKit
import MapKit
import CoreLocation


class ViewControllerPublic: UIViewController, CLLocationManagerDelegate {
let locationManager = CLLocationManager()



let initialLocation = CLLocation(latitude: 3.632488, longitude: -117.898886)
override func viewDidLoad() {
    super.viewDidLoad()
    centerMapOnLocation(initialLocation)

    // Ask for Authorisation from the User.
    self.locationManager.requestAlwaysAuthorization()

    // For use in foreground
    self.locationManager.requestWhenInUseAuthorization()

    if CLLocationManager.locationServicesEnabled() {
        locationManager.delegate = self
        locationManager.desiredAccuracy = kCLLocationAccuracyNearestTenMeters
        locationManager.startUpdatingLocation()
    }

}

func locationManager(manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {
    let locValue:CLLocationCoordinate2D = manager.location!.coordinate
    print("locations = \(locValue.latitude) \(locValue.longitude)")
    let currentLocation = CLLocation(latitude: locValue.latitude, longitude: locValue.longitude)
    centerMapOnLocation(currentLocation)
}

let regionRadius: CLLocationDistance = 2300
func centerMapOnLocation(location: CLLocation) {
    let coordinateRegion = MKCoordinateRegionMakeWithDistance(location.coordinate,
        regionRadius * 2.0, regionRadius * 2.0)
    MapOutlet.setRegion(coordinateRegion, animated: true)
}

@IBOutlet weak var MapOutlet: MKMapView!

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}

}

1 个答案:

答案 0 :(得分:1)

你永远不会使CLLocation manager无效,所以@Ashish Kakkad说,每当你得到最轻微的位置改变,你的功能就会被再次召唤。如果您不想要此行为,那么在获得didUpdateLocations中的位置后,您需要执行locationManager.stopUpdatingLocation()。或者,如果您希望每次位置更改时您的应用都更新地图,您可能需要考虑更改所需的位置准确性。