ColorfulProgressView
效果
说明
1. 支持颜色定制
2. 进度条动画可以自己控制
3. 简单易用
源码
https://github.com/YouXianMing/UI-Component-Collection
//
// ColorfulProgressView.h
// ColorfulProgressView
//
// Created by YouXianMing on 15/7/13.
// Copyright (c) 2015年 YouXianMing. All rights reserved.
//
#import <UIKit/UIKit.h>
#import "ProgressColor.h"
@interface ColorfulProgressView : UIView
/**
* 进度
*/
@property (nonatomic) CGFloat progress;
/**
* 进度颜色(不设置的话有默认值)
*/
@property (nonatomic, strong) ProgressColor *progressColor;
/**
* 配置生效以及开始运行
*/
- (void)configAvailableAndBegin;
/**
* 便利构造器方法
*
* @param frame 尺寸
* @param progressColor 颜色值,可以为空
*
* @return 实例对象
*/
+ (instancetype)colorfulProgressViewWithFrame:(CGRect)frame progressColor:(ProgressColor *)progressColor;
@end
//
// ColorfulProgressView.m
// ColorfulProgressView
//
// Created by YouXianMing on 15/7/13.
// Copyright (c) 2015年 YouXianMing. All rights reserved.
//
#import "ColorfulProgressView.h"
@interface ColorfulProgressView () {
/**
* 当前view宽度
*/
CGFloat _width;
/**
* 当前view高度
*/
CGFloat _height;
}
@property (nonatomic, strong) UIView *baseView;
@property (nonatomic, strong) CAGradientLayer *gradientLayer;
@end
@implementation ColorfulProgressView
#pragma mark - 初始化与初始设置
- (instancetype)initWithFrame:(CGRect)frame {
self = [super initWithFrame:frame];
if (self) {
[self setup];
}
return self;
}
- (void)setup {
_width = self.frame.size.width;
_height = self.frame.size.height;
// baseView
self.baseView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 0, _height)];
self.baseView.layer.masksToBounds = YES;
[self addSubview:self.baseView];
// 渐变色Layer
self.gradientLayer = [CAGradientLayer layer];
self.gradientLayer.frame = self.bounds;
[self.baseView.layer addSublayer:self.gradientLayer];
}
#pragma mark -
- (void)configAvailableAndBegin {
// 如果没有设置ProgressColor,则自己生成一个
if (_progressColor == nil) {
_progressColor = [ProgressColor new];
NSMutableArray *cgColors = [NSMutableArray array];
for (NSInteger deg = 0; deg <= 360; deg += 5) {
UIColor *color = [UIColor colorWithHue:1.0 * deg / 360.0 saturation:1.0 brightness:1.0 alpha:1.0];
[cgColors addObject:(id)[color CGColor]];
}
_progressColor.cgColors = cgColors;
}
self.gradientLayer.colors = _progressColor.cgColors;
self.gradientLayer.startPoint = _progressColor.startPoint;
self.gradientLayer.endPoint = _progressColor.endPoint;
[self doAnimation];
}
- (void)doAnimation {
NSArray *fromColors = _progressColor.cgColors;
NSArray *toColors = [_progressColor accessColors];
_progressColor.cgColors = toColors;
CABasicAnimation *animation = [CABasicAnimation animationWithKeyPath:@"colors"];
animation.fromValue = fromColors;
animation.toValue = toColors;
animation.duration = _progressColor.duration;
animation.removedOnCompletion = YES;
animation.fillMode = kCAFillModeForwards;
animation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionLinear];
animation.delegate = self;
self.gradientLayer.colors = toColors;
[self.gradientLayer addAnimation:animation forKey:@"animateGradient"];
}
#pragma mark - 动画代理
- (void)animationDidStop:(CAAnimation *)anim finished:(BOOL)flag {
[self doAnimation];
}
#pragma mark - 便利构造器
+ (instancetype)colorfulProgressViewWithFrame:(CGRect)frame progressColor:(ProgressColor *)progressColor {
ColorfulProgressView *progressView = [[self alloc] initWithFrame:frame];
if (progressColor) {
progressView.progressColor = progressColor;
}
[progressView configAvailableAndBegin];
return progressView;
}
#pragma mark - 重写getter,setter方法
@synthesize progress = _progress;
- (void)setProgress:(CGFloat)progress {
_progress = progress;
if (progress <= 0) {
_baseView.frame = CGRectMake(0, 0, 0, _height);
} else if (progress <= 1) {
_baseView.frame = CGRectMake(0, 0, _progress * _width, _height);
} else {
_baseView.frame = CGRectMake(0, 0, _width, _height);
}
}
- (CGFloat)progress {
return _progress;
}
@end
//
// ProgressColor.h
// ColorfulProgressView
//
// Created by YouXianMing on 15/7/13.
// Copyright (c) 2015年 YouXianMing. All rights reserved.
//
#import <Foundation/Foundation.h>
#import <UIKit/UIKit.h>
@interface ProgressColor : NSObject
/**
* 存储的是CGColor的数组元素
*/
@property (nonatomic, strong) NSArray *cgColors;
/**
* 颜色起始点
*/
@property (nonatomic) CGPoint startPoint;
/**
* 颜色结束点
*/
@property (nonatomic) CGPoint endPoint;
/**
* 颜色移位一次的动画时间
*/
@property (nonatomic) NSTimeInterval duration;
/**
* -----------[ 子类可以重写该方法 ]-----------
*
* 转换颜色的算法
*
* @return 移位后的颜色数组
*/
- (NSArray *)accessColors;
#pragma mark - 便利构造器方法(自己添加方法)
+ (ProgressColor *)redGradientColor;
+ (ProgressColor *)yellowGradientColor;
@end
//
// ProgressColor.m
// ColorfulProgressView
//
// Created by YouXianMing on 15/7/13.
// Copyright (c) 2015年 YouXianMing. All rights reserved.
//
#import "ProgressColor.h"
@implementation ProgressColor
#pragma mark - 默认配置
- (instancetype)init {
self = [super init];
if (self) {
[self setup];
}
return self;
}
- (void)setup {
self.startPoint = CGPointMake(0.f, 0.5f);
self.endPoint = CGPointMake(1.f, 0.5f);
self.duration = 0.1f;
}
#pragma mark - 切换颜色的算法
- (NSArray *)accessColors {
NSMutableArray *mutable = [_cgColors mutableCopy];
id last = [mutable lastObject];
[mutable removeLastObject];
[mutable insertObject:last atIndex:0];
NSArray *colors = [NSArray arrayWithArray:mutable];
return colors;
}
#pragma mark - 便利构造器
+ (ProgressColor *)redGradientColor {
ProgressColor *color = [ProgressColor new];
NSMutableArray *cgColors = [NSMutableArray array];
[cgColors addObject:(id)[[UIColor colorWithRed:0.2f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.2f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.3f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.4f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.5f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.6f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.7f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.8f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.9f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:1.0f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:1.0f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:1.0f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:1.0f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:1.0f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:1.0f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:1.0f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:1.0f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.9f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.8f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.7f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.6f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.5f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.4f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.3f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.2f green:0.f blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0.2f green:0.f blue:0.f alpha:1.f] CGColor]];
color.cgColors = cgColors;
color.duration = 0.1f;
return color;
}
+ (ProgressColor *)yellowGradientColor {
ProgressColor *color = [ProgressColor new];
NSMutableArray *cgColors = [NSMutableArray array];
[cgColors addObject:(id)[[UIColor colorWithRed:0 green:0.1 blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0 green:0.2 blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0 green:0.3 blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0 green:0.3 blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0 green:0.2 blue:0.f alpha:1.f] CGColor]];
[cgColors addObject:(id)[[UIColor colorWithRed:0 green:0.1 blue:0.f alpha:1.f] CGColor]];
color.cgColors = cgColors;
color.duration = 0.5f;
return color;
}
@end
细节