日韩性视频-久久久蜜桃-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)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产精品国产三级国产aⅴ中文 | 精品三区视频 | 国产高清一级片 | 欧美卡一卡二 | 97黄色片| 伊人久久大香线 | 可以在线观看的av网站 | 孕妇疯狂做爰xxxⅹ 国产精品乱码久久久久久 99久久久成人国产精品 | 亚洲首页| 91手机视频| 蜜桃av导航 | 久精品在线观看 | 中文字幕首页 | 亚洲一区日韩 | 牛牛电影国产一区二区 | 成年人免费网 | 91av国产在线 | 国产网红女主播精品视频 | 国产一区二区视频播放 | 欧洲亚洲精品 | 国产乱码久久久久 | 开心春色激情网 | 成人18视频在线观看 | 日韩毛片一区二区三区 | 制服丝袜影音先锋 | 在线免费国产 | 久久精品久久精品 | 伊人久久五月天 | 插插操操| 最新精品国产 | 欧美精品自拍视频 | 亚洲精品国产精品乱码不卡√香蕉 | 九色一区 | 成人影院免费 | 制服丝袜国产精品 | 98精品视频 | 精品一区精品二区 | 乱精品一区字幕二区 | 俺去日| 日本不卡在线观看 | 国产高清视频免费在线观看 | 中文字幕综合在线 | 成人爱爱| 黄色中文视频 | 一本色道久久综合亚洲精品 | 国产综合精品在线 | 成人久久免费 | 亚洲第一色视频 | www狠狠| 天天天干| 国产精品精东影业 | 91亚洲精品久久久久久久久久久久 | 日韩av在线看免费观看 | 黑人干亚洲 | 国产美女无遮挡免费 | 成人免费视频大全 | 免费视频一二三区 | 国产丝袜一区二区 | 久久99久久98精品免观看软件 | 欧美成年人视频 | 99色图 | 亚洲v欧美v另类v综合v日韩v | 国产一区综合 | 精品视频国产 | 亚洲乱轮视频 | 久久久久久久久久久久电影 | 亚洲久久一区二区 | 亚洲av无码国产精品久久 | 91精品国产91久久久久青草 | 伊人欧美 | 曰本黄色片 | 亚洲综合91 | 午夜婷婷网 | 国产亚洲精品久久久久久 | 少妇喷水在线观看 | 风间由美av | 成年人一级黄色片 | 国产精品高潮呻吟久久av野狼 | 秋霞视频在线 | 在线看h网站| 免费亚洲一区二区 | 最近免费中文字幕中文高清百度 | 求免费黄色网址 | jk美女又爽又黄视频 | 日本少妇久久久 | 午夜国产一区 | 嫩草亚洲| 亚洲区色| 久久久96人妻无码精品 | 日本大乳奶做爰 | sm久久捆绑调教精品一区 | 久久久久免费精品视频 | 成人午夜视频在线免费观看 | 老熟女重囗味hdxx69 | 欧美久久综合网 | 亚洲综合在线一区二区 | 91网视频| 国产成人精品无码高潮 | 窝窝午夜精品一区二区 |