将UIPickerView放在UIAlertController的中心

时间:2018-12-25 13:41:46

标签: ios arrays swift uipickerview uialertcontroller

如何将 UIPickerView 放置在 UIAlertController 的中心?

现在我有了以下代码:

let alertController = UIAlertController(title: "Представьтесь пожалуйста", message: "Кто вы?", preferredStyle: .alert)
alertController.isModalInPopover = true
userTypePickerView = UIPickerView(frame: CGRect(x: 0,
                                                y: 0,
                                                width: alertController.view.bounds.size.width,
                                                height: 140))
userTypePickerView.delegate = self
userTypePickerView.dataSource = self
let height: NSLayoutConstraint = NSLayoutConstraint(item: alertController.view, attribute: .height, relatedBy: .equal, toItem: nil, attribute: .notAnAttribute, multiplier: 1, constant: 240)
alertController.view.addConstraint(height)
alertController.view.addSubview(userTypePickerView)

我看到这张照片...

enter image description here

1 个答案:

答案 0 :(得分:0)

尽管我投票赞成创建自定义提醒,但是您可以这样做

let alertController = UIAlertController(title: "Представьтесь пожалуйста", message: "Кто вы?", preferredStyle: .alert)
alertController.addAction(UIAlertAction(title: "ok", style: .default, handler: nil))
alertController.isModalInPopover = true
let userTypePickerView = UIPickerView(frame:.zero)
 alertController.view.addSubview(userTypePickerView)
userTypePickerView.translatesAutoresizingMaskIntoConstraints = false
NSLayoutConstraint.activate([
    userTypePickerView.widthAnchor.constraint(equalToConstant: 200),
    userTypePickerView.heightAnchor.constraint(equalToConstant: 200),
    userTypePickerView.topAnchor.constraint(equalTo: alertController.view.topAnchor,constant:70),
    userTypePickerView.bottomAnchor.constraint(equalTo: alertController.view.bottomAnchor,constant:-40),
    userTypePickerView.centerXAnchor.constraint(equalTo: alertController.view.centerXAnchor)
])
userTypePickerView.backgroundColor = .red
self.present(alertController, animated: true, completion: nil)