簡體   English   中英

UIView clipsToBounds 不起作用

[英]UIView clipsToBounds doesn't work

我有一個帶有 XIB 的視圖控制器,里面有一個視圖( contentView )。 此視圖包含一些按鈕。

內容視圖有圓角和邊界剪輯,但它不尊重剪輯矩形。 我在視圖控制器的viewDidLoad中設置了角半徑和clipsToBounds

在這里您可以看到顯示視圖以正確方式組合的顯示屏幕截圖,但在模擬器和設備上不遵守剪切邊界。

任何人都可以請幫助我了解發生了什么。

該應用程序針對 iOS 10 和 11,兩者都有相同的問題。

在此處輸入圖片說明

在此處輸入圖片說明

在此處輸入圖片說明

我找到了一個解決方案,我移動了 viewDidLayoutSubviews 中的 clipsToBound 而不是 viewDidLoad 現在可以工作了

override func viewDidLoad() {
    super.viewDidLoad()

    contentView.layer.cornerRadius = Dimensions.CornerRaius
    contentView.dropShadow()
}

override func viewDidLayoutSubviews() {
    super.viewDidLayoutSubviews()

    contentView.clipsToBounds = true
}

我像這樣定義了我的視圖(在我的情況下為 UIView):

fileprivate let backView: UIView = {
    let view = UIView()
    view.clipsToBounds = true
    view.layer.masksToBounds = false
    view.layer.cornerRadius = 10
    view.translatesAutoresizingMaskIntoConstraints = false
    return view
}()

圖像:

fileprivate let imgView: UIImageView = {
    let iv = UIImageView()
    iv.translatesAutoresizingMaskIntoConstraints = false
    return iv
}()

就我而言,我在自定義表格視圖單元格中定義了這些元素:

class customCell: UITableViewCell {

雖然我在背景視圖的定義中設置了“clipsToBounds = true” ,但沒有剪輯圖像。

但是,如果我稍后設置“clipsToBounds = true” ,它會剪輯圖像。

override init(style: UITableViewCell.CellStyle, reuseIdentifier: String?) {
    super.init(style: style, reuseIdentifier: reuseIdentifier)

    backView.addSubview(imgView)
    contentView.addSubview(backView)

    imgView.topAnchor.constraint(equalTo: backView.topAnchor, constant: 0).isActive = true
    imgView.leadingAnchor.constraint(equalTo: backView.leadingAnchor, constant: 0).isActive = true
    imgView.trailingAnchor.constraint(equalTo: backView.trailingAnchor, constant: 0).isActive = true
    imgView.heightAnchor.constraint(equalTo: imgView.widthAnchor, multiplier: 1/4).isActive = true

    backView.topAnchor.constraint(equalTo: contentView.topAnchor, constant: 0).isActive = true
    backView.leadingAnchor.constraint(equalTo: contentView.leadingAnchor, constant: 15).isActive = true
    backView.trailingAnchor.constraint(equalTo: contentView.trailingAnchor, constant: -15).isActive = true
    backView.bottomAnchor.constraint(equalTo: contentView.bottomAnchor, constant: 0).isActive = true

“init”方法中:

backView.clipsToBounds = true

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM