iOS芝麻信用仪表盘效果(一)

整体效果如下


表盘.gif

(一)做出白点旋转效果
大致说一下基础工作和需求:

基础工作:UI做好的表盘一个(可以自己绘制),带白点的条形图一个(我的白点其实是一个长条,除了白点其它是透明的,当然你可以用一个白点围绕着某个点做旋转)

需求:给定一个分数,白点相应旋转一定度数,分数显示的lab值递增,每达到20分星星亮一颗,背景色过渡变换,最后一段要求减速。

把整体分割一下,我们要做的动画有这么几个:

1.白点的旋转
2.分数值的变化
3.背景色的变化
4.减速的体现
5.动画同步

先说1、2、4
材料UI准备过了(表盘标准圆的一部分这点很重要,不然圆心找不对)。
既然几个动画的时间要同步,那么就要找一个基准点,围绕什么来规划,这里我选择了“分数值”(个人觉得除了分数值其他的做不了参考价值)。
这里自定义,每增加一个数值动画时间为X,我定义的为0.05,那么总的动画时间就有了,为0.05 * 分数,白点的旋转时间也就有了依据。这里挺简单的不多说。
说一下这个白点条条的设置,从图上可以看出白点在初始位置并不是水平的,说明我们一开始就要它围绕着圆心偏移一定的角度。
圆心怎么找呢,UI给的图非常标准这点非常感谢,如图显示我的仪表盘


92E26A30-DE88-4F64-9787-E93271165EF6.png

这样半径就是图片的width / 2,圆心就是(width / 2,height - width / 2),然后把白点条条放到圆心上(需要大致调整一下,因为有条条有高度),还要注意适配,等比例缩放可以解决
设置好之后开始设置围绕圆心旋转,这里需要设置锚点为(1.0,0.5),角度测一下就OK,因为等比例缩放不会改变度数,贴一下这段代码

    self.xuanZhuanView = [[UIImageView alloc] initWithFrame:CGRectMake(-JWScaleY(6.5), JWScaleY(128.5 - 7), JWScaleY(135), JWScaleY(14))];
    _xuanZhuanView.image = [UIImage imageNamed:@"旋转白点"];
    [self addSubview:_xuanZhuanView];
    _xuanZhuanView.layer.anchorPoint = CGPointMake(1, 0.5);
    self.xuanZhuanView.frame = CGRectMake(-JWScaleY(6.5), JWScaleY(128.5 - 7), JWScaleY(135), JWScaleY(14));
    CGAffineTransform transform = CGAffineTransformMakeRotation(-20 * M_PI/180.0);
    [_xuanZhuanView setTransform:transform];

这样初始状态就是这样的:

BE785070-0740-46DC-AED4-1C29ADAA5304.png

白点的旋转我选择了CALayer的基础动画,操作起来清晰简便,最重要的是它有个设置动画速度的属性,轻松达到减速效果。这里需要计算一下需要旋转多少度和一个临界值(这里是 9 分,9分以下是负值,以上是正值),设置旋转之后位置不恢复到起始点等属性。代码大致如下:

#pragma mark 圆点动画
- (void)yuanDianAnimation {
    [_instrumentView.xuanZhuanView.layer removeAllAnimations];
    CABasicAnimation *roteAnimation = [CABasicAnimation animationWithKeyPath:@"transform.rotation.z"];
    
    CGFloat rote = 0;
    
    if (grades < 9) {
        rote = -(20 - grades / 100.0);
    } else {
        rote = grades / 100.0 * 220 - 20;
    }
    
    roteAnimation.fromValue = [NSNumber numberWithFloat:-20 * M_PI/180.0];
    roteAnimation.toValue = [NSNumber numberWithFloat:rote * M_PI/180.0];

    //位置不恢复
    roteAnimation.fillMode = kCAFillModeForwards;
    roteAnimation.removedOnCompletion = NO;
    roteAnimation.duration = animationTime;

    //减速效果
    roteAnimation.timingFunction =
    [CAMediaTimingFunction functionWithName: kCAMediaTimingFunctionEaseInEaseOut];
    
    [_instrumentView.xuanZhuanView.layer addAnimation:roteAnimation forKey:@"rotationAnimation"];
    [_fastTimer setFireDate:[NSDate distantPast]];
}

到目前位置,白点的动画全部完毕,分数递增的动画匀速的话很简单,现在要做成渐变的,最后一段要明显减速,这里需要再做些处理。
这里我用了两个计时器fastTimer和slowTimer,大致思路如下(如果有更好的方法欢迎提出):

fastTimer负责百分之90的分数值递增,比如80分的话这个计时器方法负责0-72之间快速的方法处理,这个过程速度加快为0.05 * 0.9。然后计算剩下的时间和分数,得出多少秒需要执行一次慢速的方法处理。

这里注意,如果你的视图有滑动视图的话,因为RunLoop的原因需要手动将计时器加到CommonModes里,不然因为mode的切换影响计时器。
代码大致如下:

#pragma mark 设置定时器等事件
- (void)setUpThings {
    animationTime = grades * kTimerInterval;
    self.fastTimer = [NSTimer timerWithTimeInterval:kTimerInterval * kFastProportion target:self selector:@selector(fastTimerAction) userInfo:nil repeats:YES];
    [[NSRunLoop currentRunLoop] addTimer:_fastTimer forMode:NSRunLoopCommonModes];
    self.slowTimer = [NSTimer timerWithTimeInterval:(animationTime - kTimerInterval * kFastProportion * grades * kFastProportion) / (grades * (1 - kFastProportion)) target:self selector:@selector(slowTimerAction) userInfo:nil repeats:YES];
    [[NSRunLoop currentRunLoop] addTimer:_slowTimer forMode:NSRunLoopCommonModes];
    [_fastTimer setFireDate:[NSDate distantFuture]];
    [_slowTimer setFireDate:[NSDate distantFuture]];
}

#pragma mark 加速定时器触发事件
- (void)fastTimerAction {
    if (labTextNumber == grades) {
        [self.fastTimer invalidate];
        return;
    }
    if (labTextNumber > grades * kFastProportion) {
        [self.fastTimer invalidate];
        [self.slowTimer setFireDate:[NSDate distantPast]];
        return;
    }
    [self actionTimerConmmon];
}

#pragma mark 减速定时器触发事件
- (void)slowTimerAction {
    if (labTextNumber == grades) {
        [self.slowTimer invalidate];
        if (labTextNumber == 100) {
            _instrumentView.starView.starArray[4].image = [UIImage imageNamed:@"实心星星"];
        }
        return;
    }
    [self actionTimerConmmon];
}

#pragma mark 计时器共性事件 - lab赋值 背景颜色变化
- (void)actionTimerConmmon {
    if (labTextNumber % 20 == 0 && labTextNumber != 0) {
        NSInteger index = labTextNumber / 20;
        _instrumentView.starView.starArray[index - 1].image = [UIImage imageNamed:@"实心星星"];
    }
    if (labTextNumber % 7 == 0 && labTextNumber != 0) {
        NSInteger colorIndex = labTextNumber / 7;
        dispatch_async(dispatch_get_main_queue(), ^{
            [self setUpBackGroundColorWithColorArrayIndex:colorIndex];
        });
    }
    labTextNumber++;
    _instrumentView.gradeLab.text = [NSString stringWithFormat:@"%ld",labTextNumber];
}

到这里,白点和lab的动画就已经完成了,星星的动画很简单不多说了。
这里有个问题,lab的数值变化的时候抖动感很强烈,在芝麻信用里感觉不到,知道这个小bug解决方式的同学求指导。

个人原创,引用或转载请注明出处。

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

推荐阅读更多精彩内容

  • Core Animation Core Animation,中文翻译为核心动画,它是一组非常强大的动画处理API,...
    45b645c5912e阅读 3,013评论 0 21
  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥ios动画全貌。在这里你可以看...
    每天刷两次牙阅读 8,461评论 6 30
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,409评论 25 707
  • 不止从一个人或者几个人口中提到永生233这支钢笔出奇的好用,再加上这种富有二次元味道的名字,这次终于鼓足勇气,买了...
    nonozone阅读 895评论 0 1
  • 图先生是我相识的一位朋友,最近发生一起车祸,因车速过快,车翻了,车里的两个人从车里爬出去之后,不到一分钟,车子起火...
    旷野里的树儿阅读 456评论 3 10