CALayer的基本介绍和生成圆角图片的分类


通过CALayer给view设置边框,边框是往view内部填充。view系统自带的layer,称为根层
UIImageView显示的图片是放在UIImageView根层layer的contents里面的
//设置边框
    self.imageView.layer.borderColor = [UIColor blueColor].CGColor;
    self.imageView.layer.borderWidth = 3;
    
    //设置阴影
    //阴影的不透明度0-1,1是不透明,0是透明
    self.imageView.layer.shadowOpacity = 1;
   //(阴影的偏移量)x为正,阴影在右边,为负,阴影在左边。y为正,阴影在下边,为负,阴影在上面
    self.imageView.layer.shadowOffset = CGSizeMake(-10, 10);
   // 阴影的颜色
    self.imageView.layer.shadowColor = [UIColor greenColor].CGColor;
    
    //设置圆角
    self.imageView.layer.cornerRadius = 50;
    //超过根层以外的内容给裁剪掉,包括阴影也会被裁解掉
   clipsToBounds操作的其实还是layer.masksToBounds
    //self.imageView.clipsToBounds = YES;

  //离屏渲染是masksToBounds造成的,不是cornerRadius造成的
    self.imageView.layer.masksToBounds = YES;

    // UIImageView显示的图片就放在layer的这个属性中
    NSLog(@"%@",self.imageView.layer.contents);
一般在tableView列表中,图片有圆角的话,是不用clipsToBounds和masksToBounds来设置图片圆角的,
因为会触发离屏渲染,这是消耗性能的。而直接用Quartz2D来裁剪,因为这样是不消耗性能的
裁剪图片开启的位图上下文的大小,要跟图片本身的大小保持一致,防止图片被压缩放大。要先设置裁剪区域,
在画图像。一定要先生成图片,在关闭位图上下文,先关闭位图上下文,是拿不到图片的
生成一张圆形的image图片

生成带边框图片的逻辑,淡红圆是边框需要的,蓝色的圆是裁剪用的。裁剪用的圆不需要画上去

生成带边框的图片
生成一张带有边框的圆角图片分类
#import <UIKit/UIKit.h>

@interface UIImage (image)

/**
 *  返回一张带有边框的图片
 *
 *  @param borderW 边框的宽度
 *  @param color   边框的颜色
 *  @param image   要裁剪的图片
 *
 *  @return 裁剪好带有边框的图片
 */
+ (UIImage *)imageWithBorderW:(CGFloat)borderW color:(UIColor *)color image:(UIImage *)image;

@end
#import "UIImage+image.h"

@implementation UIImage (image)

+ (UIImage *)imageWithBorderW:(CGFloat)borderW color:(UIColor *)color image:(UIImage *)image {
    //1.先开启一个图片上下文 ,尺寸大小在原始图片基础上宽高都加上两倍边框宽度.
    CGSize size = CGSizeMake(image.size.width + 2 * borderW, image.size.height + 2 * borderW);
    UIGraphicsBeginImageContext(size);
    //2.填充一个圆形路径.这个圆形路径大小,和上下文尺寸大小一样.
    //把大圆画到上下文当中.
    UIBezierPath *path = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(0, 0, size.width, size.height)];
    [color set];
    [path fill];
    
    //3.添加一个小圆,小圆,x,y从边框宽度位置开始添加,宽高和原始图片一样大小.把小圆设为裁剪区域.
    UIBezierPath *clipPath = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(borderW, borderW, image.size.width, image.size.height)];
    //把小圆设为裁剪区域.
    [clipPath addClip];
    
    //4.把图片给绘制上去.
    [image drawAtPoint:CGPointMake(borderW, borderW)];
    
    //5.从上下文当中生成一张图片
    UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();
    
    //6.关闭上下文
    UIGraphicsEndImageContext();
    
    return newImage;
}

@end
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容