久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

iOS UIBezierPath實現餅狀圖

瀏覽:5日期:2022-09-16 18:17:37

本文實例為大家分享了iOS UIBezierPath實現餅狀圖的具體代碼,供大家參考,具體內容如下

首先看效果圖:

iOS UIBezierPath實現餅狀圖

代碼:

#import <UIKit/UIKit.h> NS_ASSUME_NONNULL_BEGIN @interface CircleView : UIView @property (nonatomic, copy) NSArray<NSNumber *> *valueArray; @end NS_ASSUME_NONNULL_END // #define S_W self.frame.size.width #import 'CircleView.h' @interface CircleView () @property (nonatomic, copy) NSArray<NSNumber *> *dataArray;@property (nonatomic, assign) CGFloat endAngleFloat; // 每個扇形起點角度 @end @implementation CircleView - (void)setValueArray:(NSArray<NSNumber *> *)valueArray { self.dataArray = valueArray; self.endAngleFloat = 0; [self creatUI];} - (void)creatUI { for (NSInteger i = 0; i<_dataArray.count; i++) { CAShapeLayer *shapeLayer = [CAShapeLayer layer]; shapeLayer.lineWidth = 1; shapeLayer.fillColor = [UIColor colorWithRed:arc4random()%256/255.0f green:arc4random()%256/255.0f blue:arc4random()%256/255.0f alpha:1].CGColor; shapeLayer.strokeColor = shapeLayer.fillColor; CGFloat valueFloat = [_dataArray[i] floatValue]; CGFloat angleFloat = valueFloat*2*M_PI/100; UIBezierPath *bezierPath = [UIBezierPath bezierPath]; [bezierPath moveToPoint:CGPointMake(S_W/2, S_W/2)]; [bezierPath addLineToPoint:CGPointMake(S_W*(1+cos(_endAngleFloat))/2, S_W*(1+sin(_endAngleFloat))/2)]; [bezierPath addArcWithCenter:CGPointMake(S_W/2, S_W/2) radius:S_W/2 startAngle:_endAngleFloat endAngle:angleFloat+_endAngleFloat clockwise:YES]; [bezierPath closePath]; shapeLayer.path = bezierPath.CGPath; [self.layer addSublayer:shapeLayer]; [self addLabelWithFloat:valueFloat angleFloat:angleFloat]; _endAngleFloat += angleFloat; }} - (void)addLabelWithFloat:(CGFloat)valueFloat angleFloat:(CGFloat)angleFloat { UILabel *label = [[UILabel alloc] init]; label.center = CGPointMake(S_W*(2+cos(angleFloat/2 + _endAngleFloat))/4, S_W*(2+sin(angleFloat/2 + _endAngleFloat))/4); label.bounds = CGRectMake(0, 0, 50, 50); label.text = [NSString stringWithFormat:@'%.f%%',valueFloat]; label.textColor = UIColor.whiteColor; label.textAlignment = NSTextAlignmentCenter; label.font = [UIFont systemFontOfSize:14]; [self addSubview:label];}

外部調用:

CircleView *view = [[CircleView alloc] initWithFrame:CGRectMake(20, 100, self.view.frame.size.width-40, self.view.frame.size.width-40)]; view.valueArray = @[@(10),@(20),@(30),@(40)]; [self.view addSubview:view];

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: IOS
相關文章:
主站蜘蛛池模板: 亚洲精品一区二区网址 | 在线高清av | 激情综合在线 | 亚洲无吗电影 | 免费看的黄色 | 婷婷av在线| 国产精品69毛片高清亚洲 | 精品无人乱码一区二区三区 | 国产成人精品一区二区三区网站观看 | 久久一区| 中文字幕在线免费看 | 国产精品久久久久久久久久久小说 | 国产成人免费视频网站视频社区 | 亚洲成人免费在线 | 色视频网站在线观看一=区 日韩一二三区 | 天天看天天爽 | 午夜欧美 | 激情欧美日韩一区二区 | 国产免费看 | 国产亚洲精品一区二区 | 日日做夜夜爽毛片麻豆 | 91在线观看视频 | 国内精品视频在线观看 | 日韩免费视频 | 午夜午夜精品一区二区三区文 | 国产成人在线看 | 在线中文一区 | 精品久久久久久久久久久久久久久久久久久 | 天堂在线中文字幕 | 成人精品二区 | 一区二区三区四区在线播放 | 成人一区视频 | 97色综合 | 日韩免费视频 | 久一久久 | 国产一区二区三区色淫影院 | 亚洲精品9999| 午夜影院| 欧美日韩亚洲一区 | 久久久久久精 | 中文成人在线 |