如何将圆角半径添加到 UIView 周围的虚线边框

Sha*_*man 4 calayer uiview ios swift

我有一个圆形,UIView并在其中添加了一条虚线描边。

,,,
    var view = CAShapeLayer()
    view.strokeColor = UIColor.red.cgColor
    view.lineDashPattern = [2, 2]
    view.frame = addphotoView.bounds
    view.fillColor = nil
    view.path = UIBezierPath(rect: addphotoView.bounds).cgPath
    view.cornerRadius = 16
    view.masksToBounds = true

    addphotoView.layer.addSublayer(yourViewBorder)
Run Code Online (Sandbox Code Playgroud)

view.cornerRadius没有按预期工作: 演示

角落被抹去。

Moj*_*ini 13

快速回答

你应该舍入Layers path

像这样:

borderLayer.path = UIBezierPath(roundedRect: addphotoView.bounds, byRoundingCorners: .allCorners, cornerRadii: CGSize(width: 16, height: 16)).cgPath
Run Code Online (Sandbox Code Playgroud)

使用扩展更好的答案

您可以将所有这些逻辑移动到扩展中:

extension UIView {
    @discardableResult
    func addLineDashedStroke(pattern: [NSNumber]?, radius: CGFloat, color: CGColor) -> CALayer {
        let borderLayer = CAShapeLayer()

        borderLayer.strokeColor = color
        borderLayer.lineDashPattern = pattern
        borderLayer.frame = bounds
        borderLayer.fillColor = nil
        borderLayer.path = UIBezierPath(roundedRect: bounds, byRoundingCorners: .allCorners, cornerRadii: CGSize(width: radius, height: radius)).cgPath

        layer.addSublayer(borderLayer)
        return borderLayer
    }
}
Run Code Online (Sandbox Code Playgroud)

用法:

addphotoView.addLineDashedStroke(pattern: [2, 2], radius: 16, color: UIColor.gray.cgColor)
Run Code Online (Sandbox Code Playgroud)

演示

  • 您应该在诸如“layoutSubviews”之类的地方更新图层 (3认同)