我调用的控制器中有一个函数

private func toggleLauncher() {
    let launcher = CommentsLauncher()
    launcher.showLauncher()
}


这实质上是在当前视图之上添加一个视图,并带有半透明的背景。

然后,我想在新添加的视图的底部呈现自定义inputAccessoryView

class CommentsLauncher: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()

        view.backgroundColor = UIColor(white: 0, alpha: 0.5)
    }

    func showLauncher() {
         if let window = UIApplication.shared.keyWindow {
            window.addSubview(view)
        }
    }

    override var inputAccessoryView: UIView? {
        get {
            let containerView = UIView()
            containerView.frame = CGRect(x: 0, y: 0, width: view.frame.width, height: 50)
            containerView.backgroundColor = .purple
            return containerView
        }
    }

    override var canBecomeFirstResponder: Bool {
        return true
    }
}


尽管发生的所有事情都是半透明的背景可见,但是我也没有在视图中添加inputAccessoryView,我不确定为什么。

最佳答案

您的CommentsLauncher永远不会成为您提供的代码中的第一响应者。当响应者成为第一响应者时,将显示UIResponder的inputAccessoryView。

将showLauncher方法更改为如下所示:

func showLauncher() {
    if let window = UIApplication.shared.keyWindow {
        window.addSubview(view)
        becomeFirstResponder()
    }
}


并且您应该看到输入附件视图。

关于ios - 如何在此 View Controller 中显示inputAccessoryView,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/54929565/

10-12 00:08