如何制作“地图中心位置”?

时间:2017-02-14 17:55:08

标签: ios swift core-location

我是编程新手。 我找到了下面的代码,除了中心位置外,它还可以做任何事情。(放大,地图,蓝点都可以。) 如果我在模拟器中运行,(城市运行),蓝点就会在页面上运行。

import UIKit
import MapKit
import CoreLocation
import Foundation

class ViewController: UIViewController, CLLocationManagerDelegate {
    @IBOutlet weak var map: MKMapView!

    var locationManager: CLLocationManager?

    override func viewDidLoad() {
        super.viewDidLoad()

        locationManager = CLLocationManager()
        locationManager!.delegate = self

        map.showsUserLocation = true

        if CLLocationManager.authorizationStatus() == .authorizedWhenInUse {
            locationManager!.startUpdatingLocation()
        } else {
            locationManager!.requestWhenInUseAuthorization()
        }
    }

    private func locationManager(manager: CLLocationManager, didChangeAuthorizationStatus status: CLAuthorizationStatus) {
        switch status {
        case .notDetermined:
            print("NotDetermined")
        case .restricted:
            print("Restricted")
        case .denied:
            print("Denied")
        case .authorizedAlways:
            print("AuthorizedAlways")
        case .authorizedWhenInUse:
            print("AuthorizedWhenInUse")
            locationManager!.startUpdatingLocation()
        }
    }

    func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {
        let location = locations.first!
        let coordinateRegion = MKCoordinateRegionMakeWithDistance(location.coordinate, 500, 500)
        map.setRegion(coordinateRegion, animated: true)
        locationManager?.stopUpdatingLocation()
        locationManager = nil
    }
}

2 个答案:

答案 0 :(得分:0)

删除

的实施
func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {

获得授权,设置map.showsUserLocation = true,然后退后。

答案 1 :(得分:0)

这是我的Swift 3代码,可以运行并经过测试。它加载mapView,询问用户的权限并放大他的位置。

import UIKit
import MapKit

class ViewController: UIViewController, CLLocationManagerDelegate {
@IBOutlet weak var mapView: MKMapView!

let locationManager = CLLocationManager()

override func viewDidLoad() {
    super.viewDidLoad()
    locationManager.delegate = self
    locationManager.desiredAccuracy = kCLLocationAccuracyNearestTenMeters
    locationManager.activityType = .automotiveNavigation
    locationManager.distanceFilter = 10.0
    mapView.showsUserLocation = true
    mapView.mapType = .standard
    self.mapView.delegate = self
}

override func viewWillAppear(_ animated: Bool) {
    super.viewWillAppear(animated)
    locationManager.requestWhenInUseAuthorization()
    locationManager.startUpdatingLocation()
}

func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {
    let userLocation:CLLocation = locations[0] as CLLocation
    locationManager.stopUpdatingLocation()
    let location = CLLocationCoordinate2D(latitude: userLocation.coordinate.latitude, longitude: userLocation.coordinate.longitude)
    let span = MKCoordinateSpanMake(0.05, 0.05)
    let region = MKCoordinateRegion (center:  location,span: span)       
    mapView.setRegion(region, animated: true)
}
}