Round top corners of a UIView and add border

前端 未结 4 506
自闭症患者
自闭症患者 2020-12-03 01:55

I have the following code in a category that does rounding of corners. I would also like to draw a border. But the border is not shown on the rounded part of the corner.

4条回答
  •  夕颜
    夕颜 (楼主)
    2020-12-03 02:20

    The mask layer doesn't get drawn, just used to compute the mask. Try:

    -(void)roundCorners:(UIRectCorner)corners radius:(CGFloat)radius
    {
        CGRect bounds = self.bounds;
        UIBezierPath *maskPath = [UIBezierPath bezierPathWithRoundedRect:bounds
                                                       byRoundingCorners:corners
                                                             cornerRadii:CGSizeMake(radius, radius)];
    
        CAShapeLayer *maskLayer = [CAShapeLayer layer];
        maskLayer.frame = bounds;
        maskLayer.path = maskPath.CGPath;
    
        self.layer.mask = maskLayer;
    
        CAShapeLayer*   frameLayer = [CAShapeLayer layer];
        frameLayer.frame = bounds;
        frameLayer.path = maskPath.CGPath;
        frameLayer.strokeColor = [UIColor redColor].CGColor;
        frameLayer.fillColor = nil;
    
        [self.layer addSublayer:frameLayer];
    }
    
    -(void)roundTopCornersRadius:(CGFloat)radius
    {
        [self roundCorners:(UIRectCornerTopLeft|UIRectCornerTopRight) radius:radius];
    }
    
    -(void)roundBottomCornersRadius:(CGFloat)radius
    {
        [self roundCorners:(UIRectCornerBottomLeft|UIRectCornerBottomRight) radius:radius];
    }
    

    The frame you're currently seeing drawn is the UITextField's normal frame, so set the frame style to none. You'll also have to adjust the insets to make up for the fact that with the frame style set to none there's normally no inset.

提交回复
热议问题