Swift - 集成百度地图的周边雷达功能(附样例)

2023-10-15 12:59

本文主要是介绍Swift - 集成百度地图的周边雷达功能(附样例),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、周边雷达功能介绍
1,什么是周边雷达
(1)周边雷达功能,是面向移动端开发者的一套  SDK 功能接口(同步支持  Android 和  iOS 端)。
(2)周边雷达本质是一个连接百度  LBS 开放平台前端  SDK 产品和后端  LBS 云的中间服务。
原文:Swift - 集成百度地图的周边雷达功能(附样例)

2,使用场景
利用周边雷达功能,我们可以便捷的在自己的应用内,帮助用户实现查找周边跟“我”使用同一款  App 的人。比如:
(1)查看周边都有谁跟“我”使用同一个  App,分布在哪里?
(2)查看周边用户在听什么歌、看什么文章、有什么新动态?
(3)查看周边有什么最新发生的新闻、资讯?


二、准备工作 
1,申请API Key
首先我们要到百度地图开放平台上申请个  API Key,供我们程序使用。具体参考我前面一篇文章: Swift - 百度地图SDK的配置和使用(附样例) 

2,注册周边雷达
要使用周边雷达功能,我们光申请个  API Key 还不够。还需要对这个Key做相应的注册操作。
注册周边雷达是使用其相应功能的基础前提。通过注册可实现一个或多个应用之间的关系绑定,实现相互之间的位置信息查看。 
注册地址: http://developer.baidu.com/map/index.php?title=radar
原文:Swift - 集成百度地图的周边雷达功能(附样例)

3,集成SDK
周边雷达是百度地图 SDK产品的一个功能模块。我们除了要将百度地图 SDK的基础包集成进来外,还要集成周边雷达相关库( BaiduMapAPI_Radar.framework)。具体集成方式同样参考 前文。
原文:Swift - 集成百度地图的周边雷达功能(附样例)
同时桥接头文件中也要将雷达库文件  import 进来。
1
2
3
4
5
6
7
8
9
# import  < BaiduMapAPI_Base / BMKBaseComponent .h>  //引入base相关所有的头文件
# import  < BaiduMapAPI_Map / BMKMapComponent .h>  //引入地图功能所有的头文件
# import  < BaiduMapAPI_Map / BMKMapView .h>  //只引入所需的单个头文件X
# import  < BaiduMapAPI_Radar / BMKRadarComponent .h>  //引入周边雷达功能所有的头文件
/****** 下面的几个暂时不需要 ******/
//#import <BaiduMapAPI_Search/BMKSearchComponent.h> //引入检索功能所有的头文件
//#import <BaiduMapAPI_Cloud/BMKCloudSearchComponent.h> //引入云检索功能所有的头文件
//#import <BaiduMapAPI_Location/BMKLocationComponent.h> //引入定位功能所有的头文件
//#import <BaiduMapAPI_Utils/BMKUtilsComponent.h> //引入计算工具所有的头文件

三、样例介绍
下面通过“附近的人”这个小样例演示周边雷达的使用。
(1)程序启动后,应用会自动定时上传用户位置信息(每隔5秒)
(2)上传位置的时候我们同时还附带上传用户名(随机生成的)
(3)主界面有个“附近的人”列表,显示500米范围内其他的用户,以及离你的距离(列表也是5秒钟刷新一次)。
(4)只用一台手机不太好看出效果。拿两台或以上数量的手机测试的话,就可以看到其他人信息,以及他们离你的距离。比如我这里用3部手机测试,其中1部手机的运行效果如下:
原文:Swift - 集成百度地图的周边雷达功能(附样例)


四、样例代码 
1,info.plist
由于我们要使用  CoreLocation 获取实时位置数据,所以在  info.plist 里加入定位描述( Value 值为空也可以):
NSLocationWhenInUseDescription :允许在前台获取GPS的描述 
NSLocationAlwaysUsageDescription :允许在后台获取GPS的描述 
原文:Swift - 集成百度地图的周边雷达功能(附样例)

2,AppDelegate.swift
在这里使用我们之前申请的授权  Key,来对  BMKMapManager 进行声明和初始化。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import  UIKit
@UIApplicationMain
class  AppDelegate UIResponder UIApplicationDelegate BMKGeneralDelegate  {
     var  window:  UIWindow ?
     
     var  _mapManager:  BMKMapManager ?
     func  application(application:  UIApplication ,
         didFinishLaunchingWithOptions launchOptions: [ NSObject AnyObject ]?) ->  Bool  {
         
         _mapManager =  BMKMapManager ()
         // 如果要关注网络及授权验证事件,请设定generalDelegate参数
         let  ret = _mapManager?.start( "mRYTrHzAZUlT5Aojf5tMSxxxxxxxxxxx" ,
                                      generalDelegate:  self )
         if  ret ==  false  {
             NSLog ( "manager start failed!" )
         }
         return  true
     }
     //...............

3,ViewController.swift

位置信息上传、周边位置检索并显示等功能都在这里实现。这里要注意的是在上传和获取位置信息前,我们需要设置  userid
如果我们不设置的话,这个也会自动生成的。自动生成的 userid  是唯一的,且与当前设备有关。也就是说对于同一个设备每次启动程序后,生成的  userid  都是一样的。(所以多次关闭启动程序不会造成不断新增新用户的问题)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
import  UIKit
import  CoreLocation
class  ViewController UIViewController CLLocationManagerDelegate BMKRadarManagerDelegate ,
         UITableViewDelegate UITableViewDataSource  {
     
     //定位管理器
     let  locationManager: CLLocationManager  CLLocationManager ()
     
     //当前位置坐标
     var  currCoordinate: CLLocationCoordinate2D ?
     //周边雷达管理类
     var  _radarManager: BMKRadarManager ?
     
     //定时器,用于定时请求周边信息数据
     var  timer: NSTimer !
     
     //周边用户集合
     var  infoList:[ BMKRadarNearbyInfo ] = [ BMKRadarNearbyInfo ]()
     
     //显示周边用户的表格
     var  tableView: UITableView ?
     
     //当前用户名称
     var  userName: String !
     
     override  func  viewDidLoad() {
         super .viewDidLoad()
         
         //随机生成一个用户名
         userName =  "陌生人\(String(format: " %03i ", Int(arc4random()%1000)))"
         self .title =  "\(userName),你好!下面是你周围的人。"
         
         //设置定位服务管理器代理
         locationManager.delegate =  self
         //设置定位进度
         locationManager.desiredAccuracy = kCLLocationAccuracyBest
         //更新距离
         locationManager.distanceFilter = 100
         发送授权申请
         locationManager.requestAlwaysAuthorization()
         if  ( CLLocationManager .locationServicesEnabled()){
             //允许使用定位服务的话,开启定位服务更新
             locationManager.startUpdatingLocation()
             print ( "定位开始" )
         }
         //获取周边雷达管理类实例
         _radarManager =   BMKRadarManager .getRadarManagerInstance()
         //在上传和拉取位置信息前,需要设置userid,否则会自动生成
         //_radarManager?.userId = "u007"
         //通过添加radar delegate获取自动上传时的位置信息,以及获得雷达操作结果
         _radarManager?.addRadarManagerDelegate( self )
         
         //位置信息连续自动上传(每隔5秒上传一次)
         _radarManager?.startAutoUpload(5)
         //启用计时器,控制每5秒执行一次requestNearbyData方法,请求周边信息
         timer =  NSTimer .scheduledTimerWithTimeInterval(5,
                         target: self ,selector:#selector( ViewController .requestNearbyData),
                         userInfo: nil ,repeats: true )
         
         //创建表视图
         self .tableView =  UITableView (frame:  self .view.frame, style: UITableViewStyle . Plain )
         self .tableView!.delegate =  self
         self .tableView!.dataSource =  self
         //创建一个重用的单元格
         self .tableView!.registerClass( UITableViewCell . self ,
                                       forCellReuseIdentifier:  "SwiftCell" )
         self .view.addSubview( self .tableView!)
     }
     
     //定位改变执行,可以得到新位置、旧位置
     func  locationManager(manager:  CLLocationManager ,
                          didUpdateLocations locations: [ CLLocation ]) {
         //获取最新的坐标
         currCoordinate = locations.last!.coordinate
     }
     
     //获取我的位置信息(自动上传调用)
     func  getRadarAutoUploadInfo() ->  BMKRadarUploadInfo ! {
         if  let  pt = currCoordinate{
             let  myinfo =  BMKRadarUploadInfo ()
             myinfo.extInfo = userName
             //myinfo.pt = CLLocationCoordinate2DMake(39.916, 116.404)
             myinfo.pt = pt
             return  myinfo
         } else {
             return  nil
         }
     }
     
     //返回雷达 上传结果
     func  onGetRadarUploadResult(error:  BMKRadarErrorCode ) {
         if  error ==  BMK_RADAR_NO_ERROR  {
             print ( "位置上传成功" )
         } else {
             print ( "位置上传失败" )
         }
     }
     
     //发起检索请求,获取周边信息
     func  requestNearbyData() {
         if  let  centerPt = currCoordinate {
             let  option =   BMKRadarNearbySearchOption ()
             option.radius = 500  //检索半径
             option.sortType =  BMK_RADAR_SORT_TYPE_DISTANCE_FROM_NEAR_TO_FAR  //排序方式
             option.centerPt = centerPt  //检索中心点
             //发起检索
             
             let  res = _radarManager?.getRadarNearbySearchRequest(option)
             if  res! {
                 print ( "周边信息获取成功" )
             else  {
                 print ( "周边信息获取失败" )
             }
         }
     }
     
     //获取到周边位置信息回调
     func  onGetRadarNearbySearchResult(result:  BMKRadarNearbyResult !, error:  BMKRadarErrorCode ) {
         if  error ==  BMK_RADAR_NO_ERROR  {
             print ( "周边用户数量:" ,result.totalNum)
             self .infoList = result.infoList  as ! [ BMKRadarNearbyInfo ]
             self .tableView?.reloadData()
         }
     }
     
     //在本例中,只有一个分区
     func  numberOfSectionsInTableView(tableView:  UITableView ) ->  Int  {
         return  1;
     }
     
     //返回表格行数(也就是返回控件数)
     func  tableView(tableView:  UITableView , numberOfRowsInSection section:  Int ) ->  Int  {
         return  self .infoList.count
     }
     
     //创建各单元显示内容(创建参数indexPath指定的单元)
     func  tableView(tableView:  UITableView , cellForRowAtIndexPath indexPath:  NSIndexPath )
         ->  UITableViewCell  {
         let  cell =   UITableViewCell (style:  UITableViewCellStyle . Value1 ,
                         reuseIdentifier:  "SwiftCell" )
         cell.textLabel?.text =  self .infoList[indexPath.row].extInfo
         cell.detailTextLabel?.text =  "\(self.infoList[indexPath.row].distance)m"
         return  cell
     }
     override  func  didReceiveMemoryWarning() {
         super .didReceiveMemoryWarning()
     }
}

源码下载 hangge_1279.zip
原文出自: www.hangge.com   转载请保留原文链接: http://www.hangge.com/blog/cache/detail_1279.html

这篇关于Swift - 集成百度地图的周边雷达功能(附样例)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/217890

相关文章

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

Spring+MyBatis+jeasyui 功能树列表

java代码@EnablePaging@RequestMapping(value = "/queryFunctionList.html")@ResponseBodypublic Map<String, Object> queryFunctionList() {String parentId = "";List<FunctionDisplay> tables = query(parent

【Shiro】Shiro 的学习教程(三)之 SpringBoot 集成 Shiro

目录 1、环境准备2、引入 Shiro3、实现认证、退出3.1、使用死数据实现3.2、引入数据库,添加注册功能后端代码前端代码 3.3、MD5、Salt 的认证流程 4.、实现授权4.1、基于角色授权4.2、基于资源授权 5、引入缓存5.1、EhCache 实现缓存5.2、集成 Redis 实现 Shiro 缓存 1、环境准备 新建一个 SpringBoot 工程,引入依赖: