#import <UIKit/UIKit.h>

@interface JianBianView : UIView

//为了增加一个表示进度条的进行,可们可以使用mask属性来屏蔽一部分

@property (nonatomic, strong) CALayer *maskLayer;

@property (nonatomic, assign) CGFloat progress;

//动画方法

-(void)performAnimation;

-(void)setProgress:(CGFloat)value;

@end

#import "JianBianView.h"

@implementation JianBianView

@synthesize maskLayer,progress;

+(Class)layerClass

{

//设置默认是 CAGradientLayer

return [CAGradientLayer class];

}

-(id)initWithFrame:(CGRect)frame

{

self = [super initWithFrame:frame];

if (self)

{

maskLayer = [CALayer layer];

[maskLayer setFrame:CGRectMake(0, 0, 0, frame.size.height)];

[maskLayer setBackgroundColor:[UIColor blackColor].CGColor];

CAGradientLayer *layer = (id)[self layer];

[layer setStartPoint:CGPointMake(0.0, 0.5)];

[layer setEndPoint:CGPointMake(1.0, 0.5)];

NSMutableArray *colors = [[NSMutableArray alloc] init];

for (NSInteger hue = 0; hue < 360; hue += 5)

{

UIColor *color;

//hue 色调 saturation 饱和度 brightness 亮度

color = [UIColor colorWithHue:1.0*hue/360.0 saturation:1.0 brightness:1.0 alpha:1.0];

[colors addObject:(id)[color CGColor]];

}

[layer setColors:[NSArray arrayWithArray:colors]];

[layer setMask:maskLayer];

}

return self;

}

//创建一个宽度为0的mask覆盖整个View,mask的颜色不重要,当我们progress属性更新的时候我们会增加它的宽度 然后在initWithFrame:里面添加:

/*

maskLayer = [CALayer layer];

[maskLayer setFrame:CGRectMake(0, 0, 0, frame.size.height)];

[maskLayer setBackgroundColor:[UIColor blackColor].CGColor];

*/

//所以重写setProgress:

-(void)setProgress:(CGFloat)value

{

if (progress != value)

{

progress = MIN(1.0, fabs(value));

[self setNeedsLayout];

}

}

-(void)layoutSubviews

{

CGRect maskRect = [maskLayer frame];

maskRect.size.width = CGRectGetWidth([self bounds]) * progress;

[maskLayer setFrame:maskRect];

}

-(void)performAnimation

{

// Move the last color in the array to the front

// shifting all the other colors.

CAGradientLayer *layer = (id)[self layer];

NSMutableArray *mutable = [[layer colors] mutableCopy];

id lastColor = [mutable lastObject];

[mutable removeLastObject];

[mutable insertObject:lastColor atIndex:0];

NSArray *shiftColors = [NSArray arrayWithArray:mutable];

[layer setColors:shiftColors];

CABasicAnimation *animation;

animation = [CABasicAnimation animationWithKeyPath:@"Colors"];

[animation setToValue:shiftColors];

[animation setDuration:0.08];

[animation setRemovedOnCompletion:YES];

[animation setFillMode:kCAFillModeForwards];

[animation setDelegate:self];

[layer addAnimation:animation forKey:@""];

}

-(void)animationDidStop:(CAAnimation *)anim finished:(BOOL)flag

{

[self performAnimation];

}

@end

视图控制器 调用

- (void)viewDidLoad

{

[super viewDidLoad];

// Do any additional setup after loading the view, typically from a nib.

self.title = @"渐变测试";

self.view.backgroundColor = [UIColor whiteColor];

//    [self jianBianMethord];

[NSTimer scheduledTimerWithTimeInterval:1.0 target:self selector:@selector(timeMethod) userInfo:nil repeats:YES];

[self addJianBianView];

}

-(void)timeMethod

{

NSLog(@"进入");

progress += 0.1;

[self.jianBianView setProgress:progress];

}

//-----------添加渐变view

-(void)addJianBianView

{

if (self.jianBianView == nil)

{

self.jianBianView = [[JianBianView alloc] initWithFrame:CGRectMake(0, 100, self.view.frame.size.width, 10)];

[self.view addSubview:self.jianBianView];

[self.jianBianView performAnimation];

}

}

iOS 渐变进度条的更多相关文章

  1. 【iOS】环形渐变进度条实现

    之前有人在找渐变进度条的效果,闲来无事就顺手写了一个,然后画了视图层级,方便讲解. 环境信息: Mac OS X 10.10.3 Xcode 6.3.1 iOS 8.3 效果图: 源码下载地址: ht ...

  2. iOS圆弧渐变进度条的实现

    由于项目需要一个环形渐变进度条显示课程,这方便网上的确有很多相关资料但是,都是比较零散的而且,大多数只是放一堆代码就算完了.这里我想详细写一篇我自己实现这个进度条的过程. 实现一个圆弧进度条主要分为三 ...

  3. 自定义控件之圆形颜色渐变进度条--SweepGradient

    前几天在群里面有人找圆形可颜色渐变进度条,其中主要的知识点是SweepGradient: mSweepGradient = new SweepGradient(240, 360, new int[] ...

  4. iOS 自定义进度条

    自定义条形进度条(iOS) ViewController.m文件 #import "ViewController.h" @interface ViewController () @ ...

  5. [iOS]圆形进度条及计时功能

    平时用战网安全令的时候很喜欢圆形倒计时的效果,然后简单看了一下Android的圆形进度条,后来又写了一个IOS的.整体界面参照IOS系统的倒计时功能,顺便熟悉了UIPickerView的一些特性的实现 ...

  6. android自己定义渐变进度条

    项目中须要用到一个弧形渐变的进度条,通过android自带是不能实现的.我是没有找到实现的方法,有大神知道的能够指点.效果图是以下这种 这是通过继承VIew来绘制出来的,网上也有相似的,可是代码那是相 ...

  7. vue 渐变 进度条 progress

    废话 不多少说 ,直接上代码 新建文件 gradual-progress.vue <!-- * @Author: gfc * @Date: 2019-11-07 14:00:11 * @Last ...

  8. svg和css3创建环形渐变进度条

    在负责的项目中,有一个环形渐变读取进度的效果的需求,于是在网上查阅相关资料整理一下.代码如下: <!DOCTYPE html> <html lang="en"&g ...

  9. canvas锥形渐变进度条

    从一个渐变圆角进度条浅出画一个圆 开始 这一切需要从一个(简单)的需求开始,在最开始对设计第一眼看到这张图的时候,感觉挺简单的嘛,直接用echarts饼图模拟出来一个就好了 echarts 然后上ec ...

随机推荐

  1. C#编码规范 转 http://www.cnblogs.com/wulinfeng/archive/2012/08/31/2664720.html

    C#编码规范   1  规范目的 ……………………………………………………… 3 2  适用范围 ……………………………………………………… 3 3  代码注释 ………………………………………………… ...

  2. (47) odoo详细操作手册

    odoo 8 详细操作手册, ERP(Odoo8.0)操作手册-v1.10(陈伟明).pdf 链接: http://pan.baidu.com/s/1hsp0bVQ 密码: r9tt 花了将近9个月时 ...

  3. 简单的验证码识别(opecv)

    opencv版本: 3.0.0 处理验证码: 纯数字验证码 (颜色不同,有噪音,和带有较多的划痕) 测试时间 :  一天+一晚 效果: 比较挫,可能是由于测试的图片是在太小了的缘故. 原理:  验证码 ...

  4. VC比例放大缩小

    CRect rect; ::GetWindowRect(m_hWnd, rect); ScreenToClient(rect); m_nDlgWidth = rect.right - rect.lef ...

  5. 新春测 kinect motor

    大年30,祝所有开发伙伴新春快乐. 天天FQ, 叹国内学习成本太高 看到一篇台湾 kinect 电机控制, 赞 using Microsoft.Kinect; using System; using ...

  6. SharePoint Foundation 2013 安装出错

    前段时间装foundation 13的时候遇到这个问题.怀疑是Office的问题.然后找了一些资料,问题得到了解决 解决方案: 运行 regedit,删除注册表下的office的LicenseType ...

  7. java 中Session 持久化问题

    首先: 今天发现了个session 持久化的问题 在Tomcat 停止运行后再启动  session  中保存的东西还会存在 ,百度了一下 原理 1.Session Create 时 2.Sessio ...

  8. uva 10817(状压dp)

    题意:就是有个学校要招老师.要让没门课至少有两个老师可以上.每个样样例先输入三个数字课程数量s,已经在任的老师数量,和应聘的老师数量.已经在任的一定要聘请. 思路是参考了刘汝佳书上的,关键如何状压. ...

  9. 【基本技能篇】>>第3篇《暗时间_指导学习的方法论——心得》

    暗时间——指导学习的方法论 ——2016年2月11日 打造自己的核心竞争力:①专业领域技能:②跨领域的技能(解决问题的能力,创新思维,判断与决策能力,表达沟通能力等等):③学习能力,持续学习和思考新知 ...

  10. vue-todolist

    look:先看效果: 在浏览器的地址输入localhost:8080时,页面展示的是coding和walking两个无序序列,接着在输入框输入任何字符再敲enter回车键时,列表中又增加了一列,但是只 ...