Изображения не округляются в UIStackView - PullRequest
0 голосов
/ 13 сентября 2018

Я пытаюсь округлить несколько изображений и добавить их в виде стека, по некоторым причинам это не работает.По сути, у меня есть массив со всеми UIImage именами и я присваиваю им UIImageView.Когда я пытаюсь сделать из изображения круг, он не работает:

 var navStackView : UIStackView = {
    let stack = UIStackView()
    stack.axis = .horizontal
    stack.alignment = .center
    stack.distribution = .fillEqually
   // stack.spacing = -10
    stack.translatesAutoresizingMaskIntoConstraints = false
    return stack
}()

var images = ["1", "2", "3", "4"]

override func viewDidLoad() {
    super.viewDidLoad()

    let navController = navigationController!

    navController.navigationBar.addSubview(navStackView)
    // x, y, w, h
    navStackView.leadingAnchor.constraint(equalTo: navController.navigationBar.leadingAnchor).isActive = true
    navStackView.trailingAnchor.constraint(equalTo: navController.navigationBar.trailingAnchor).isActive = true
    navStackView.topAnchor.constraint(equalTo: navController.navigationBar.topAnchor).isActive = true
    navStackView.bottomAnchor.constraint(equalTo: navController.navigationBar.bottomAnchor).isActive = true


    for image in images {
        let imageView = UIImageView()
        imageView.image = UIImage(named: image)
        imageView.layer.cornerRadius = imageView.frame.height / 2
        imageView.clipsToBounds = true
        imageView.layer.masksToBounds = false
        imageView.contentMode = .scaleAspectFit
     //   imageView.frame = CGRect(x: 0, y: 0, width: 30, height: 30)
        navStackView.addArrangedSubview(imageView)

        navStackView.layoutIfNeeded()
    }

    navigationItem.titleView = navStackView
}

1 Ответ

0 голосов
/ 13 сентября 2018

Вы можете попробовать

var once = true
override func viewDidLayoutSubviews() {
  super.viewDidLayoutSubviews()
  if once {
     navStackView.subviews.forEach { $0.layer.cornerRadius = $0.frame.height / 2 }
     once = false
  }
}
...