麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

OC-9.使用Quartz2D繪制下載進度條

2019-11-14 18:02:07
字體:
來源:轉載
供稿:網友

 

效果圖


實現思路


  • 要實現繪圖,通常需要自定義一個UIView的子類,重寫父類的- (void)drawRect:(CGRect)rect方法,在該方法中實現繪圖操作
  • 若想顯示下載進度,只需要實例化自定義子類的對象(若是storyboard中控件,只需修改控件的class屬性為自定義子類的類名即可)

  • 效果圖所示的效果其實是繪制一個圓弧,動態的改變終點的位置,最終達到一個封閉的圓
  • 中間的文字是一個UILabel控件,根據進度動態改變文字的現實

實現步驟


  • 自定義一個UIView的子類

    //提供一個成員屬性,接收下載進度值@PRoperty (nonatomic, assign) CGFloat progress;
  • 重寫成員屬性progress的setter

    //每次改變成員屬性progress的值,就會調用它的setter- (void)setProgress:(CGFloat)progress{	_progress = progress;	//當下載進度改變時,手動調用重繪方法	[self setNeedsDisplay];}
  • 重寫- (void)drawRect:(CGRect)rect(核心

    - (void)drawRect:(CGRect)rect{	//設置圓弧的半徑	CGFloat radius = rect.size.width * 0.5;	//設置圓弧的圓心	CGPoint center = CGPointMake(radius, radius);	//設置圓弧的開始的角度(弧度制)	CGFloat startAngle = - M_PI_2;	//設置圓弧的終止角度	CGFloat endAngle = - M_PI_2 + 2 * M_PI * self.progress;	//使用UIBezierPath類繪制圓弧	UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:center radius:radius - 5 startAngle:startAngle endAngle:endAngle clockwise:YES];	//將繪制的圓弧渲染到圖層上(即顯示出來)	[path stroke];}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 免费观看一级黄色片 | 免费网站看v片在线a | 欧美国产一区二区三区 | 中文字幕免费在线看 | 国产精品久久久久久久久久iiiii | 一级电影在线免费观看 | 久久精品视频日本 | 毛片大全免费 | 在线免费观看毛片 | 国产精品剧情一区二区三区 | freexxx69性欧美hd | 国产资源视频在线观看 | 国产性tv国产精品 | 成人不卡一区二区 | 毛片免费看电影 | 羞羞色在线观看 | 九九热九九爱 | 久久精品亚洲国产奇米99 | 中文字幕网址 | 少妇一级淫片免费放正片 | 久久精品视频一区二区 | 亚洲码无人客一区二区三区 | 成人短视频在线播放 | 国产羞羞视频免费在线观看 | 成年免费大片黄在线观看岛国 | 亚洲综合视频网站 | 亚洲午夜电影 | 91小视频在线观看免费版高清 | 一区二区三区欧美在线 | xnxx 日本19| 人禽l交免费视频观看 视频 | 日韩在线播放中文字幕 | 国产黄色一区二区 | 国产中出视频 | 看毛片电影| 欧美亚洲黄色 | 成人网在线观看 | 黄色特级毛片 | 免费一区二区三区 | 成人在线免费视频观看 | 一本色道精品久久一区二区三区 |