我尝试使用MapKit和CoreLocation获取用户当前位置。我对Objective-C很陌生。至于我的研究,实现与旧的iOS到iOS 8.0略有不同。我已经正确地遵循了一切。它仍然是当前的位置。我的实际目标是在用户在文本字段中给出位置时,在运行时获取mapKit上的pin用户位置。
filename.h
#import <UIKit/UIKit.h>
#import <MapKit/MapKit.h>
@interface LocationSelectionViewController : UIViewController <CLLocationManagerDelegate>
@property (weak, nonatomic) IBOutlet UITextField *insertLocation;
@property (strong, nonatomic) IBOutlet MKMapView *serviceLocation;
- (IBAction)next:(id)sender;
@end
#import "LocationSelectionViewController.h"
#import <CoreLocation/CoreLocation.h>
@interface LocationSelectionViewController () <CLLocationManagerDelegate>
@end
@implementation LocationSelectionViewController
CLLocationManager *locationManager;
@synthesize serviceLocation;
- (void)viewDidLoad {
[super viewDidLoad];
locationManager = [[CLLocationManager alloc] init];
locationManager.delegate = self;
[locationManager requestAlwaysAuthorization];
[locationManager startUpdatingLocation];
// Do any additional setup after loading the view.
self.serviceLocation = [[MKMapView alloc] initWithFrame:self.view.bounds];
self.serviceLocation.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
[self.view addSubview:self.serviceLocation];
[self.serviceLocation.delegate self];
//[self.serviceLocation setShowsUserLocation:YES];
}
/*- (void)mapView:(MKMapView *)mapView didUpdateUserLocation:(MKUserLocation *)userLocation{
CLLocationCoordinate2D loc=[userLocation coordinate];
MKCoordinateRegion region = MKCoordinateRegionMakeWithDistance(loc, 100, 100);
[self.serviceLocation setRegion:region animated:YES];
}*/
-(void) locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray<CLLocation *> *)locations{
[locationManager requestAlwaysAuthorization];
[locationManager startUpdatingLocation];
}
-(void) locationManager:(CLLocationManager *)manager didChangeAuthorizationStatus:(CLAuthorizationStatus)status{
if(status == kCLAuthorizationStatusAuthorizedAlways || status == kCLAuthorizationStatusAuthorizedWhenInUse){
self.serviceLocation.showsUserLocation = YES;
}
}
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
/*
#pragma mark - Navigation
// In a storyboard-based application, you will often want to do a little preparation before navigation
- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender {
// Get the new view controller using [segue destinationViewController].
// Pass the selected object to the new view controller.
}
*/
- (IBAction)next:(id)sender {
}
@end
在图像中,我根据iOS 8要求添加了两个属性。
任何人都可以建议我存档:
答案 0 :(得分:1)
请求和启动位置更新的流程不正确。首先,requestAlwaysAuthorization
不会立即更改授权状态,因为它需要用户在警报中按Allow
或Don't Allow
按钮。因此,您应该在获得结果后才开始更新位置。然后在didUpdateLocations
中无需再次请求/重新开始。
以下列方式进行,
你的viewDidLoad
BOOL isAuthorized = [CLLocationManager authorizationStatus] == kCLAuthorizationStatusAuthorizedAlways;
if (isAuthorized) {
[locationManager startUpdatingLocation];
}
else {
[locationManager requestAlwaysAuthorization];
}
并实现委托方法,如
- (void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray<CLLocation *> *)locations {
CLLocation *current = locations.firstObject;
}
- (void)locationManager:(CLLocationManager *)manager didChangeAuthorizationStatus:(CLAuthorizationStatus)status{
if(status == kCLAuthorizationStatusAuthorizedAlways || status == kCLAuthorizationStatusAuthorizedWhenInUse){
self.serviceLocation.showsUserLocation = YES;
[locationManager startUpdatingLocation];
}
}
在iOS 8中,如果要请求权限,则应在info.plist
中添加使用说明字符串。在您的情况下,密钥为NSLocationAlwaysUsageDescription
。