iOS高德地图自定义定位小蓝点

首先看下高德默认的小蓝点效果



再来看下我们产品要实现的效果



有没有熟悉的感觉,没错,就是模仿keep的,我们的产品真的是对keep大爱啊。

要自定义定位点,首先要展示当前定位点,用到这个属性,设置为YES

///是否显示用户位置
@property (nonatomic) BOOL showsUserLocation;

对于当前定位点来说,它也是一个MAAnnotation标注,但是高德对它单独封装了一个类,继承自MAAnnotation,叫做MAUserLocation。我们设置了showsUserLocation为YES之后,只要在这个代理方法里面对该类型标注进行处理,即能实现自定义效果。

/**
 * @brief 根据anntation生成对应的View
 * @param mapView 地图View
 * @param annotation 指定的标注
 * @return 生成的标注View
 */
- (MAAnnotationView *)mapView:(MAMapView *)mapView viewForAnnotation:(id <MAAnnotation>)annotation;

然后我们先来设置一张图片,替换掉它官方的白底蓝色呼吸点,看看什么效果

- (MAAnnotationView *)mapView:(MAMapView *)mapView viewForAnnotation:(id<MAAnnotation>)annotation
{
    if ([annotation isKindOfClass:[MAUserLocation class]]) {
        static NSString *userLocationStyleReuseIndetifier = @"userLocationStyleReuseIndetifier";
        MAAnnotationView *annotationView = [mapView dequeueReusableAnnotationViewWithIdentifier:userLocationStyleReuseIndetifier];
        if (annotationView == nil) {
            annotationView = [[MAPinAnnotationView alloc] initWithAnnotation:annotation reuseIdentifier:userLocationStyleReuseIndetifier];
        }
        annotationView.image = [UIImage imageNamed:@"icon_tracking_userLocation"];
        self.userLocationAnnotationView = annotationView;
        return annotationView;
    }
    return nil;
}

替换了张图片,效果出来了,但是,这个呼吸效果呢,哪个白点呢!!!
少年,你还是太天真,你以为这样换张图片就能搞定?!图样图森破!
这个放着,我们先来优化下这个图标。首先,箭头出来,就表示需要根据方位指示。
我们只要获取到当前定位点的定位信息,拿出来方向的值,处理下即可。
首先,声明一个标注属性

@property (nonatomic, strong) MAAnnotationView *userLocationAnnotationView;

前面我们在- (MAAnnotationView *)mapView:(MAMapView *)mapView viewForAnnotation:(id<MAAnnotation>)annotation的方法里面已经关联到了自定义的定位点

self.userLocationAnnotationView = annotationView;

然后再定位回调里面如下设置,就能实时指示当前方位。

- (void)mapView:(MAMapView *)mapView didUpdateUserLocation:(MAUserLocation *)userLocation updatingLocation:(BOOL)updatingLocation
{
    if (!updatingLocation && self.userLocationAnnotationView != nil) {
        [UIView animateWithDuration:0.1 animations:^{
            double degree = userLocation.heading.trueHeading - self.mapView.rotationDegree;
            self.userLocationAnnotationView.transform = CGAffineTransformMakeRotation(degree * M_PI / 180.f );
        }];
    }
}

那么问题来了,那个呼吸的白底圆点呢???!!!
少年,不要心急,下面就来说说这个实现。
既然定位点是个标注MAAnnotationView,先点进去文件看看,没有啥相关的设置,那就只能继承MAAnnotationView自定义标注了。
首先把customizeUserLocationAccuracyCircleRepresentation这是为YES

@property (nonatomic) BOOL customizeUserLocationAccuracyCircleRepresentation;

然后新建一个类,继承自MAAnnotationView

#import <MAMapKit/MAMapKit.h>

@interface YTUserLocationAnnotationView : MAAnnotationView

@end

接着代理方法里面修改下类

- (MAAnnotationView *)mapView:(MAMapView *)mapView viewForAnnotation:(id<MAAnnotation>)annotation
{
    if ([annotation isKindOfClass:[MAUserLocation class]]) {
        static NSString *userLocationStyleReuseIndetifier = @"userLocationStyleReuseIndetifier";
        YTUserLocationAnnotationView *annotationView = (YTUserLocationAnnotationView *)[mapView dequeueReusableAnnotationViewWithIdentifier:userLocationStyleReuseIndetifier];
        if (annotationView == nil) {
            annotationView = [[YTUserLocationAnnotationView alloc] initWithAnnotation:annotation reuseIdentifier:userLocationStyleReuseIndetifier];
        }
        annotationView.image = [UIImage imageNamed:@"icon_tracking_userLocation"];
        self.userLocationAnnotationView = annotationView;
        //为了让位置点永远在图层最上面,设置选定图标。
        //高德SDK5.4.0必须在主线程选定图标,否则会导致界面进入地图加载卡死,暂时不懂为何
        dispatch_async(dispatch_get_main_queue(), ^{
            [self.mapView selectAnnotation:annotation animated:NO];
        });
        return annotationView;
    }
    return nil
}

在自定义的定位点类里面实现didMoveToSuperview方法,当 annotation 被添加到地图上就会触发,然后就可以执行需要的动画了,具体实现如下。

#import "YTUserLocationAnnotationView.h"

@interface YTUserLocationAnnotationView ()

@property (nonatomic, strong) CALayer *circleView;

@end

@implementation YTUserLocationAnnotationView

- (CALayer *)circleView
{
    if (!_circleView) {
        _circleView = [CALayer layer];
        _circleView.frame = CGRectMake(0, 0, self.ab_width + 6, self.ab_height + 6);
        _circleView.position = self.imageView.center;
        _circleView.backgroundColor = [UIColor whiteColor].CGColor;
        _circleView.cornerRadius = _circleView.frame.size.width / 2;
        [self.layer insertSublayer:_circleView below:self.imageView.layer];
    }
    return _circleView;
}

- (void)didMoveToSuperview
{
    [super didMoveToSuperview];
    
    [self startAnimate];
}

- (void)startAnimate
{
    CABasicAnimation *animation = [CABasicAnimation animationWithKeyPath:@"transform.scale"];
    animation.fromValue = [NSNumber numberWithFloat:1.0f];
    animation.toValue = [NSNumber numberWithFloat:2.2f];
    animation.autoreverses = YES;
    animation.duration = 1.f;
    animation.repeatCount = MAXFLOAT;
    animation.removedOnCompletion = NO;
    animation.fillMode = kCAFillModeForwards;
    animation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];
    [self.circleView addAnimation:animation forKey:nil];
}

- (void)dealloc
{
    DLog(@"%s",__func__);
}

掌握了这个小技巧,你也能实现各种各样的定位点展示UI。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,233评论 6 495
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,357评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,831评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,313评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,417评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,470评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,482评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,265评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,708评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,997评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,176评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,503评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,150评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,391评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,034评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,063评论 2 352

推荐阅读更多精彩内容