[code]关于圆角图片问题

CPU、GPU在渲染图片时是如何工作的?

计算机系统中CPU、GPU协同工作,CPU计算好显示的内容给GPU,GPU渲染完>成后将渲染结果提交到真缓冲区,所以两者之间相互协作。如果CPU替GPU干了>活,就会拖慢了UI层的FBS,这就是所谓的离屏渲染。

离屏渲染

CPU干了不擅长的GPU的活,导致拖慢了UI层面的FBS,而且离屏需要创建新的缓冲区和上下文的切换,因此消耗大量的性能。

生成圆角图片的常用方式

  • 方法1:
imgView.layer.cornerRadius = 10;
imgView.clipsToBounds = YES;//消耗性能
缺点:离屏渲染。
  • 方法2:正解
-(UIImage *)hyb_imageWithCornerRadius:(CGFloat)radius { 
CGRect rect = (CGRect){0.f, 0.f, self.size}; 
UIGraphicsBeginImageContextWithOptions(self.size, NO, UIScreen.mainScreen.scale); 
CGContextAddPath(UIGraphicsGetCurrentContext(), [UIBezierPath bezierPathWithRoundedRect:rect cornerRadius:radius].CGPath);
CGContextClip(UIGraphicsGetCurrentContext()); 
[self drawInRect:rect];
UIImage *image = UIGraphicsGetImageFromCurrentImageContext(); 
UIGraphicsEndImageContext();
 return image;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 本文是基于UIKit性能调优实战讲解 - 简书这篇文章的总结详细请看原文 实例讲解可以参考:小心别让圆角成了你列表...
    Www刘阅读 4,707评论 1 8
  • 1、设置UILabel行间距 NSMutableAttributedString* attrString = [[...
    FF_911阅读 5,282评论 0 3
  • Quartz2D以及drawRect的重绘机制字数1487 阅读21 评论1 喜欢1一、什么是Quartz2D Q...
    PurpleWind阅读 4,304评论 0 3
  • //设置尺寸为屏幕尺寸的时候self.window = [[UIWindow alloc] initWithFra...
    LuckTime阅读 4,392评论 0 0
  • 1.//获取字符串(或汉字)首字母+ (NSString *)firstCharacterWithString:(...
    艾希_可可阅读 3,567评论 0 0

友情链接更多精彩内容