CAShapeLayer
CAShapeLayer 是CALayer 的子类。
- DrawRect:DrawRect属于CoreGraphic框架,占用CPU,消耗性能大
- CAShapeLayer:CAShapeLayer属于CoreAnimation框架,通过GPU来渲染图形,节省性能。动画渲染直接提交给手机GPU,不消耗内存
data:image/s3,"s3://crabby-images/c438a/c438a90d7129b4521d1a5d4c0ac61922f98b9265" alt=""
UIBezierPath
UIBezierPath 专门是用来绘制路径的,常和CAShapeLayer一起配合使用。
1.画曲线
data:image/s3,"s3://crabby-images/f546f/f546fbc72e8878d3a261debf3db4deda594c2524" alt=""
2.画椭圆或圆
data:image/s3,"s3://crabby-images/3e96c/3e96c0b11b3f225ff0875db29d875a406c7b1639" alt=""
3.画圆角矩形
data:image/s3,"s3://crabby-images/2a8b4/2a8b477cd451294da158e6dcce9beab8b4dadb20" alt=""
4.二次贝塞尔曲线
data:image/s3,"s3://crabby-images/c3323/c3323f79ad624a79a1e0cbaa0ccf16cd7e002039" alt=""
5.三次贝塞尔曲线
data:image/s3,"s3://crabby-images/df96d/df96d5e3656139076c6000e9c85b7a6f1dd26401" alt=""
画圆弧
data:image/s3,"s3://crabby-images/e722f/e722fcc76aff2a2a15d56f4b7ed65bb3eb56dbe8" alt=""
类似qq聊天的气泡
eg:
- (void)createMaskLayer:(UIView *)view {
CGFloat viewWidth = CGRectGetWidth(view.frame);
CGFloat viewHeight = CGRectGetHeight(view.frame);
CGFloat rightSpace = 10.0f; //point3距X轴imageView右侧距离
CGFloat topSpace = 15.0f; //point3距Y轴imageView顶部距离
CGFloat radiusSpace = 5.0f; //圆半径
//path点
CGPoint point1 = CGPointMake(radiusSpace, 0);
CGPoint point2 = CGPointMake(viewWidth - rightSpace - radiusSpace, 0);
//顺时针1/4圆弧
CGPoint radiusCenter1 = CGPointMake(point2.x, point2.y + radiusSpace);
// point3 4 5为箭头的位置 4为顶尖
CGPoint point3 = CGPointMake(viewWidth - rightSpace, topSpace);
CGPoint point4 = CGPointMake(viewWidth, topSpace + 5.0f);
CGPoint point5 = CGPointMake(viewWidth - rightSpace, topSpace + 10.f);
CGPoint point6 = CGPointMake(viewWidth - rightSpace, viewHeight - radiusSpace);
//顺时针1/4圆弧
CGPoint radiusCenter2 = CGPointMake(point6.x - radiusSpace, point6.y);
CGPoint point7 = CGPointMake(radiusSpace, viewHeight);
//顺时针1/4圆弧
CGPoint radiusCenter3 = CGPointMake(point7.x, point7.y - radiusSpace);
CGPoint point8 = CGPointMake(0, radiusSpace);
//顺时针1/4圆弧
CGPoint radiusCenter4 = CGPointMake(point8.x + radiusSpace, point8.y);
UIBezierPath *path = [UIBezierPath bezierPath];
[path moveToPoint:point1];
[path addLineToPoint:point2];
[path addArcWithCenter:radiusCenter1 radius:radiusSpace startAngle:(270/180.0f)*M_PI endAngle:0 clockwise:YES];
[path addLineToPoint:point3];
[path addLineToPoint:point4];
[path addLineToPoint:point5];
[path addLineToPoint:point6];
[path addArcWithCenter:radiusCenter2 radius:radiusSpace startAngle:0 endAngle:(90/180.0f)*M_PI clockwise:YES];
[path addLineToPoint:point7];
[path addArcWithCenter:radiusCenter3 radius:radiusSpace startAngle:(90/180.0f)*M_PI endAngle:M_PI clockwise:YES];
[path addLineToPoint:point8];
[path addArcWithCenter:radiusCenter4 radius:radiusSpace startAngle:M_PI endAngle:(270/180.0f)*M_PI clockwise:YES];
[path closePath];
CAShapeLayer *maskLayer = [CAShapeLayer layer];
maskLayer.path = path.CGPath;
view.layer.mask = maskLayer;
}
网友评论