UILabel的混合显示动画效果
2016-02-04 09:43
363 查看
源码
https://github.com/YouXianMing/Animations
// // MixedColorProgressViewController.m // Animations // // Created by YouXianMing on 16/1/5. // Copyright © 2016年 YouXianMing. All rights reserved. // #import "MixedColorProgressViewController.h" #import "UIView+SetRect.h" #import "GCD.h" @interface MixedColorProgressViewController () @property (nonatomic, strong) UIView *upView; @property (nonatomic, strong) UILabel *upLabel; @property (nonatomic, strong) UIView *downView; @property (nonatomic, strong) UILabel *downLabel; @property (nonatomic, strong) GCDTimer *timer; @end @implementation MixedColorProgressViewController - (void)setup { [super setup]; /* 给upView的frame值做动画才是label能够混色显示的核心 upView(红色背景) ===> upLabel(白色底字) | | | | | | | | downView(白色背景) ===> downLabel(红色底字) */ // 上面一层 { // 红色背景 _upView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 220, 17)]; _upView.center = self.view.center; _upView.layer.cornerRadius = 2.f; _upView.backgroundColor = [UIColor redColor]; _upView.layer.masksToBounds = YES; // 核心(不让subview显示超出范围) [self.view addSubview:_upView]; // 白色底字 _upLabel = [[UILabel alloc] initWithFrame:_upView.bounds]; _upLabel.font = [UIFont fontWithName:@"HelveticaNeue-Thin" size:13]; _upLabel.text = @"YouXianMing - iOS Programmer"; _upLabel.textColor = [UIColor whiteColor]; _upLabel.textAlignment = NSTextAlignmentCenter; [_upView addSubview:_upLabel]; } // 下面一层 { // 白色背景 _downView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 220, 17)]; _downView.center = self.view.center; _downView.layer.cornerRadius = 2.f; _downView.backgroundColor = [UIColor whiteColor]; [self.view addSubview:_downView]; // 红色底字 _downLabel = [[UILabel alloc] initWithFrame:_downView.bounds]; _downLabel.textColor = [UIColor redColor]; _downLabel.font = [UIFont fontWithName:@"HelveticaNeue-Thin" size:13]; _downLabel.text = @"YouXianMing - iOS Programmer"; _downLabel.textAlignment = NSTextAlignmentCenter; [_downView addSubview:_downLabel]; } // 显示上面一层 [self.view bringSubviewToFront:_upView]; // 给上面一层的frame值做动画 _timer = [[GCDTimer alloc] initInQueue:[GCDQueue mainQueue]]; [_timer event:^{ [UIView animateWithDuration:0.5f delay:0.f usingSpringWithDamping:3.f initialSpringVelocity:0 options:0 animations:^{ _upView.width = arc4random() % 220; } completion:nil]; } timeInterval:NSEC_PER_SEC]; [_timer start]; } @end
细节
相关文章推荐
- Arduino接口-week4-Lesson2
- Repeated DNA Sequences
- HDU 1005 Number Sequence
- SpeedTree - 建立UE4版本的模型
- 未来的UI/UX有哪些值得关注的发展趋势?
- weblogic 下异常 org.hibernate.QueryException
- 4、建造者模式(Builder)
- 简述Linq中.ToList(), .AsEnumerable(), AsQueryable()的区别和用法
- UITableView练习二之Dynamic Prototypes练习
- EasyUI的datagrid获取所有正在编辑状态的行的行编号
- POJ 2299 Ultra-QuickSort
- break,continue,return的区别
- HDU1242 rescue 【BFS+优先队列】
- UITableViewCell的循环利用 - 在storyboard里
- tableview跳转指定cell的某组某行的蛋疼问题
- POJ 2031 Building a Space Station(MST)
- Java并发之AbstractQueuedSynchronizer分析
- HandlerAPI介绍
- UITableViewCell的循环利用
- ndk-build生成.so