自定义设置 View 四个角的圆角 以及边框的设置

使用贝塞尔曲线

typedef NS_OPTIONS(NSUInteger, UIRectCorner) {

    UIRectCornerTopLeft     = 1 << 0,

    UIRectCornerTopRight    = 1 << 1,

    UIRectCornerBottomLeft  = 1 << 2,

    UIRectCornerBottomRight = 1 << 3,

    UIRectCornerAllCorners  = ~0UL

};

//16进制颜色

#define RGB16Color(rgbValue) [UIColor colorWithRed:((float)((rgbValue & 0xFF0000) >> 16))/255.0 green:((float)((rgbValue & 0xFF00) >> 8))/255.0 blue:((float)(rgbValue & 0xFF))/255.0 alpha:1.0]

 

UIButton * chooseButton = [UIButton buttonWithType:UIButtonTypeCustom];

chooseButton.frame = CGRectMake(10, 15, 86, 24);

[self.view addSubview:chooseButton];

UIBezierPath *maskPath_two = [UIBezierPath bezierPathWithRoundedRect: chooseButton.bounds byRoundingCorners:UIRectCornerTopRight | UIRectCornerBottomRight cornerRadii:CGSizeMake(5,5)];

    //创建 layer

    CAShapeLayer *maskLayer_two = [[CAShapeLayer alloc] init];

    maskLayer_two.frame = chooseButton.bounds;

    //赋值

    maskLayer_two.path = maskPath_two.CGPath;

    chooseButton.layer.mask = maskLayer_two;

在以上的基础上 设置边框

//设置边框

    CAShapeLayer *borderLayer = [CAShapeLayer layer];

    borderLayer.frame = chooseButton.bounds;

    borderLayer.path = maskPath_two.CGPath;

    borderLayer.lineWidth = 1;

    borderLayer.fillColor = [UIColor clearColor].CGColor;

    borderLayer.strokeColor = RGB16Color(0x30C26D).CGColor;

    [chooseButton.layer addSublayer:borderLayer];

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值