使用UIBezierPath将半径设置为某些角并向自定义UIButton添加阴影

时间:2016-02-10 10:20:52

标签: ios swift uibezierpath

我有一个自定义UIButton。 我想在某些角落添加半径(而不是所有角落) 我使用UIBezierPath进行设置。 但是因为我掩盖了这个层,所以我不能添加阴影。

对于所有角落都有效:

func setupView() {
    layer.cornerRadius = 10
    addShadow(UIColor.blackColor(), opacity: 0.8, radius: 5, offset: CGSizeMake(1, 1))
}

func addShadow(color: UIColor, opacity: Float, radius: CGFloat, offset: CGSize){
    layer.shadowColor = color.CGColor
    layer.shadowOpacity = opacity
    layer.shadowRadius = radius
    layer.shadowOffset = offset
}

对于使用UIBezierPath的某些角落,我只获得圆角但没有阴影

func setupView() {
    addCornerRadiusToCurners(false, leftTop: true, rightBottom: false, leftBottom: false, radius: 10)
    addShadow(UIColor.blackColor(), opacity: 0.8, radius: 5, offset: CGSizeMake(1, 1))
}


func addCornerRadiusToCurners(rightTop: Bool = true, leftTop: Bool = true, rightBottom: Bool = true, leftBottom: Bool = true, radius: CGFloat) {

    var corners: UIRectCorner = []

    if rightTop {  corners.insert(.TopRight)  }
    if leftTop { corners.insert(.TopLeft) }
    if rightBottom {  corners.insert(.BottomRight) }
    if leftBottom { corners.insert(.BottomLeft) }

    let cornerPath = UIBezierPath(roundedRect: bounds, byRoundingCorners: corners, cornerRadii: CGSizeMake(radius, radius))
    let cornerMaskLayer = CAShapeLayer()
    cornerMaskLayer.path = cornerPath.CGPath
    layer.mask = cornerMaskLayer
}

1 个答案:

答案 0 :(得分:0)

使用此更新的CustomButton类:

class CustomButton:UIButton {

var cornerMaskLayer : CAShapeLayer!
var corners: UIRectCorner = []
var cornerRadius : CGFloat = 0

override func awakeFromNib() {
    addCornerRadiusToCurners(radius: 10)
    addShadow(UIColor.blackColor(), opacity: 0.5, radius: 2.0, offset: CGSizeMake(2, 5))
}

func addShadow(color: UIColor, opacity: Float, radius: CGFloat, offset: CGSize){
    layer.shadowColor = color.CGColor
    layer.shadowOpacity = opacity
    layer.shadowRadius = radius
    layer.shadowOffset = offset
}

func setupView() {
    addCornerRadiusToCurners(false, leftTop: true, rightBottom: false, leftBottom: false, radius: 10)
    addShadow(UIColor.blackColor(), opacity: 0.8, radius: 5, offset: CGSizeMake(1, 1))
}

override func layoutSubviews() {
    super.layoutSubviews()

    let cornerPath = UIBezierPath(roundedRect: bounds, byRoundingCorners: corners, cornerRadii: CGSizeMake(cornerRadius, cornerRadius))

    cornerMaskLayer.path = cornerPath.CGPath

}


func addCornerRadiusToCurners(rightTop: Bool = true, leftTop: Bool = true, rightBottom: Bool = true, leftBottom: Bool = true, radius: CGFloat) {

    if rightTop {  corners.insert(.TopRight)  }
    if leftTop { corners.insert(.TopLeft) }
    if rightBottom {  corners.insert(.BottomRight) }
    if leftBottom { corners.insert(.BottomLeft) }

    cornerRadius = radius

    let cornerPath = UIBezierPath(roundedRect: bounds, byRoundingCorners: corners, cornerRadii: CGSizeMake(radius, radius))
    cornerMaskLayer = CAShapeLayer()
    cornerMaskLayer.path = cornerPath.CGPath
    cornerMaskLayer.fillColor = self.backgroundColor?.CGColor
    self.backgroundColor = UIColor.clearColor()
    layer.addSublayer(cornerMaskLayer);
}

}

结果为Output