激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - IOS - iOS實現(xiàn)帶動畫的環(huán)形進度條

iOS實現(xiàn)帶動畫的環(huán)形進度條

2021-03-02 15:59CUG IOS

這篇文章主要為大家詳細介紹了iOS實現(xiàn)帶動畫的環(huán)形進度條,同時帶數(shù)字同步效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本篇寫的是實現(xiàn)環(huán)形進度條,并帶動畫效果,要實現(xiàn)這些,僅能通過自己畫一個

方法直接看代碼

為了方便多次調(diào)用,用繼承UIView的方式

.m文件

?
1
2
3
4
5
6
7
8
#import <UIKit/UIKit.h>
 
@interface LoopProgressView : UIView
 
@property (nonatomic, assign) CGFloat progress;
 
 
@end

.h文件

NSTimer的調(diào)用并非精確,可以自行百度

 這里因為每0.01s啟動一次定時器,所以要同步進度條和數(shù)字,就將self.progress賦值給動畫的duration屬性就可以了,duration為動畫時間。

 在使用時我發(fā)現(xiàn)如果在tableviewcell中添加了這個環(huán)形進度條時有個缺點,就是定時器原本用的是系統(tǒng)的runloop,導致數(shù)據(jù)顯示滯后,所以現(xiàn)更新為子線程里添加定時器,子線程的定時器必須添加[[NSRunLoop currentRunLoop] run];才可啟動定時器,因為子線程的runloop里是不帶nstimer的,要手動添加運行。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
#import "LoopProgressView.h"
#import <QuartzCore/QuartzCore.h>
 
#define ViewWidth self.frame.size.width //環(huán)形進度條的視圖寬度
#define ProgressWidth 2.5   //環(huán)形進度條的圓環(huán)寬度
#define Radius ViewWidth/2-ProgressWidth //環(huán)形進度條的半徑
 
@interface LoopProgressView()
{
 CAShapeLayer *arcLayer;
 UILabel *label;
 NSTimer *progressTimer;
}
@property (nonatomic,assign)CGFloat i;
 
@end
 
@implementation LoopProgressView
 
-(id)initWithFrame:(CGRect)frame
{
 self = [super initWithFrame:frame];
 if (self) {
 self.backgroundColor = [UIColor clearColor];
 }
 return self;
}
 
-(void)drawRect:(CGRect)rect
{
 _i=0;
 CGContextRef progressContext = UIGraphicsGetCurrentContext();
 CGContextSetLineWidth(progressContext, ProgressWidth);
 CGContextSetRGBStrokeColor(progressContext, 209.0/255.0, 209.0/255.0, 209.0/255.0, 1);
 
 CGFloat xCenter = rect.size.width * 0.5;
 CGFloat yCenter = rect.size.height * 0.5;
 
 //繪制環(huán)形進度條底框
 CGContextAddArc(progressContext, xCenter, yCenter, Radius, 0, 2*M_PI, 0);
 CGContextDrawPath(progressContext, kCGPathStroke);
 
 // //繪制環(huán)形進度環(huán)
 CGFloat to = self.progress * M_PI * 2; // - M_PI * 0.5為改變初始位置
 
 // 進度數(shù)字字號,可自己根據(jù)自己需要,從視圖大小去適配字體字號
 int fontNum = ViewWidth/6;
 49 label = [[UILabel alloc]initWithFrame:CGRectMake(0, 0,Radius+10, ViewWidth/6)];
 label.center = CGPointMake(xCenter, yCenter);
 label.textAlignment = NSTextAlignmentCenter;
 label.font = [UIFont boldSystemFontOfSize:fontNum];
 label.text = @"0%";
 [self addSubview:label];
 
 UIBezierPath *path=[UIBezierPath bezierPath];
 [path addArcWithCenter:CGPointMake(xCenter,yCenter) radius:Radius startAngle:0 endAngle:to clockwise:YES];
 arcLayer=[CAShapeLayer layer];
 arcLayer.path=path.CGPath;//46,169,230
 arcLayer.fillColor = [UIColor clearColor].CGColor;
 arcLayer.strokeColor=[UIColor colorWithRed:227.0/255.0 green:91.0/255.0 blue:90.0/255.0 alpha:0.7].CGColor;
 arcLayer.lineWidth=ProgressWidth;
 arcLayer.backgroundColor = [UIColor blueColor].CGColor;
 [self.layer addSublayer:arcLayer];
 
 
 dispatch_async(dispatch_get_global_queue(0, 0), ^{
 [self drawLineAnimation:arcLayer];
 });
 
 if (self.progress > 1) {
 NSLog(@"傳入數(shù)值范圍為 0-1");
 self.progress = 1;
 }else if (self.progress < 0){
 NSLog(@"傳入數(shù)值范圍為 0-1");
 self.progress = 0;
 return;
 }
 
 if (self.progress > 0) {
 NSThread *thread = [[NSThread alloc]initWithTarget:self selector:@selector(newThread) object:nil];
 [thread start];
 }
 
}
 
-(void)newThread
{
 @autoreleasepool {
 progressTimer = [NSTimer scheduledTimerWithTimeInterval:0.01 target:self selector:@selector(timeLabel) userInfo:nil repeats:YES];
 [[NSRunLoop currentRunLoop] run];
 }
}
 
//NSTimer不會精準調(diào)用
-(void)timeLabel
{
 _i += 0.01;
 label.text = [NSString stringWithFormat:@"%.0f%%",_i*100];
 
 if (_i >= self.progress) {
 [progressTimer invalidate];
 progressTimer = nil;
 
 }
 
}
 
//定義動畫過程
-(void)drawLineAnimation:(CALayer*)layer
{
 CABasicAnimation *bas=[CABasicAnimation animationWithKeyPath:@"strokeEnd"];
 bas.duration=self.progress;//動畫時間
 bas.delegate=self;
 bas.fromValue=[NSNumber numberWithInteger:0];
 bas.toValue=[NSNumber numberWithInteger:1];
 [layer addAnimation:bas forKey:@"key"];
}
@end
 

完成后在要調(diào)用的控制器里,僅需幾段代碼:傳進的參數(shù):為0-1

?
1
2
3
LoopProgressView *custom = [[LoopProgressView alloc]initWithFrame:CGRectMake(50, 100, 100, 100)];
custom.progress = 0.44;
[self.view addSubview:custom];

實現(xiàn):

已經(jīng)實現(xiàn)進度條和數(shù)字的同步:

iOS實現(xiàn)帶動畫的環(huán)形進度條

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 毛片一级视频 | 久久久人人爽 | 黄色av片在线观看 | 草操视频 | lutube成人福利在线观看 | 国产精品av久久久久久无 | 国产二区三区在线播放 | 亚洲一区二区三区日本久久九 | 一级电影在线观看 | 日本一区视频在线播放 | 色人阁五月天 | 免费国产一级特黄久久 | 亚洲第一页中文字幕 | 亚洲最新色 | 国产精品久久久久一区二区 | 久久久三区 | 亚洲影院在线 | av免费在线网 | 中文字幕精品在线观看 | 99re66热这里只有精品8 | 13一14毛片免费看 | 深夜福利久久久 | 在线日韩在线 | 91嫩草丨国产丨精品入口 | 日韩视频一区二区在线观看 | 久久精品日产第一区二区三区 | 最新一级毛片 | 久久精品国产亚洲7777小说 | 亚洲第一成人在线视频 | 黄色二区三区 | www日韩大片 | 成人毛片免费 | 国产亚洲欧美在线视频 | 亚洲国产视频在线 | av在线免费观看中文字幕 | 免费观看三级毛片 | 国产乱淫av片免费 | 夜夜夜精品视频 | 91久久国产综合久久91精品网站 | 国产亚洲自拍一区 | 国产大片中文字幕在线观看 |