iOS view圓角化的四種方法
最近在進行專案效能的優化,遇到view圓角優化的問題,有一些粗略的看法,現總結一下。
設定圓角目前知道的有四種方法:
- 1、通過shapeLayer設定
- 2、通過view的layer設定
- 3、通過BezierPath設定
- 4、通過貼圖的方式設定
shapeLayer的�實現
通過bezizerpath設定一個路徑,加到目標檢視的layer上。程式碼如下:
// 建立一個view
UIView *showView = [[UIView alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];
[self.view addSubview:showView];
showView.backgroundColor = [UIColor whiteColor];
showView.alpha = 0.5;
// 貝塞爾曲線(建立一個圓)
UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:CGPointMake(100 / 2.f, 100 / 2.f)
radius:100 / 2.f
startAngle:0
endAngle:M_PI * 2
clockwise:YES];
CAShapeLayer *layer = [CAShapeLayer layer];
layer.frame = showView.bounds;
layer.path = path.CGPath;
[showView.layer addSublayer:layer];
view的layer的�實現
通過view的layer直接設定的方式,是所有的方法中最簡單的,程式碼如下:
- (UIImageView *)avatarImage {
if (!_avatarImage) {
_avatarImage = [[UIImageView alloc] initWithFrame:CGRectMake(20,10, avatarDiameter, avatarDiameter)];
_avatarImage.backgroundColor = [UIColor grayColor];
_avatarImage.contentMode = UIViewContentModeScaleAspectFit;
_avatarImage.layer.cornerRadius = avatarDiameter/2.0;
_avatarImage.layer.masksToBounds = YES;
[_avatarImage setImage:[UIImage imageNamed:@"test.jpg"]];
}
return _avatarImage;
}
BezierPath的�實現
BezierPath的實現方式繼承UIView,自己實現一個customview,程式碼如下。
- (instancetype)initWithFrame:(CGRect)frame {
if (self = [super initWithFrame:frame]) {
}
return self;
}
- (void)drawRect:(CGRect)rect {
// Drawing code
CGRect bounds = self.bounds;
[[UIColor whiteColor] set];
UIRectFill(bounds);
[[UIBezierPath bezierPathWithRoundedRect:rect cornerRadius:CGRectGetWidth(bounds)/2.0] addClip];
[self.image drawInRect:bounds];
}
貼圖的�實現
貼圖的方式是使用一箇中間是圓形鏤空的圖覆蓋在需要圓角化的圖片的上方。程式碼如下:
- (instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier {
if (self = [super initWithStyle:style reuseIdentifier:reuseIdentifier]) {
[self.contentView addSubview:self.avatarImage];
[self.contentView addSubview:self.maskImage];
}
return self;
}
- (UIImageView *)avatarImage {
if (!_avatarImage) {
_avatarImage = [[UIImageView alloc] initWithFrame:CGRectMake(20,10, avatarDiameter, avatarDiameter)];
_avatarImage.backgroundColor = [UIColor grayColor];
_avatarImage.contentMode = UIViewContentModeScaleAspectFit;
[_avatarImage setImage:[UIImage imageNamed:@"test.jpg"]];
}
return _avatarImage;
}
//中心鏤空的圖
- (UIImageView *)maskImage {
if (!_maskImage) {
_maskImage = [[UIImageView alloc] initWithFrame:CGRectMake(20,10, avatarDiameter, avatarDiameter)];
_maskImage.contentMode = UIViewContentModeScaleAspectFit;
[_maskImage setImage:[UIImage imageNamed:@"corner_circle.png"]];
}
return _maskImage;
}
如果大家有什麼新的方法,希望推薦給我。
相關文章
- word中間的圓點符號怎麼打 word打出圓點的四種方法符號
- 筆記-圓角四種方法的對比以及效能檢測筆記
- 程式碼共享的四種方法
- iOS常見的幾種加密方法iOS加密
- 筆記-iOS設定圓角方法以及指定位置設圓角筆記iOS
- Android 自定義 View:包含多種狀態的下載用圓形進度條AndroidView
- Javascript獲取原型的四種方法JavaScript原型
- 進入docker容器的四種方法Docker
- CSS清除浮動的四種方法CSS
- 修改MySQL密碼的四種方法MySql密碼
- iOS 多執行緒的四種技術方案iOS執行緒
- 四種OS下安裝Docker的方法Docker
- 按照名字殺死程式的四種方法
- 監聽檔案修改的四種方法
- 四種在Javascript比較物件的方法JavaScript物件
- iOS使用頻率最高的四種記憶體管理iOS記憶體
- 視訊直播app原始碼,對首頁樣式的整體調整,調整成圓角化APP原始碼
- iOS 開發中 runtime 常用的幾種方法iOS
- 直播平臺原始碼,自定義設定 View 四個角的圓角 以及邊框的設定原始碼View
- 【LeetCode】求眾數(四種方法)LeetCode
- Apache Camel日誌四種方法Apache
- 推薦一種簡單的在Flutter中分離View與Model的方法FlutterView
- Flutter混合開發——一種另類卻高效的的原生View嵌入方法FlutterView
- PyCharm中批次註釋常用的四種方法!PyCharm
- 【java】int轉換成String的四種方法Java
- linux下檢視mysql版本的四種方法LinuxMySql
- javascript實現tab切換的四種方法JavaScript
- 請使用css畫一個圓,方法可以多種CSS
- 【朝花夕拾】Android自定義View篇之(四)自定義View的三種實現方式及自定義屬性詳解AndroidView
- iOS 繪製圓角iOS
- 『自定義View實戰』—— 仿ios圖示下載viewViewiOS
- 樹莓派四種登陸方法樹莓派
- java語言複製陣列的四種方法Java陣列
- Java中轉義HTML符號的四種方法JavaHTML符號
- JavaScript判斷變數型別的四種方法JavaScript變數型別
- 使用CRM系統資料分析的四種方法
- 保障爬蟲穩定執行的四種方法爬蟲
- STM32延時函式的四種方法函式
- JavaScript資料型別判斷的四種方法JavaScript資料型別