程序员必知:地图显示的步骤

简介: 程序员必知:地图显示的步骤

1.MapKit: 着重与在手机上显示地图,地图上可以显示路线,覆盖层,大头针

2.如何添加大头针:

#需要自定义,因为用户的大头针位置是无法改变

#自定义注意点:

#要遵守MKAnnotation这个协议

#实现这个协议必须实现的方法

#**可以给协议增加方法,以达到设置这个属性的值

#创建大头针

#设置经纬度(title, subTitle)

#添加到地图上面

3.大头针的理论基础

#操作大头针就是操作大头针数据模型

#添加大头针就是添加大头针的数据模型

#删除大头针就是删除大头针的数据模型

4.大头针是如何显示出来的

#当将一根大头针的数据模型添加到地图上时,会调用对应的代理方法,在内部创建大头针视图并返回,之后显示在地图上

#**系统默认的大头针的视图的类型MKPinAnnotationView

一.代码:01-01(掌握)地图的基本使用(显示类型地图控制显示控制) // POI: point of intreset

七.代码: 07-01(了解)导航-方案3-第三方-百度地图-集成百度地图SDK(百度开发平台模块: iOS地图SDK)

# 1.生成秘钥key: "iA5UyEGFTdQ4iFe6FGdeGryhjPfpUXFm

# 2.配置inf.plist文件: 01."App Transport Security Settings""Allow Arbitrary Loads"

# 02."Privacy - Location When In Use Usage Description"--"地图定位测试"

# 或者"NSLocationAlwaysUsageDescription"--"地图定位测试"

# 03."Bundle display name"--"$(PRODUCT_NAME)"

# 04.添加系统以来库: // CoreLocation.framework

// QuartzCore.framework

// OpenGLES.framework

// SystemConfiguration.framework

// CoreGraphics.framework

// Security.framework

// libsqlite3.0.tbd(xcode7以前为 libsqlite3.0.dylib)、CoreTelephony.framework

// libstdc++.6.0.9.tbd(xcode7以前为libstdc++.6.0.9.dylib)

# 05.单独引入mapapi.bundle资源文件(在"BaiduMapAPIMap.framework"中)

七.代码: 07-01(了解)导航-方案3-第三方-百度地图-集成百度地图SDK

# 1.初始化检索对象,并设置BMKPoiSearch 代理

// 实现代理: 返回POI搜索结果

//func onGetPoiResult( searcher: BMKPoiSearch!, result poiResult: BMKPoiResult!, errorCode: BMKSearchErrorCode) {...}

/// 当检索到结果的时候会来到的方法

//当在设置城市未找到结果,但在其他城市找到结果时,回调建议检索城市列表

# 2. 设置BMKMapView代理

// 实现代理: 长按地图时会回调此接口

//func mapview(_ mapView: BMKMapView!, onLongClick coordinate: CLLocationCoordinate2D) {...}//代码效果参考:http://www.ezhiqi.com/zx/art_3012.html

//发起检索

七.代码: 07-03(了解)导航-方案3-第三方-百度地图-添加大头针

# 1.设置地图显示区域:

//let span = BMKCoordinateSpan(...)

//let region = BMKCoordinateRegion(...)

//mapView.setRegion(region, animated: true)

# 2.获取poi列表: poiResult.poiInfoList as? 【BMKPoiInfo】

# 3.添加大头针:

//let annotaion = BMKPointAnnotation()

//annotaion.coordinate = poiInfoList.pt

//annotaion.title = poiInfoList.name

//annotaion.subtitle = poiInfoList.address

//mapView.addAnnotation(annotaion)

七.代码: 07-04(了解)导航-方案3-第三方-百度地图-集成百度导航SDK(百度开发平台模块: iOS导航SDK)

# 小功能: "双指放大缩小: commamd + option

# 1.导入BaiduNaviSSDK

# 2.设置定位服务,并设置代理:

"lazy var locService : BMKLocationService = {...}()

# 3.遵守并实现位置服务代理

// 1.获取用户位置

// 获取用户一次位置

"locService.stopUserLocationService()

// 2.进行导航

// 节点数组

"var nodesArray = 【BNRoutePlanNode】()

// 3.起点

"let startNode = BNRoutePlanNode()

"nodesArray.append(startNode)

// 4.终点

"let endNode = BNRoutePlanNode()

"nodesArray.append(endNode)

// 5.发起路径规划

"BNCoreServices.routePlanService().startNaviRoutePlan(BNRoutePlanModeRecommend, naviNodes: nodesArray, time: nil, delegete: self, userInfo: nil)

# 4.遵守并实现算路代理

// 算路成功回调

"func routePlanDidFinished( userInfo: 【AnyHashable : Any】!) {...}//代码效果参考:http://www.ezhiqi.com/zx/art_362.html

//路径规划成功,开始导航

"BNCoreServices.uiService().showPage(BNaviUI_NormalNavi, delegate: nil, extParams: nil)

完事皆项目,感兴趣可联系我邮箱~hjjuny@163.com

目录
打赏
0
7
8
0
32
分享
相关文章
【python实操】软件安装进展提示进度条如何实现的?如何设置窗体拉伸?如何获取输入框内容?
【python实操】软件安装进展提示进度条如何实现的?如何设置窗体拉伸?如何获取输入框内容?
108 0
Echarts实战案例代码(19):利用visualMap视觉映射组件制作五色玫瑰工作进程图
Echarts实战案例代码(19):利用visualMap视觉映射组件制作五色玫瑰工作进程图
282 0
WPF开发者必备秘籍:深度解析数据网格最佳实践,轻松玩转数据展示与编辑大揭秘!
【8月更文挑战第31天】数据网格控件是WPF应用程序中展示和编辑数据的关键组件,提供排序、筛选等功能,显著提升用户体验。本文探讨WPF中数据网格的最佳实践,通过DevExpress DataGrid示例介绍其集成方法,包括添加引用、定义数据模型及XAML配置。通过遵循数据绑定、性能优化、自定义列等最佳实践,可大幅提升数据处理效率和用户体验。
112 0
好的设计,文本-------------------字体嵌入,图形化管理技术,当你搜索,或者关注某个具体的地方,可以引入一种使用图形进行外标,比如方框,以更快找到该内容
好的设计,文本-------------------字体嵌入,图形化管理技术,当你搜索,或者关注某个具体的地方,可以引入一种使用图形进行外标,比如方框,以更快找到该内容
ElementPlus卡片如何能够一行呈四,黑马UI前端布局视频资料,element样式具体的细节无法修改,F12找到那个位置,可能在其他组件写了错误,找到那个位置,围绕着位置解决问题最快了,卡片下边
ElementPlus卡片如何能够一行呈四,黑马UI前端布局视频资料,element样式具体的细节无法修改,F12找到那个位置,可能在其他组件写了错误,找到那个位置,围绕着位置解决问题最快了,卡片下边
《QT从基础到进阶·二十六》绘制多个图形项(QGraphicsRectItem,QGraphicsLineItem,QGraphicsPolygonItem)
《QT从基础到进阶·二十六》绘制多个图形项(QGraphicsRectItem,QGraphicsLineItem,QGraphicsPolygonItem)
291 0
|
10月前
|
PyQt中图表的建立与显示(完整过程演示)
PyQt中图表的建立与显示(完整过程演示)
221 0
《QT从基础到进阶·二十二》QGraphicsView显示大量图形项item导致界面卡顿的解决办法
《QT从基础到进阶·二十二》QGraphicsView显示大量图形项item导致界面卡顿的解决办法
827 0
前端学习笔记202305学习笔记第二十三天-地图区域样式设置1
前端学习笔记202305学习笔记第二十三天-地图区域样式设置1
60 0
前端学习笔记202305学习笔记第二十三天-地图区域样式设置1
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等