美文网首页
CoreLocation框架的简单实用

CoreLocation框架的简单实用

作者: 七里田间的守望者 | 来源:发表于2017-09-17 18:34 被阅读14次

    使用须知

    image.png
    • 使用定位功能由于牵涉到用户的隐私所以要在info.plist文件中设置
      Privacy - Location Usage Description 使用定位的描述

    简单的定位

    #pragma mark - 懒加载
    - (CLLocationManager *)lM
    {
        if (!_lM) {
            // 1. 创建位置管理者
            _lM = [[CLLocationManager alloc] init];
            _lM.delegate = self;//设置代理
            
            // 每隔多米定位一次
    //        _lM.distanceFilter = 100;
            /**
               kCLLocationAccuracyBestForNavigation // 最适合导航
               kCLLocationAccuracyBest; // 最好的
               kCLLocationAccuracyNearestTenMeters; // 10m
               kCLLocationAccuracyHundredMeters; // 100m
               kCLLocationAccuracyKilometer; // 1000m
               kCLLocationAccuracyThreeKilometers; // 3000m
             */
            // 精确度越高, 越耗电, 定位时间越长
            _lM.desiredAccuracy = kCLLocationAccuracyBest;
    
            //iOS 7.0之前可以按照上面这种方法去设置
            //iOS 8.0以后的就要多做一件事情就是请求授权
        if([[UIDevice currentDevice].systemVersion floatValue] >= 8.0)
            {
                // [_lM requestWhenInUseAuthorization];  当使用的时候请求授权
                // 当前的授权状态为前台授权时,此方法也会有效
                [_lM requestAlwaysAuthorization];//一直请求授权
    
            }
     // 允许后台获取用户位置(iOS9.0)
             if([[UIDevice currentDevice].systemVersion floatValue] >= 9.0)
             {
                 // 一定要勾选后台模式 location updates
                 _lM.allowsBackgroundLocationUpdates = YES;
             }
        }
        return _lM;
    }
    
    ###然后再使用定位的方法中调用就
    [self.lM startUpdatingLocation];//就可以请求定位了
    

    请求到的定位信息在代理方法里面

    #pragma mark - CLLocationManagerDelegate
    /**
     *  更新到位置之后调用
     *
     *  @param manager   位置管理者
     *  @param locations 位置数组
     */
    -(void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations
    {
        NSLog(@"定位到了");
        
        // 拿到位置,做一些业务逻辑操作
        /**
         *  CLLocation 详解
         *  coordinate : 经纬度
         *  altitude : 海拔
         *  course : 航向
         *  speed ; 速度
         */
        //拿到对象后你可以对里面的属性进行使用
       //CLLocation的这个方法 distanceFromLocation 是计算当前位置和之前位置的距离
        CLLocation *location = [locations lastObject];
        
        // 停止更新
    //    [manager stopUpdatingLocation];
        
        
        
    }
    
    // 定位失败
    -(void)locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error
    {
        NSLog(@"定位失败");
    }
    
    #pragma mark - CLLocationManagerDelegate
    /**
     *  获取到手机朝向时调用
     *
     *  @param manager    位置管理者
     *  @param newHeading 朝向对象
     */
    -(void)locationManager:(CLLocationManager *)manager didUpdateHeading:(CLHeading *)newHeading
    {
        /**
         *  CLHeading 
         *  magneticHeading : 磁北角度
         *  trueHeading : 真北角度
         */
        
        NSLog(@"%f", newHeading.magneticHeading);
        
        CGFloat angle = newHeading.magneticHeading;
        
        // 把角度转弧度
        CGFloat angleR = angle / 180.0 * M_PI;
        //利用角度的转换可以实现指南针效果
    
        // 旋转图片
        [UIView animateWithDuration:0.25 animations:^{
            self.compassView.transform = CGAffineTransformMakeRotation(-angleR);
        }];
        
        
    }
    

    请求授权的时候会调用下面方法

    
    /**
     *  授权状态发生改变时调用
     *
     *  @param manager 位置管理者
     *  @param status  状态
     */
    -(void)locationManager:(CLLocationManager *)manager didChangeAuthorizationStatus:(CLAuthorizationStatus)status
    {
        switch (status) {
                // 用户还未决定
            case kCLAuthorizationStatusNotDetermined:
            {
                NSLog(@"用户还未决定");
                break;
            }
                // 问受限
            case kCLAuthorizationStatusRestricted:
            {
                NSLog(@"访问受限");
                break;
            }
                // 定位关闭时和对此APP授权为never时调用
            case kCLAuthorizationStatusDenied:
            {
                // 定位是否可用(是否支持定位或者定位是否开启)
                if([CLLocationManager locationServicesEnabled])
                {
                    NSLog(@"定位开启,但被拒");
                }else
                {
                    NSLog(@"定位关闭,不可用");
                }
    //            NSLog(@"被拒");
                break;
            }
                // 获取前后台定位授权
            case kCLAuthorizationStatusAuthorizedAlways:
                //        case kCLAuthorizationStatusAuthorized: // 失效,不建议使用
            {
                NSLog(@"获取前后台定位授权");
                break;
            }
                // 获得前台定位授权
            case kCLAuthorizationStatusAuthorizedWhenInUse:
            {
                NSLog(@"获得前台定位授权");
                break;
            }
            default:
                break;
        }
    
        
        
    }
    

    区域监听

    - (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
    {
    
        // 区域监听
        //设置经纬度
        CLLocationCoordinate2D center = {21.13, 123.456};
        CLCircularRegion *region = [[CLCircularRegion alloc] initWithCenter:center radius:1000 identifier:@"北京"];
    
        // 请求区域状态
        [self.lM requestStateForRegion:region];
    
    }
    
    #pragma mark - CLLocationManagerDelegate
    // 进入区域
    -(void)locationManager:(CLLocationManager *)manager didEnterRegion:(CLRegion *)region
    {
        NSLog(@"进入区域--%@", region.identifier);
    }
    
    // 离开区域
    -(void)locationManager:(CLLocationManager *)manager didExitRegion:(CLRegion *)region
    {
        NSLog(@"离开区域--%@", region.identifier);
    }
    
    
    -(void)locationManager:(CLLocationManager *)manager didDetermineState:(CLRegionState)state forRegion:(CLRegion *)region
    {
        NSLog(@"%zd", state);
        
        
    }
    

    相关文章

      网友评论

          本文标题:CoreLocation框架的简单实用

          本文链接:https://www.haomeiwen.com/subject/dermsxtx.html