本人有若干成套学习视频, 可试看! 可试看! 可试看, 重要的事情说三遍 包含Java
, 数据结构与算法
, iOS
, 安卓
, python
, flutter
等等, 如有需要, 联系微信tsaievan
.
其实利用反地理编码显示大头针的位置并不是一个非常复杂的内容,
在我写的这个 demo 中, 可以看到的是:
我必须将大头针显示在屏幕的正中央, 这个大头针的视图是添加在 view 上的,所以在地图显示出来的时候, 拖动地图并不会造成大头针跟着移动, 我们将大头针所处的点实时地转化为地图上的点,然后将地图上的坐标通过反地理编码就可以显示出当前的位置, 基本的思路就是这样.
我还是用一张思维导图来显示这个思路:
具体实现步骤如下
- 我在视图底部的 toolBar 上加上了一个 barButtonItem, 即查找位置,这个按钮点击事件的处理代码是这样的:
// -------- 显示大头针所在位置信息 --------
- (IBAction)showPinButtonPlaceAction:(UIBarButtonItem *)sender {
[kBaiduMapManager showMapCenterLocationWithSuccessBlock:^(UIButton *pinButton) {
pinButton.center = CGPointMake(self.view.center.x, self.view.center.y - pinButton.bounds.size.height);
[self.view addSubview:pinButton];
[self.view bringSubviewToFront:pinButton];
} andView:self.view];
}
在上面的这个 方法中,我将 Button 先创建好, 再回调给 ViewController, 然后再将 self.view 作为参数传给这个方法内部, 这样就用一个方法的调用就完成了多件事情
1.button 的创建,这个 button 实际上就是位于视图中间的大头针
2.将 button 添加到视图的正中央
这个方法内部的实现是这样的:
// -------- 在视图中间显示一个大头针 --------
- (void)showMapCenterLocationWithSuccessBlock:(void(^)(UIButton *pinButton))successBlock andView:(UIView *)view
{
kBaiduMapManager.geoCodeSearch.delegate = self;
UIButton *pinButton = [UIButton buttonWithType:UIButtonTypeCustom];
[pinButton setImage:[UIImage imageNamed:@"cm2_discover_icn_abc"] forState:UIControlStateNormal];
[pinButton sizeToFit];
self.pinButton = pinButton;
successBlock(pinButton);
}
- 当地图显示的区域发生变化的时候, mapView 的代理会走,在这个代理中,我们提交反地理编码请求, 将大头针底部所指的点转化成地理坐标, 赋值给反地理编码请求的属性
// -------- 当前的地图视图发生改变的时候调用这个 API --------
- (void)mapView:(BMKMapView *)mapView regionDidChangeAnimated:(BOOL)animated
{
/* 创建一个反地理编码请求 */
BMKReverseGeoCodeOption *reverseGeoCodeOption = [[BMKReverseGeoCodeOption alloc]init];
/* 给反地理编码请求的属性赋值,告诉请求,你需要将地图上的哪个点的坐标反地理编码 */
reverseGeoCodeOption.reverseGeoPoint = [mapView convertPoint:CGPointMake(self.pinButton.center.x, CGRectGetMaxY(self.pinButton.frame)) toCoordinateFromView:self.pinButton.superview];
/* 提交反地理编码请求,提交请求之后,服务器返回的结果就会在代理方法里完成回调 */
[kBaiduMapManager.geoCodeSearch reverseGeoCode:reverseGeoCodeOption];
}
- 请求提交后,服务器通过代理返回一个结果,然后我们再通过 BaiduMapManager 的代理将结果返回给控制器
#pragma mark *** BMKGeoCodeSearchDelegate 代理 API 回调 ***
- (void)onGetReverseGeoCodeResult:(BMKGeoCodeSearch *)searcher result:(BMKReverseGeoCodeResult *)result errorCode:(BMKSearchErrorCode)error
{
/* 反地理编码结果的回调通过代理回传给控制器 */
if ([self.delegate respondsToSelector:@selector(baiduMapManager:getAddressName:)]) {
[self.delegate baiduMapManager:self getAddressName:result.address];
}
}
- 控制器实现 BaiduMapManager 的代理方法,将结果赋值给 label, 这样就可以实时地显示当前大头针所指的地理位置了
#pragma mark *** BaiduMapManagerDelegate代理API 回调 ***
- (void)baiduMapManager:(BaiduMapManager *)manager getAddressName:(NSString *)addressName
{
self.popView.hidden = (addressName.length == 0)?YES:NO;
[self.view bringSubviewToFront:self.popView];
self.placeTipLabel.text = addressName;
}
这样就实现了实时显示大头针底部所指位置的需求了
以上这5篇文章只是百度地图的入门阶段, 还有很多地方值得我们去挖掘, 在写代码的过程中, 也会遇到很多坑, 有时候耗很久都跳不出来, 但是这就是学习的过程.世界很大, 牛人很多, 唯有勤奋能够提高自己.
导了百度的框架, 有50M, 坑爹啊, 之前没提交 github, 现在要一次性提交实在卡得不行, 上 github 又奇慢无比, 只有打个包上传百度云盘了, 需要的同学可以下载, 欢迎提出宝贵意见, 一起学习进步
附上源码链接: 下载 demo链接