欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS中設置view圓角化的四種方法示例

 更新時間:2017年09月12日 11:40:14   作者:藍光95  
最近因為工作的原因,遇到view圓角優(yōu)化的問題,所以將實現(xiàn)的幾種方法總結分享出來,下面這篇文章主要給大家介紹了關于iOS中設置view圓角化的四種方法,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧。

前言

在最近進行項目性能優(yōu)化的過程中,遇到view圓角優(yōu)化的問題,有一些粗略的看法,現(xiàn)總結一下。分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。

設置圓角目前知道的有四種方法:

     1、通過shapeLayer設置

     2、通過view的layer設置

     3、通過BezierPath設置

     4、通過貼圖的方式設置

1、shapeLayer的實現(xiàn)

通過bezizerpath設置一個路徑,加到目標視圖的layer上。代碼如下:

// 創(chuàng)建一個view
 UIView *showView = [[UIView alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];
 [self.view addSubview:showView];
 showView.backgroundColor = [UIColor whiteColor];
 showView.alpha = 0.5;
 
 // 貝塞爾曲線(創(chuàng)建一個圓)
 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];

2、view的layer的實現(xiàn)

通過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;
}

3、BezierPath的實現(xiàn)

BezierPath的實現(xiàn)方式繼承UIView,自己實現(xiàn)一個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];
} 

4、貼圖的實現(xiàn)

貼圖的方式是使用一個中間是圓形鏤空的圖覆蓋在需要圓角化的圖片的上方。代碼如下:

- (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?Swift?Lazy?var?View失效問題解決

    iOS?Swift?Lazy?var?View失效問題解決

    這篇文章主要為大家介紹了iOS?Swift?Lazy?var?View失效問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • iOS開發(fā)中使用文字圖標iconfont的應用示例

    iOS開發(fā)中使用文字圖標iconfont的應用示例

    這篇文章主要介紹了iOS開發(fā)中使用文字圖標iconfont的應用示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • IOS安裝包比Android容量大的原因

    IOS安裝包比Android容量大的原因

    這篇文章主要介紹了為什么IOS安裝包比Android容量大的原因,如果你是一個IOS或者安卓開發(fā)者,學習下相關知識吧。
    2018-02-02
  • iOS-Mac配置Tomcat教程 Mac環(huán)境配置Tomcat教程

    iOS-Mac配置Tomcat教程 Mac環(huán)境配置Tomcat教程

    這篇文章主要介紹了iOS-Mac配置Tomcat教程,Mac環(huán)境配置Tomcat,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • iOS App開發(fā)中使cell高度自適應的黑魔法詳解

    iOS App開發(fā)中使cell高度自適應的黑魔法詳解

    這篇文章主要介紹了iOS App開發(fā)中使cell高度自適應的黑魔法詳解,作者利用iOS8以后的新特性講解了TableView、CollectionView中的cell高度自適應以及UITextView輸入內容實時更新cell高度的方法,需要的朋友可以參考下
    2016-03-03
  • iOS開發(fā)實現(xiàn)抽屜效果

    iOS開發(fā)實現(xiàn)抽屜效果

    這篇文章主要為大家詳細介紹了iOS開發(fā)實現(xiàn)抽屜效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • iOS自定義時間滾動選擇控件

    iOS自定義時間滾動選擇控件

    這篇文章主要為大家詳細介紹了iOS自定義時間滾動選擇控件,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • IOS URL中文亂碼問題解決方案

    IOS URL中文亂碼問題解決方案

    這篇文章主要介紹了IOS 解決URL中文亂碼問題解決方案的相關資料,需要的朋友可以參考下
    2016-10-10
  • IOS UIWebView獲取404、504等錯誤問題解決方案

    IOS UIWebView獲取404、504等錯誤問題解決方案

    這篇文章主要介紹了IOS UIWebView獲取404、504等錯誤問題的相關資料,并對相應的錯誤問題提出相應的解決方案,需要的朋友可以參考下
    2016-11-11
  • iOS開發(fā)之路--微博“更多”頁面

    iOS開發(fā)之路--微博“更多”頁面

    本文是IOS開發(fā)之路系列文章第五篇,主要講訴了,如何制作微博的更多頁面,并附上效果圖及源碼,需要的朋友可以參考下,希望能有所幫助
    2014-08-08

最新評論