百度地图反地理编码问题总结(swift)
2016-09-19 14:11
330 查看
百度地图SDK提供了一套功能很强大的地图框架使用接口,它不仅提供构建地图的基本接口,还提供POI搜索、地理编码、路线规划、定位、本地覆盖物绘制等服务。而由于百度地图SDK官方网站上给出的使用说明是使用Objective-C语言以及Xcode4来进行开发的,很多朋友在使用Swift语言来进行开发的过程中遇到了不少的问题,在此我将我的使用经验与遇到的问题写下来给大家进行分享,帮助大家快速使用百度地图。
百度地图iOSSDK是一套基于iOS5.0及以上版本设备的应用程序接口,不仅提供展示地图的基本接口,还提供POI检索、路径规划、地图标注、离线地图、室内地图、定位、周边雷达等丰富的LBS能力。
您可以使用百度地图iOSSDK开发适用于移动设备的地图应用,通过接口,您可以轻松访问百度服务和数据,构建功能丰富、交互性强的地图应用程序。
自v3.0起,iOS地图SDK全面支持IPv6网络。该套SDK提供的服务是免费的,任何非营利性程序均可使用,您需要先申请密钥(key) ,才可使用该套SDK接口。任何非营利性产品请直接使用,商业目的产品使用前请参考 使用须知 。
在您使用百度地图iOSSDK之前,请先阅读百度地图API使用条款 。
第一步、导入地图SDK,参考配置开发环境;
百度地图iOSSDK自v2.7.0版本起,向广大开发者提供了.framework形式的SDK开发包,这种形式的开发包配置简单,使用方便,推荐大家使用。
注:由于iOS9改用更安全的https,为了能够在iOS9中正常使用地图SDK,请在"Info.plist"中进行如下配置,否则影响SDK的使用。
注:此种方式只支持导入全量包的SDK,包含百度地图iOSSDK所有功能
一、前提:安装CocoaPods
在终端输入
如果安装成功,会有一个提示
二、使用CocoaPods导入地图SDK
在当前工程文件(.xcodeproj)所在文件夹下,打开terminal
1.创建Podfile:
2.编辑Podfile内容如下:
3.在Podfile所在的文件夹下输入命令:
成功以后,会出现如下记录:
恭喜你已成功导入百度地图iOSSDK,现在就可以打开xcworkspace文件,在你的项目中使用百度地图SDK了
第一步、根据需要导入.framework包
百度地图iOSSDK采用分包的形式提供.framework包,请广大开发者使用时确保各分包的版本保持一致。其中BaiduMapAPI_Base.framework为基础包,使用SDK任何功能都需导入,其他分包可按需导入。
将所需的BaiduMapAPI_**.framework拷贝到工程所在文件夹下。
在TARGETS->BuildPhases->LinkBinaryWithLibaries中点击“+”按钮,在弹出的窗口中点击“AddOther”按钮,选择BaiduMapAPI_**.framework添加到工程中。
注:静态库中采用Objective-C++实现,因此需要您保证您工程中至少有一个.mm后缀的源文件(您可以将任意一个.m后缀的文件改名为.mm),或者在工程属性中指定编译方式,即在Xcode的Project->EditActiveTarget->BuildSetting中找到CompileSourcesAs,并将其设置为"Objective-C++"
第二步、引入所需的系统库
百度地图SDK中提供了定位功能和动画效果,v2.0.0版本开始使用OpenGL渲染,因此您需要在您的Xcode工程中引入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)。
(注:红色标识的系统库为v2.9.0新增的系统库,使用v2.9.0及以上版本的地图SDK,务必增加导入这3个系统库。)
添加方式:在Xcode的Project->ActiveTarget->BuildPhases->LinkBinaryWithLibraries,添加这几个系统库即可。
第三步、环境配置
在TARGETS->BuildSettings->OtherLinkerFlags中添加-ObjC。
第四步、引入mapapi.bundle资源文件
如果使用了基础地图功能,需要添加该资源,否则地图不能正常显示mapapi.bundle中存储了定位、默认大头针标注View及路线关键点的资源图片,还存储了矢量地图绘制必需的资源文件。如果您不需要使用内置的图片显示功能,则可以删除bundle文件中的image文件夹。您也可以根据具体需求任意替换或删除该bundle中image文件夹的图片文件。
方法:选中工程名,在右键菜单中选择AddFilesto“工程名”…,从BaiduMapAPI_Map.framework||Resources文件中选择mapapi.bundle文件,并勾选“Copyitemsifneeded”复选框,单击“Add”按钮,将资源文件添加到工程中。
第五步、引入头文件
在使用SDK的类按需引入下边的头文件:
一、初始化BMKMapManager在您的AppDelegate.swift文件中添加对BMKMapManager的声明和初始化,并填入您申请的授权Key,示例如下
var_mapManager:BMKMapManager? funcapplication(application:UIApplication,didFinishLaunchingWithOptionslaunchOptions:[NSObject:AnyObject]?)->Bool { _mapManager=BMKMapManager() //如果要关注网络及授权验证事件,请设定generalDelegate参数 letret=_mapManager?.start("申请的百度地图key",generalDelegate:self) ifret==false{ NSLog("managerstartfailed!") } returntrue }
}
二、创建BMKMapView在您的ViewController.swift文件中添加BMKMapView的创建代码,示例如下
classViewController:UIViewController,BMKGeoCodeSearchDelegate,BMKLocationServiceDelegate {
@IBOutletweakvaraddressLabel:UILabel! varlocationService:BMKLocationService! vargeoCodeSearch:BMKGeoCodeSearch! varlat=Double() varlon=Double() overridefuncviewDidLoad(){ super.viewDidLoad() geoCodeSearch=BMKGeoCodeSearch() locationService=BMKLocationService() locationService.startUserLocationService() }
自2.0.0起,BMKMapView新增viewWillAppear、viewWillDisappear方法来控制BMKMapView的生命周期,并且在一个时刻只能有一个BMKMapView接受回调消息,因此在使用BMKMapView的viewController中需要在viewWillAppear、viewWillDisappear方法中调用BMKMapView的对应的方法,并处理delegate,代码如下:
overridefuncviewWillAppear(animated:Bool) { super.viewWillAppear(animated) geoCodeSearch.delegate=self locationService.delegate=self} overridefuncviewWillDisappear(animated:Bool){ super.viewWillDisappear(animated) geoCodeSearch.delegate=nil locationService.delegate=nil }
/** *用户位置更新后,会调用此函数 *@paramuserLocation新的用户位置 */ funcdidUpdateBMKUserLocation(userLocation:BMKUserLocation!) { self.lat=userLocation.location.coordinate.latitude self.lon=userLocation.location.coordinate.longitude letreverseGeocodeSearchOption=BMKReverseGeoCodeOption() reverseGeocodeSearchOption.reverseGeoPoint=CLLocationCoordinate2DMake(self.lat,self.lon) print("目标位置:\(self.lat)\(self.lon)") //发送反编码请求.并返回是否成功 letflag=geoCodeSearch.reverseGeoCode(reverseGeocodeSearchOption) if(flag) { print("反geo检索发送成功") }else{ print("反geo检索发送失败") } } /** *返回反地理编码搜索结果 *@paramsearcher搜索对象 *@paramresult搜索结果 *@paramerror错误号,@seeBMKSearchErrorCode -(void)onGetReverseGeoCodeResult:(BMKGeoCodeSearch*)searcherresult:(BMKReverseGeoCodeResult*)resulterrorCode:(BMKSearchErrorCode)error; */ funconGetReverseGeoCodeResult(searcher:BMKGeoCodeSearch!,result:BMKReverseGeoCodeResult!,errorCodeerror:BMKSearchErrorCode) { print("返回错误信息%@",error) if(error==BMK_SEARCH_NO_ERROR){ print("返回正常") self.addressLabel.text=result.address }else{ print("返回错误....") } }
上面代码即可通过百度地图实现反地理编码,可以显示当前位置的详细地址信息!但是有些情况下当反geo检索发送成功
时onGetReverseGeoCodeResult方法不执行,这时我们应该检查:
1
.百度地图的安全码是否与该项目的BundleIdentifier名称是否一致如过不一致将两者名称保持一致,再进行测试运行,
2
.百度地图为了给用户提供更安全的服务,iOSSDK自v2.0.2版本开始采用了全新的Key验证体系。因此,当您选择使用v2.0.2及之后版本的SDK时,需要到新的Key申请页面进行全新Key的申请,申请及配置流程请参考开发指南对应章节。(选择使用v2.0.1及之前版本SDK的开发者,申请密钥(Key)的方式不变)。
可以根据自己的百度地图版本查看自己key值是否相对应,检查完毕后ok后,再运行进行测试.
通过上面两个方法,我的反地理编码已成功解决,希望看完文章后能够对您有所帮助!
Demo下载地址:
点击打开链接
百度地图iOSSDK是一套基于iOS5.0及以上版本设备的应用程序接口,不仅提供展示地图的基本接口,还提供POI检索、路径规划、地图标注、离线地图、室内地图、定位、周边雷达等丰富的LBS能力。
您可以使用百度地图iOSSDK开发适用于移动设备的地图应用,通过接口,您可以轻松访问百度服务和数据,构建功能丰富、交互性强的地图应用程序。
自v3.0起,iOS地图SDK全面支持IPv6网络。该套SDK提供的服务是免费的,任何非营利性程序均可使用,您需要先
在您使用百度地图iOSSDK之前,请先阅读
第一步、导入地图SDK,参考
百度地图iOSSDK自v2.7.0版本起,向广大开发者提供了.framework形式的SDK开发包,这种形式的开发包配置简单,使用方便,推荐大家使用。
注:由于iOS9改用更安全的https,为了能够在iOS9中正常使用地图SDK,请在"Info.plist"中进行如下配置,否则影响SDK的使用。
<key>NSAppTransportSecurity</key> <dict> <key>NSAllowsArbitraryLoads</key> <true/> </dict>
自动配置.framework形式开发包(使用CocoaPods)
注:此种方式只支持导入全量包的SDK,包含百度地图iOSSDK所有功能一、前提:安装CocoaPods
在终端输入
sudogeminstallcocoapods
如果安装成功,会有一个提示
SuccessfullyinstalledcocoaPods
二、使用CocoaPods导入地图SDK
在当前工程文件(.xcodeproj)所在文件夹下,打开terminal
1.创建Podfile:
touchPodfile
2.编辑Podfile内容如下:
pod'BaiduMapKit'#百度地图SDK
3.在Podfile所在的文件夹下输入命令:
podinstall(这个可能比较慢,请耐心等待……)
成功以后,会出现如下记录:
Analyzingdependencies Downloadingdependencies InstallingBaiduMapKit(2.9.1) GeneratingPodsproject Integratingclientproject [!]PleasecloseanycurrentXcodesessionsanduse`***.xcworkspace`forthisprojectfromnowon. Sendingstats
恭喜你已成功导入百度地图iOSSDK,现在就可以打开xcworkspace文件,在你的项目中使用百度地图SDK了
手动配置.framework形式开发包
第一步、根据需要导入.framework包百度地图iOSSDK采用分包的形式提供.framework包,请广大开发者使用时确保各分包的版本保持一致。其中BaiduMapAPI_Base.framework为基础包,使用SDK任何功能都需导入,其他分包可按需导入。
将所需的BaiduMapAPI_**.framework拷贝到工程所在文件夹下。
在TARGETS->BuildPhases->LinkBinaryWithLibaries中点击“+”按钮,在弹出的窗口中点击“AddOther”按钮,选择BaiduMapAPI_**.framework添加到工程中。
注:静态库中采用Objective-C++实现,因此需要您保证您工程中至少有一个.mm后缀的源文件(您可以将任意一个.m后缀的文件改名为.mm),或者在工程属性中指定编译方式,即在Xcode的Project->EditActiveTarget->BuildSetting中找到CompileSourcesAs,并将其设置为"Objective-C++"
第二步、引入所需的系统库
百度地图SDK中提供了定位功能和动画效果,v2.0.0版本开始使用OpenGL渲染,因此您需要在您的Xcode工程中引入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)。
(注:红色标识的系统库为v2.9.0新增的系统库,使用v2.9.0及以上版本的地图SDK,务必增加导入这3个系统库。)
添加方式:在Xcode的Project->ActiveTarget->BuildPhases->LinkBinaryWithLibraries,添加这几个系统库即可。
第三步、环境配置
在TARGETS->BuildSettings->OtherLinkerFlags中添加-ObjC。
第四步、引入mapapi.bundle资源文件
如果使用了基础地图功能,需要添加该资源,否则地图不能正常显示mapapi.bundle中存储了定位、默认大头针标注View及路线关键点的资源图片,还存储了矢量地图绘制必需的资源文件。如果您不需要使用内置的图片显示功能,则可以删除bundle文件中的image文件夹。您也可以根据具体需求任意替换或删除该bundle中image文件夹的图片文件。
方法:选中工程名,在右键菜单中选择AddFilesto“工程名”…,从BaiduMapAPI_Map.framework||Resources文件中选择mapapi.bundle文件,并勾选“Copyitemsifneeded”复选框,单击“Add”按钮,将资源文件添加到工程中。
第五步、引入头文件
在使用SDK的类按需引入下边的头文件:
一、初始化BMKMapManager在您的AppDelegate.swift文件中添加对BMKMapManager的声明和初始化,并填入您申请的授权Key,示例如下
var_mapManager:BMKMapManager? funcapplication(application:UIApplication,didFinishLaunchingWithOptionslaunchOptions:[NSObject:AnyObject]?)->Bool { _mapManager=BMKMapManager() //如果要关注网络及授权验证事件,请设定generalDelegate参数 letret=_mapManager?.start("申请的百度地图key",generalDelegate:self) ifret==false{ NSLog("managerstartfailed!") } returntrue }
}
二、创建BMKMapView在您的ViewController.swift文件中添加BMKMapView的创建代码,示例如下
classViewController:UIViewController,BMKGeoCodeSearchDelegate,BMKLocationServiceDelegate {
@IBOutletweakvaraddressLabel:UILabel! varlocationService:BMKLocationService! vargeoCodeSearch:BMKGeoCodeSearch! varlat=Double() varlon=Double() overridefuncviewDidLoad(){ super.viewDidLoad() geoCodeSearch=BMKGeoCodeSearch() locationService=BMKLocationService() locationService.startUserLocationService() }
自2.0.0起,BMKMapView新增viewWillAppear、viewWillDisappear方法来控制BMKMapView的生命周期,并且在一个时刻只能有一个BMKMapView接受回调消息,因此在使用BMKMapView的viewController中需要在viewWillAppear、viewWillDisappear方法中调用BMKMapView的对应的方法,并处理delegate,代码如下:
overridefuncviewWillAppear(animated:Bool) { super.viewWillAppear(animated) geoCodeSearch.delegate=self locationService.delegate=self} overridefuncviewWillDisappear(animated:Bool){ super.viewWillDisappear(animated) geoCodeSearch.delegate=nil locationService.delegate=nil }
/** *用户位置更新后,会调用此函数 *@paramuserLocation新的用户位置 */ funcdidUpdateBMKUserLocation(userLocation:BMKUserLocation!) { self.lat=userLocation.location.coordinate.latitude self.lon=userLocation.location.coordinate.longitude letreverseGeocodeSearchOption=BMKReverseGeoCodeOption() reverseGeocodeSearchOption.reverseGeoPoint=CLLocationCoordinate2DMake(self.lat,self.lon) print("目标位置:\(self.lat)\(self.lon)") //发送反编码请求.并返回是否成功 letflag=geoCodeSearch.reverseGeoCode(reverseGeocodeSearchOption) if(flag) { print("反geo检索发送成功") }else{ print("反geo检索发送失败") } } /** *返回反地理编码搜索结果 *@paramsearcher搜索对象 *@paramresult搜索结果 *@paramerror错误号,@seeBMKSearchErrorCode -(void)onGetReverseGeoCodeResult:(BMKGeoCodeSearch*)searcherresult:(BMKReverseGeoCodeResult*)resulterrorCode:(BMKSearchErrorCode)error; */ funconGetReverseGeoCodeResult(searcher:BMKGeoCodeSearch!,result:BMKReverseGeoCodeResult!,errorCodeerror:BMKSearchErrorCode) { print("返回错误信息%@",error) if(error==BMK_SEARCH_NO_ERROR){ print("返回正常") self.addressLabel.text=result.address }else{ print("返回错误....") } }
上面代码即可通过百度地图实现反地理编码,可以显示当前位置的详细地址信息!但是有些情况下当反geo检索发送成功
时onGetReverseGeoCodeResult方法不执行,这时我们应该检查:
1
.百度地图的安全码是否与该项目的BundleIdentifier名称是否一致如过不一致将两者名称保持一致,再进行测试运行,
2
.百度地图为了给用户提供更安全的服务,iOSSDK自v2.0.2版本开始采用了全新的Key验证体系。因此,当您选择使用v2.0.2及之后版本的SDK时,需要到新的Key申请页面进行全新Key的申请,申请及配置流程请参考
可以根据自己的百度地图版本查看自己key值是否相对应,检查完毕后ok后,再运行进行测试.
通过上面两个方法,我的反地理编码已成功解决,希望看完文章后能够对您有所帮助!
Demo下载地址:
相关文章推荐
- 【开发小谈】百度地图术语总结 反地理编码的意思 地理围栏的意思
- (转)MySQL5.0中文问题及JDBC数据库连接和JSP汉字编码问题解决方法总结
- MySQL5.0中文问题及JDBC数据库连接和JSP汉字编码问题解决方法总结
- Python编码问题总结
- 字符集编码以及java乱码问题学习总结
- Java编码问题总结
- MySQL5.0中文问题及JDBC数据库连接和JSP汉字编码问题解决方法总结
- jruby 中文编码问题总结
- 编码问题 个人总结
- 编码与解码问题的总结
- JSP/Servlet编码问题总结(JAVA编码问题)
- MySQL5.0中文问题及JDBC数据库连接和JSP汉字编码问题解决方法总结
- JSP/Servlet编码问题总结
- ajax 编码问题总结
- Web 开发中遇到的UTF-8编码的问题总结第1/2页
- [ASP/PHP/JSP]MySQL5.0中文问题及JDBC数据库连接和JSP汉字编码问题解决方法总结
- jsp中中文编码问题的总结
- Ajax跟PHP交互时编码问题的总结
- PHP页面和Mysql数据库的转UTF8编码问题总结
- jsp 编码问题总结