日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

ios弧形进度条_ios 圆形进度条

發(fā)布時間:2024/10/8 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ios弧形进度条_ios 圆形进度条 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

今天產(chǎn)品要弄一個圓形的進度條

1532512706923.jpg

有很多開源的進度條不用,非要弄這種效果,就不吐槽了,還是想想怎么實現(xiàn)

廢話就不多說了 直接上代碼

#import

@interface RoundProgressView : UIView

/**進度條顏色*/

@property (strong, nonatomic) UIColor *progressColor;

/**dash pattern*/

@property (strong, nonatomic) NSArray *lineDashPattern;

/**進度Label字體*/

@property (strong, nonatomic) UIFont *progressFont;

- (void)updateProgress:(CGFloat)progress;

@end

#import "RoundProgressView.h"

#define kBorderWith 10

#define center CGPointMake(self.bounds.size.width / 2.0, self.bounds.size.height / 2.0)

@interface RoundProgressView()

@property (strong, nonatomic) CAShapeLayer *outLayer;

@property (strong, nonatomic) CAShapeLayer *progressLayer;

@property (strong, nonatomic) UILabel *progressLabel;

@end

@implementation RoundProgressView

/*

// Only override drawRect: if you perform custom drawing.

// An empty implementation adversely affects performance during animation.

- (void)drawRect:(CGRect)rect {

// Drawing code

}

*/

- (instancetype)initWithFrame:(CGRect)frame

{

self = [super initWithFrame:frame];

if (self) {

[self drawProgress];

}

return self;

}

-(void)drawProgress{

UIBezierPath *loopPath = [UIBezierPath bezierPathWithArcCenter:center radius:(self.bounds.size.width - kBorderWith)/ 2.0 startAngle:-M_PI_2 endAngle:M_PI * 3.0 / 2.0 clockwise:YES];

// 外圈

self.outLayer = [CAShapeLayer layer];

self.outLayer.strokeColor = [UIColor lightGrayColor].CGColor;

self.outLayer.lineWidth = kBorderWith;

self.outLayer.fillColor = [UIColor clearColor].CGColor;

self.outLayer.path = loopPath.CGPath;

[self.layer addSublayer:self.outLayer];

// 進度條

self.progressLayer = [CAShapeLayer layer];

self.progressLayer.fillColor = [UIColor clearColor].CGColor;

self.progressLayer.strokeColor = [UIColor blackColor].CGColor;

self.progressLayer.lineWidth = kBorderWith;

self.progressLayer.strokeStart = 0;

self.progressLayer.strokeEnd = 0;

self.progressLayer.path = loopPath.CGPath;

[self.layer addSublayer:self.progressLayer];

// 進度Label

self.progressLabel = [UILabel new];

self.progressLabel.frame = CGRectMake(0, 0, self.frame.size.width, self.frame.size.height);

self.progressLabel.font = [UIFont systemFontOfSize:40];

self.progressLabel.textAlignment = NSTextAlignmentCenter;

[self addSubview:self.progressLabel];

}

- (void)updateProgress:(CGFloat)progress {

[CATransaction begin];

[CATransaction setAnimationTimingFunction:[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseIn]];

[CATransaction setAnimationDuration:0.5];

self.progressLayer.strokeEnd = progress / 100.0;

[CATransaction commit];

self.progressLabel.text = [NSString stringWithFormat:@"%.0f",progress];

}

- (void)setLineDashPattern:(NSArray *)lineDashPattern

{

_lineDashPattern = lineDashPattern;

self.outLayer.lineDashPattern = lineDashPattern;

self.progressLayer.lineDashPattern = lineDashPattern;

}

- (void)setProgressColor:(UIColor *)progressColor

{

self.progressLayer.strokeColor = progressColor.CGColor;

self.progressLabel.textColor = progressColor;

}

- (void)setProgressFont:(UIFont *)progressFont

{

self.progressLabel.font = progressFont;

}

調(diào)用

- (void)viewDidLoad {

[super viewDidLoad];

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

self.progressView =[[RoundProgressView alloc]initWithFrame:CGRectMake((ScreenWidth - 200)/2, 100, 200, 200)];

self.progressView.backgroundColor = [UIColor yellowColor];

[self.progressView setProgressColor:[UIColor blueColor]];

self.progressView.lineDashPattern = @[@(8),@(5)];

self.progressView.progressFont = [UIFont systemFontOfSize:70];

[self.view addSubview:self.progressView];

}

- (void)viewDidAppear:(BOOL)animated

{

[super viewDidAppear:animated];

[self.progressView updateProgress:25];

}

與50位技術(shù)專家面對面20年技術(shù)見證,附贈技術(shù)全景圖

總結(jié)

以上是生活随笔為你收集整理的ios弧形进度条_ios 圆形进度条的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。