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;
}
如果大家有什麼新的方法,希望推薦給我。
相關文章
- iOS給UIImageView新增圓角的三種方法iOSUIView
- word中間的圓點符號怎麼打 word打出圓點的四種方法符號
- 筆記-圓角四種方法的對比以及效能檢測筆記
- ios Image裁剪成圓形的方法iOS
- iOS UIView設定少於四個的圓角iOSUIView
- Nhibernate 對view 查詢的幾種方法View
- JAVA解析XML的四種方法JavaXML
- 程式碼共享的四種方法
- 視訊直播app原始碼,對首頁樣式的整體調整,調整成圓角化APP原始碼
- iOS 幾種加密方法iOS加密
- Javascript獲取原型的四種方法JavaScript原型
- CSS清除浮動的四種方法CSS
- 修改MySQL密碼的四種方法MySql密碼
- oracle新增主鍵的四種方法:Oracle
- 進入docker容器的四種方法Docker
- 自學Linux命令的四種方法Linux
- 筆記-iOS設定圓角方法以及指定位置設圓角筆記iOS
- iOS 常用元件 高效切圓角方法總結iOS元件
- 安卓雜記(二)利用FrameLayout疊加多種view的方法安卓View
- 四種IT治理方法(轉載)
- iOS常見的幾種加密方法iOS加密
- ios view touchiOSView
- Android 自定義 View:包含多種狀態的下載用圓形進度條AndroidView
- 監聽檔案修改的四種方法
- 四種在Javascript比較物件的方法JavaScript物件
- 四種OS下安裝Docker的方法Docker
- 按照名字殺死程式的四種方法
- CSS三欄佈局的四種方法CSS
- 常用的四種大資料分析方法大資料
- 詳解Java解析XML的四種方法JavaXML
- iOS 多執行緒的四種技術方案iOS執行緒
- Apache Camel日誌四種方法Apache
- 直播平臺原始碼,自定義設定 View 四個角的圓角 以及邊框的設定原始碼View
- ios 遍歷陣列的八種方法iOS陣列
- iOS 資料持久化的幾種方法iOS持久化
- iOS: 讓鍵盤消失的的4種方法iOS
- javascript實現tab切換的四種方法JavaScript
- PyCharm中批次註釋常用的四種方法!PyCharm