[b]原创文章,欢迎转载,转载时务必注明原文地址及作者[/b]

9. 使用GPS设定其精度并,取得方位(经度,纬度),方向的数据
使用CLLocationManager来取得当前的GPS经度,纬度,方位的数据,首先初始化CLLocationManager,设定其精度,更新回调,更新的距离筛选,通过方法startUpdatingHeading来开启方向的更新,通过方法startUpdatingLocation来开启方位的更新。

//初始化方位类       self.localManager = [[CLLocationManager alloc] init];        localManager.delegate = self;

      //开启电子罗盘      if (localManager.headingAvailable)            [localManager startUpdatingHeading];//启动

        //开启GPS       if(localManager.locationServicesEnabled) {            localManager.desiredAccuracy = kCLLocationAccuracyBest;//设定为最佳精度         localManager.distanceFilter = 5.0f;//响应位置变化的最小距离(m)          [localManager startUpdatingLocation];     }

10. 取得方位(经度,纬度),方向的数据更新回调值
通过实现协议CLLocationManagerDelegate来取得数据更新的回调,其中(BOOL)locationManagerShouldDisplayHeadingCalibration:(CLLocationManager *)manager是方向更新的过滤器,- (void)locationManager:(CLLocationManager *)manager didUpdateHeading:(CLHeading *)newHeading 是方向更新的回调方法,可以通过newHeading.magneticHeading来取得当前的方向角度(正北方向为0度)。
- (void)locationManager:(CLLocationManager *)manager
didUpdateToLocation:(CLLocation *)newLocation
fromLocation:(CLLocation *)oldLocation为方位(经度,纬度)的更新回调,可以通过newLocation.horizontalAccuracy取得当前定位精度圆半径,newLocation.coordinate.latitude取得纬度数据,newLocation.coordinate.longitude取得精度数据,而- (void)locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error是GPS初始化失败的回调,应为开启GPS需要得到用户的许可,没有许可就无法正常开启。

//方位变化的回调函数- (void)locationManager:(CLLocationManager *)manager didUpdateHeading:(CLHeading *)newHeading {   //初始化方位   if ([fileLoader isKindOfClass:[TestLoader class]]) {      if (localDir == 0) {            baseDir = newHeading.magneticHeading;            localDir = newHeading.magneticHeading;       } } float newlocalDir = newHeading.magneticHeading;  //当变化超过一定范围,刷新标志显示 if (abs(newlocalDir - localDir) > FLASH_DEGREE) {      localDir = newlocalDir;      [self computer];  } //更新指南针方向 [overlayView updateHeading:newHeading];}//方位变化的回调函数- (BOOL)locationManagerShouldDisplayHeadingCalibration:(CLLocationManager *)manager {    return YES;}

//GPS位置变化的回调- (void)locationManager:(CLLocationManager *)manager      didUpdateToLocation:(CLLocation *)newLocation         fromLocation:(CLLocation *)oldLocation {  self.local = newLocation;    //更新经纬度表示值    [overlayView updateLocation:self.local];  if ([fileLoader isKindOfClass:[GPSLoader class]]) {       [fileLoader computerDis:allTags andLocal:local];      //重新计算当前标志点的位置        [self computer];  } //关闭定位    //[localManager stopUpdatingLocation];}

//GPS初始化失败- (void)locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error { NSLog(@"Location manager error: %@", [error description]);}

11. 计算GPS两点间的距离的算法
一种方法通过CLLocation的实例方法getDistanceFrom方法计算两点间的距离(m),
如果没有API可用,可以通过积分的方式利用三角定律估算出两点的直线距离。

 CLLocation* location1 = [[CLLocation alloc] initWithLatitude:latin1 longitude:lonin1];   CLLocation* location2 = [[CLLocation alloc] initWithLatitude:latin2 longitude:lonin2];   return [location1 getDistanceFrom:location2];

12. 计算GPS两点间的方向角度的算法
以其中一点作为原点,经过此原点的经度线作为y坐标轴,纬度线作为x坐标轴,在这个坐标系中利用atan2f三角函数取得相对于y轴夹角,再加上对应的偏移量,就可以取得相当于y轴的正方向(正北方向)的角度。

//计算GPS两点间的经度距离+ (CGFloat) calcuLoninM:(CGFloat) latin1 withLonin:(CGFloat) lonin1         withDisLatin:(CGFloat) latin2 withDisLonin:(CGFloat) lonin2 {  CGFloat retval = 0.0;    CGFloat latin = latin1;  CGFloat latinStep = (latin1 - latin2) / MAX_LENGTH;  CGFloat loninStep = (lonin1 - lonin2) / MAX_LENGTH;  if (loninStep < 0) {       loninStep = -1.0 * loninStep;    } for (int i = 0 ; i < MAX_LENGTH; i++) {     retval += EARTH_RADIUS * [GPSHelp toRadians:loninStep] * cos([GPSHelp toRadians:latin]);        latin += latinStep; } return retval;}//计算GPS两点间的纬度距离+ (CGFloat) calcuLatinM:(CGFloat) latin1 withLonin:(CGFloat) lonin1         withDisLatin:(CGFloat) latin2 withDisLonin:(CGFloat) lonin2 {  CGFloat angle = latin1 - latin2; if (angle < 0) {       angle = -1.0 * angle;    } return [GPSHelp toRadians:angle] * EARTH_RADIUS;}//角度转弧度+ (CGFloat)toRadians:(CGFloat)degree { return degree / 180.0 * M_PI;}//弧度转角度+ (CGFloat)toDegrees:(CGFloat)radian {    return radian / M_PI * 180.0;}

@end

@implementation GPSHelp

//计算GPS两点间的角度(正北方向为0度)+ (CGFloat) calcuAngle:(CGFloat) latin1 withLonin:(CGFloat) lonin1        withDisLatin:(CGFloat) latin2 withDisLonin:(CGFloat) lonin2 {   CGFloat loninM = [GPSHelp calcuLoninM:latin1 withLonin:lonin1 withDisLatin:latin2 withDisLonin:lonin2];  CGFloat latinM = [GPSHelp calcuLatinM:latin1 withLonin:lonin1 withDisLatin:latin2 withDisLonin:lonin2];  CGFloat radian = atan2f(loninM, latinM); if (lonin2 >= lonin1) {       if (latin2 >= latin1) {           ;     } else {          radian = M_PI - radian;      } } else {      if (latin2 >= latin1) {           radian = 2.0 * M_PI - radian;;       } else {          radian = M_PI + radian;     } } return [GPSHelp toDegrees:radian];}

13. 根据GPS两点间的方向角度以及当前电子罗盘的方向角度算出对应的屏幕的2D坐标值
假设当前的可见角度范围是-90到+90之间,首先计算出电子罗盘的方向角度和GPS两点间的方向角度的角度差,再通过角度格式化成-90到+90之间的一个数值,再计算出这个角度相对于90度的比例,乘上屏幕中心点的x坐标,就可以得到此点对应于当前屏幕的x坐标值。

14. 根据两点间的距离算出对应屏幕的2D坐标值及大小
假设可见的最远距离是200m,让200m距离内的所有标志点显示在屏幕的下半部分,也就是说在>屏幕中心点的y坐标<最大的y坐标的范围内,距离越近的点显示在越靠近屏幕最下方的地方,标记大小也越接近原始大小。根据两点间的距离占200m的比例,计算出y坐标值。大小的计算类同。此算法显示的效果不是很真实,有待继续研究。

IPHONE实景导航开发总结(二)相关推荐

  1. IPHONE实景导航开发总结

    http://my.oschina.net/makeffort/blog/89016 1. 在摄像头捕获的画面上添加一个自定义的view.  使用iphoneSDK 3.1的新API:UIImageP ...

  2. IPHONE实景导航开发总结(一)

    1. 在摄像头捕获的画面上添加一个自定义的view.  使用iphoneSDK 3.1的新API:UIImagePickerController的新属性cameraOverView来添加一个自定义的v ...

  3. 适合前端工作者的iPhone Web App开发

    iPhone有着丰富的软件资源,到目前为止,仅在appStore上架的软件就达十多万个,而相比之下,有着10年历史的WM系统却不过只有大约2万个应用程序. 随着ipad和iphone 4的发布,iph ...

  4. iPhone与iPad开发实战读书笔记

    iPhone开发一些读书笔记 手机应用分类 1.教育工具 2.生活工具 3.社交应用 4.定位工具 5.游戏 6.报纸和杂志的阅读器 7.移动办公应用 8.财经工具 9.手机购物应用 10.风景区相关 ...

  5. 三维重建、视觉定位、传感器位置推算,滴滴 AR 实景导航技术详解

    导读:机场.商场.火车站等大型室内场所内GPS信号不稳定.室内面积大.路线复杂.用户判断方向难等问题,给在大型场所内发单的乘客找上车点带来了很大的挑战,用户急需一种操作简单.交互友好的引导功能.本文讲 ...

  6. iOS 7: iPhone/iPad应用开发技术详解

    iOS 7: iPhone/iPad应用开发技术详解 作者:刘一道 出版社:机械工业出版社 出版年:2013-11 页数:507 定价:79.00元 ISBN:9787111440512 样章下载:h ...

  7. 软件创富密码:iPhone应用程序开发攻略之iPhone特色传感器应用(双色)

    软件创富密码:iPhone应用程序开发攻略之iPhone特色传感器应用(双色)  王志刚等 编著 ISBN978-7-121-14440-0   2011年9月出版 定价:69.00元 16开 288 ...

  8. 滴滴AR实景导航背后的技术

    桔妹导读:机场.商场.火车站等大型室内场所内GPS信号不稳定.室内面积大.路线复杂.用户判断方向难等问题,给在大型场所内发单的乘客找上车点带来了很大的挑战,用户急需一种操作简单.交互友好的引导功能.本 ...

  9. android 原生开发 3d地图 下载_arcgis api 3.x for js 入门开发系列二不同地图服务展示(附源码下载)...

    前言 关于本篇功能实现用到的 api 涉及类看不懂的,请参照 esri 官网的 arcgis api 3.x for js:esri 官网 api,里面详细的介绍 arcgis api 3.x 各个类 ...

最新文章

  1. Libgdx New 3D API 教程之 -- 使用Libgdx加载模型
  2. [CES 2018] 上手测试:刚公布的 TPCast Plus 无线适配器
  3. eclipse格式化代码
  4. ClickHouse之访问权限控制
  5. HDFS命令行客户端使用,命令行客户端支持的命令参数,常用命令参数介绍
  6. 谷歌离开游览器不触发_谷歌游览器
  7. 酷狗直播联手腾讯游戏破圈“组团” 游戏直播正版化杀入重量级玩家
  8. SAP GRC 权限合规审计系统
  9. compser 执行命令提示do not run composer as root/super !
  10. vue 解决跨域 调试_vue+Java后端进行调试时解决跨域问题的方式
  11. 中国顶级AI盛会,10月魔都等你来解密!
  12. 获取子元素上面父元素中最大的z-index(z-index在chrome的兼容问题)
  13. 00-软件研制任务书
  14. Duplicate column name xxx
  15. 【影评】:卧虎藏龙中的人物性格的分析
  16. 并发之Striped64(l累加器)
  17. PDF改背景和字体颜色
  18. [云原生专题-18]:容器 - docker自带的集群管理工具swarm - 手工搭建集群服务全过程详细解读
  19. Android 获得手机ip
  20. 香港汇丰银行个人开户资料及流程

热门文章

  1. 如何获取《非经营性互联网信息服务备案核准》资质文件
  2. 360笔试居然过了(不可置信脸~~~)
  3. 【男士必须收藏】男士健身方法
  4. 【Qt 5】Qt中QMutex的一点理解
  5. 突发!因为这个原因,ChatGPT又双叒大面积封号了...
  6. Cisco搭建邮件服务器实现邮件收发
  7. GRR(Gauge Repeatability and Reproducibility)
  8. Lucene+分词器精确提取用户自定义关键词(Lucene版本3.6)
  9. 价值连城的macd战法
  10. 将matlab数据保存为excel文件