亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁(yè) > 系統(tǒng) > iOS > 正文

iOS實(shí)現(xiàn)音頻進(jìn)度條效果

2019-10-21 18:39:32
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前幾天開(kāi)發(fā)群里有一個(gè)老兄問(wèn)了一個(gè)開(kāi)發(fā)問(wèn)題,他們的需求是要做一個(gè)類似音頻進(jìn)度條的東西,我感覺(jué)設(shè)計(jì)還不錯(cuò),于是就寫了個(gè)小demo供大家參考,在爭(zhēng)得了他的同意的情況下寫下這篇文章。

話不多說(shuō)先上效果圖

iOS,音頻,進(jìn)度條

看到這個(gè)效果的時(shí)候我感覺(jué)相對(duì)比較難的點(diǎn)有兩點(diǎn):

一、是這個(gè)進(jìn)度條的進(jìn)度顏色變化,這里思路還是比較清晰的,直接用layer的mask來(lái)做就可以。

二、第二點(diǎn)就是這個(gè)各各條條的高度不一致又沒(méi)有規(guī)律可言,在各個(gè)方法中我最終選擇用隨機(jī)數(shù)來(lái)做。

  好了思路清晰了,那就開(kāi)始擼代碼了。

首先創(chuàng)建一個(gè)View CYXAudioProgressView

@interface CYXAudioProgressView : UIView//無(wú)動(dòng)畫設(shè)置 進(jìn)度@property (assign, nonatomic) CGFloat persentage;//有動(dòng)畫設(shè)置 進(jìn)度 0~1-(void)setAnimationPersentage:(CGFloat)persentage;/** 初始化layer 在完成frame賦值后調(diào)用一下 */-(void)initLayers;@end

成員變量及初始化方法

/*條條間隙*/#define kDrawMargin 4#define kDrawLineWidth 8/*差值*/#define differenceValue 51@interface CYXAudioProgressView ()<CAAnimationDelegate>/*條條 灰色路徑*/@property (nonatomic,strong) CAShapeLayer *shapeLayer;/*背景黃色*/@property (nonatomic,strong) CAShapeLayer *backColorLayer;@property (nonatomic,strong) CAShapeLayer *maskLayer;@end@implementation CYXAudioProgressView-(instancetype)initWithFrame:(CGRect)frame{ if (self = [super initWithFrame:frame]) { self.backgroundColor = [UIColor blackColor]; [self.layer addSublayer:self.shapeLayer]; [self.layer addSublayer:self.backColorLayer]; self.persentage = 0.0; } return self;}

畫圖方法:

/** 初始化layer 在完成frame賦值后調(diào)用一下 */-(void)initLayers{ [self initStrokeLayer]; [self setBackColorLayer];}

繪制路徑

/*路徑*/-(void)initStrokeLayer{ UIBezierPath *path = [UIBezierPath bezierPath]; CGFloat maxWidth = self.frame.size.width; CGFloat drawHeight = self.frame.size.height; CGFloat x = 0.0; while (x+kDrawLineWidth<=maxWidth) { CGFloat random =5+ arc4random()%differenceValue;//差值在1-50 之間取 NSLog(@"%f",random); [path moveToPoint:CGPointMake(x-kDrawLineWidth/2, random)]; [path addLineToPoint:CGPointMake(x-kDrawLineWidth/2, drawHeight-random)]; x+=kDrawLineWidth; x+=kDrawMargin; } self.shapeLayer.path = path.CGPath; self.backColorLayer.path = path.CGPath;}

設(shè)置mask來(lái)顯示黃色路徑

/*設(shè)置masklayer*/-(void)setBackColorLayer{ UIBezierPath *path = [UIBezierPath bezierPath]; [path moveToPoint:CGPointMake(0, self.frame.size.height/2)]; [path addLineToPoint:CGPointMake(self.frame.size.width, self.frame.size.height/2)]; self.maskLayer.frame = self.bounds; self.maskLayer.lineWidth = self.frame.size.width; self.maskLayer.path= path.CGPath; self.backColorLayer.mask = self.maskLayer;}

手動(dòng)設(shè)置百分比的兩個(gè)方法

-(void)setAnimationPersentage:(CGFloat)persentage{ CGFloat startPersentage = self.persentage; [self setPersentage:persentage]; CABasicAnimation *pathAnimation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"]; pathAnimation.duration = 1; pathAnimation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut]; pathAnimation.fromValue = [NSNumber numberWithFloat:startPersentage]; pathAnimation.toValue = [NSNumber numberWithFloat:persentage]; pathAnimation.autoreverses = NO; pathAnimation.delegate = self; [self.maskLayer addAnimation:pathAnimation forKey:@"strokeEndAnimation"];}/** * 在修改百分比的時(shí)候,修改遮罩的大小 * * @param persentage 百分比 */- (void)setPersentage:(CGFloat)persentage { _persentage = persentage; self.maskLayer.strokeEnd = persentage;}

最終使用

- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typically from a nib. self.view.backgroundColor = [UIColor whiteColor]; self.loopProgressView.frame =CGRectMake(0, 100, self.view.frame.size.width, 150); [self.loopProgressView initLayers]; [self.view addSubview:self.loopProgressView]; dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{ [self.loopProgressView setAnimationPersentage:0.5]; }); self.slider.frame = CGRectMake(30, self.view.frame.size.height-60, self.view.frame.size.width-30*2, 20); [self.view addSubview:self.slider];}

以上就簡(jiǎn)單的實(shí)現(xiàn)了上述效果,有問(wèn)題歡迎指教。

Demo: https://github.com/SionChen/CYXAudioProgressView

總結(jié)

以上所述是小編給大家介紹的iOS實(shí)現(xiàn)音頻進(jìn)度條效果,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)VEVB武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到IOS開(kāi)發(fā)頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
国产www免费观看| 日本熟妇人妻xxxx| 丝袜美腿玉足3d专区一区| 日韩经典一区二区三区| 在线观看不卡视频| www.欧美黄色| 99热自拍偷拍| 欧美第一黄网免费网站| 亚洲美女av在线播放| 成人av手机在线观看| 久久在线播放| 成人深夜视频在线观看| 日本高清不卡一区二区三区视频| 国产丰满美女做爰| 九色porny丨首页入口在线| 国产三级aaa| 你懂的网站在线观看网址| 国产精品揄拍100视频| 动漫精品视频| 亚洲激情电影在线| 18国产精品| 综合国产第二页| 久久精品国产www456c0m| 色爱综合网站| 国产熟女一区二区| 91麻豆国产福利在线观看宅福利| 91视视频在线观看入口直接观看www| 最近2018年中文字幕在线| 三年中国中文在线观看免费播放| 丁香六月色婷婷| 一区二区三区四区欧美日韩| 天天综合网日韩| 欧美国产欧美亚洲国产日韩mv天天看完整| 久久久久久久久久久福利| 日韩激情一区| 免费全黄无遮挡裸体毛片| 中文字幕一区二| 狠狠躁天天躁日日躁欧美| 亚洲欧洲精品一区二区精品久久久| 国产精品无码2021在线观看| 亚洲欧美日韩中文在线制服| 免费在线观看一区二区三区| 波多野结衣午夜| 久久国产一区二区三区| 国产精品一区二区女厕厕| 五月综合激情日本mⅴ| 操她视频网站| 国产98在线|日韩| 久9re热视频这里只有精品| 精品人妻一区二区三区日产| 亚洲网友自拍偷拍| 96日本xxxxxⅹxxx17| 黄色网在线视频| 成人av在线一区二区三区| 欧美日韩国产免费一区二区三区| 亚洲高清免费观看| 欧美日韩另类丝袜其他| 国产欧美日本一区二区三区| 欧美xxxx性| 神马一区二区三区| 久久久久久网| 亚洲制服丝袜av| 韩国亚洲精品| 2023国产精品自拍| 日韩在线第二页| 丁香激情五月少妇| 久久成人久久鬼色| 国内精品久久久久影院薰衣草| 在线亚洲免费| 亚洲欧美激情插| 伊人久久大香线蕉av一区二区| 国产成人精品一区二区色戒| 最近更新的2019中文字幕| 国产在线精品一区二区三区》| 国产欧美在线| 亚洲免费不卡| 97在线视频免费看| 国产女同91疯狂高潮互磨| 性欧美在线视频| 国产无套内射又大又猛又粗又爽| 丰满岳乱妇国产精品一区| 久久国产精品99精品国产| 另类图片国产| 大陆极品少妇内射aaaaaa| 91玉足脚交白嫩脚丫在线播放| 熟女熟妇伦久久影院毛片一区二区| 午夜影院免费播放| 欧美黑人xxxxx| 在线观看国产福利| 成人免费毛片xxx| 精品人妻无码一区二区三区蜜桃一| 亚洲图片你懂的| 中出视频在线观看| 国产欧美日本| 欧美国产日韩一区二区| 青青草久久爱| 成人在色线视频在线观看免费大全| 午夜大片在线观看| 日产精品一区| 成年人精品视频| 98视频精品全部国产| 日av在线不卡| 国产精品视频中文字幕91| 久操国产精品| 国产精品久久久久久亚洲av| 色999韩欧美国产综合俺来也| 三级电影在线看| 欧美日韩第一区日日骚| av日韩国产| 日韩一区欧美一区| 男男一级淫片免费播放| 一本色道**综合亚洲精品蜜桃冫| 欧美一区三区三区高中清蜜桃| 日韩国产一区二| 不卡一区2区| 精品国产一区二区三区麻豆免费观看完整版| 天天操夜夜做| 国内成+人亚洲+欧美+综合在线| 亚洲成人高清在线| 资源视频在线播放免费| 熟女视频一区二区三区| 97精品国产97久久久久久免费| 又色又爽又高潮免费视频国产| 日韩欧美99| 国产日韩精品在线| 久久久久成人精品无码中文字幕| av在线不卡免费看| 亚洲精品一二三四| 国产鲁鲁视频在线观看免费| 女人扒开腿免费视频app| 国产精品网站在线观看| 大杳蕉精品视频在线观看| 日韩免费视频一区二区视频在线观看| 午夜精品免费看| 色综合久久综合中文综合网| 99在线精品视频免费观看软件| 欧美色图另类图片| 国产一区在线观看免费| www.com黄色片| av网站在线免费看推荐| 亚洲特色特黄| 在线视频一区二区免费| 国产精品三级av| 女同视频在线观看| 精品乱码一区二区三四区视频| 天天色综合久久| 丁香六月婷婷综合| 国产精品极品美女在线观看免费| 成人精品第一区二区三区| 自由色视频.| 美日韩在线观看| 久久久蜜臀国产一区二区| 天天好比中文综合网| 麻豆极品一区二区三区| 15—17女人毛片| 欧美大胆a人体大胆做受| 亚洲女人被黑人巨大进入al| 国产精品久久久久久久久久久久| 男女午夜激情视频| 韩国女主播一区二区| 成人网在线视频| 免费污网站在线观看| 999久久久久久久久6666| 在线免费看黄av| 亚洲综合色婷婷| 国产一级片视频| 日批在线观看视频| 91福利精品在线观看| 欧美男男gaytwinkfreevideos| 欧美情侣在线播放| 人妻91麻豆一区二区三区| 伊人免费在线观看| 国产日韩在线看| 新天堂中文资源官网在线观看| 91九色蝌蚪国产| 色婷婷综合中文久久一本| 亚洲v国产v欧美v久久久久久| 中文.日本.精品| 欧美精品一区二区久久婷婷| av影院午夜一区| 欧美老tube| 国产乱人伦精品一区二区| 性欧美xxxx大乳国产app| 欧美激情综合网| 狠狠躁夜夜躁人人爽超碰91| 国产一级一片免费播放放a| 嫩模私拍啪啪| 国产羞羞视频在线播放| 欧美成人精品网站| 日本深夜福利视频| 久热在线中文字幕色999舞| 自由色视频.| 91精品久久久久久蜜桃| 亚洲成在人线av| 影音先锋在线一区| 国产一区在线观看视频| 亚洲a成人v| 最新国产在线视频| 一区二区三区视频网| 国产一区二区在线观看视频| 99久免费精品视频在线观78| 成年网站在线播放| 欧美日韩在线第一页| 97超碰国产在线| 欧洲生活片亚洲生活在线观看| 亚洲一级片免费| 大美女一区二区三区| 国产精品一线二线三线| 欧美精品在欧美一区二区少妇| 亚洲免费人成在线视频观看| 青青视频在线免费观看| 欧美一区二区免费| 久久人人爽国产| 91精品欧美一区二区三区综合在| 色的视频在线观看免费播放| 正在播放一区二区三区| 久久久蜜桃精品| 视频在线观看你懂的| 97精品国产99久久久久久免费| 日本一区二区三区四区高清视频| 午夜激情小视频| 美国黄色片视频| 天天爽夜夜爽一区二区三区| 欧美日韩一区二区三区四区在线观看| 亚洲精品1区2区3区| 欧美大黑帍在线播放| 韩国成人在线视频| 免费毛片一区二区三区| 中文字幕+乱码+中文乱码91| 又骚又黄的视频| 午夜精品小视频| 中文字幕免费高清在线观看| 久久久久久久久久久影视| 免费视频一区二区三区在线观看| 欧美日韩视频在线第一区| 国产成人免费视频网站| 国产精品v欧美精品v日本精品动漫| 亚洲精品123区| 福利视频免费在线观看| www.4hu95.com四虎| 黄色软件在线| japonensisjava老师可播放| 老司机精品视频一区二区| 日本不卡123| 欧美黄色一级视频| 欧美精品久久久久久久多人混战| 欧美日韩一区高清| aⅴ在线免费观看| 五月婷婷六月丁香| 人妻换人妻a片爽麻豆| 超碰中文在线| 亚洲精品午夜国产va久久成人| 国产在线观看一区二区| 日本三级日本三级日本三级极| 中文字幕一区二区三| 欧美日韩一视频区二区| 石原莉奈一区二区三区在线观看| 欲色天天网综合久久| 国产成人久久精品麻豆二区| 亚洲爱爱视频| 橘梨纱av一区二区三区在线观看| jizzjizz中国精品麻豆| 亚洲男人天堂2023| 一本色道久久| 欧美成人国产精品一区二区| 日本女人性视频| 欧美日韩精品是欧美日韩精品| 亚洲一区日韩精品| 国产精品资源站| 日韩福利视频| 亚洲一区二区三区精品视频| 精品亚洲aⅴ在线观看| 国产精品九色蝌蚪自拍| 日韩高清av电影| 乳奴隷乳フ辱julia在线观看| 精品国产中文字幕| 欧美精品18videosex性欧美| 亚洲一区欧美二区| 91免费综合在线| 91精品国产66| 91丝袜高跟美女视频| 久久久久久久久久久免费| 69av视频在线播放| 91亚色免费| 91网免费观看| 中文不卡1区2区3区| 粉嫩av一区二区三区粉嫩| 韩国三级日本三级少妇99| 亚洲一二三区在线| 欧美日韩国产精选| 国产伦精品一区二区三区在线观看| 久久久水蜜桃av免费网站| 性生活免费在线观看| 日韩精品中文字幕在线不卡尤物| 欧美色图亚洲图片| 在线视频一二三区| 国内精品久久久久久影视8| av无码av天天av天天爽| 国产三级三级在线观看| av无码精品一区二区三区宅噜噜| 性中国古装videossex| 久久久久久尹人网香蕉| 影音先锋中文资源站| 欧美亚洲视频一区二区| 国产精品嫩模av在线| 亚洲日本中文| 精品无码一区二区三区的天堂| 麻豆精品不卡国产免费看| 欧美日韩亚洲国产精品| 黄色小视频在线观看| 国产真实乱偷精品视频免| 国产成人h网站| aa免费在线观看| av片在线观看免费| julia一区二区中文久久94| 国产精品9999久久久久仙踪林| 午夜精品久久17c| 国产一区二区三区日韩| 岛国视频午夜一区免费在线观看| 51调教丨国产调教视频| 国产精品第一国产精品| 欧美在线视频在线播放完整版免费观看| 欧美视频亚洲色图| 91露出在线| 香蕉乱码成人久久天堂爱免费| 乱人伦中文字幕在线zone| 久久人人爽av| 精品人妻一区二区色欲产成人|