通过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来裁剪,因为这样是不消耗性能的
裁剪图片开启的位图上下文的大小,要跟图片本身的大小保持一致,防止图片被压缩放大。要先设置裁剪区域,
在画图像。一定要先生成图片,在关闭位图上下文,先关闭位图上下文,是拿不到图片的
生成带边框图片的逻辑,淡红圆是边框需要的,蓝色的圆是裁剪用的。裁剪用的圆不需要画上去
生成一张带有边框的圆角图片分类
#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