ios view 切上部分圆角_教你把UIView切成任意形状

http://www.dreamingwish.com/dream-2012/%E6%95%99%E4%BD%A0%E6%8A%8Auiview%E5%88%87%E6%88%90%E4%BB%BB%E6%84%8F%E5%BD%A2%E7%8A%B6.html

有时候layer.cornerRadius并不能满足需求,自己实现drawRect又太麻烦,怎么办?

多的不说,直接上代码:

- (void)dwMakeBottomRoundCornerWithRadius:(CGFloat)radius

{

CGSize size = self.frame.size;

CAShapeLayer *shapeLayer = [CAShapeLayer layer];

[shapeLayer setFillColor:[[UIColor whiteColor] CGColor]];

CGMutablePathRef path = CGPathCreateMutable();

CGPathMoveToPoint(path, NULL, size.width - radius, size.height);

CGPathAddArc(path, NULL, size.width-radius, size.height-radius, radius, M_PI/2, 0.0, YES);

CGPathAddLineToPoint(path, NULL, size.width, 0.0);

CGPathAddLineToPoint(path, NULL, 0.0, 0.0);

CGPathAddLineToPoint(path, NULL, 0.0, size.height - radius);

CGPathAddArc(path, NULL, radius, size.height - radius, radius, M_PI, M_PI/2, YES);

CGPathCloseSubpath(path);

[shapeLayer setPath:path];

CFRelease(path);

self.layer.mask = shapeLayer;//layer的mask,顾名思义,是种位掩蔽,在shapeLayer的填充区域中,alpha值不为零的部分,self会被绘制;alpha值为零的部分,self不会被绘制,甚至不会响应touch

}

- (id)initWithFrame:(CGRect)frame

{

if (self = [super initWithFrame:frame]) {

[self dwMakeBottomRoundCornerWithRadius:3.0];

}

}

这样就能切出一个只有下半部圆角的View,更厉害的是,切去的部分不响应用户点击!

这种方法,只要稍作修改就能实现很多效果,比如一个多边形的按钮,把一张图片切成邮票。

UIView:

layer.mask:

最终绘制:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值