无法通过编程方式从下拉按钮中检查按钮标题

时间:2019-04-14 08:29:42

标签: ios swift

我是Swift的新人,我的英语不太好

问题是我从本教程构建了一个下拉视图

youtube:https://youtu.be/22zu-OTS-3M github:https://github.com/Archetapp/Drop-Down-Menu

他以编程方式创建了一个没有情节提要的绝佳下拉视图

代码在我的Xcode上运行得很好

但是当我用按钮查看标题时

我从不明白。

这是我的代码

class ViewController: UIViewController, GMSMapViewDelegate

      override func viewDidLoad() 
      super.viewDidLoad()

      let typeBTN = dropDownBtn()
         self.view.addSubview(typeBTN)
         typeBTN.setTitle("animal", for: .normal)
         typeBTN.dropView.dropDownOptions = ["dog", "cat", "cow", "boy"]


 // ....

protocol dropDownProtocol {
    func dropDownPressed(string: String)
}

class dropDownBtn: UIButton, dropDownProtocol {

    func dropDownPressed(string: String) {
        self.setTitle(string, for: .normal)
        self.dismissDropDown()
    }

    var dropView = dropDownView()
    var height = NSLayoutConstraint()



    override init(frame: CGRect) {
        super.init(frame: frame)
        self.backgroundColor = UIColor.darkGray

        dropView = dropDownView.init(frame: CGRect.init(x: 0, y: 0, width: 0, height: 0))
        dropView.delegate = self
        dropView.translatesAutoresizingMaskIntoConstraints = false
    }

    override func didMoveToSuperview() {
        self.superview?.addSubview(dropView)
        self.superview?.bringSubviewToFront(dropView)
        dropView.topAnchor.constraint(equalTo: self.bottomAnchor).isActive = true
        dropView.centerXAnchor.constraint(equalTo: self.centerXAnchor).isActive = true
        dropView.widthAnchor.constraint(equalTo: self.widthAnchor).isActive = true
        height = dropView.heightAnchor.constraint(equalToConstant: 0)
    }

    var isOpen = false

    override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {

        if isOpen == false {
            isOpen = true
            NSLayoutConstraint.deactivate([self.height])
            if self.dropView.tableView.contentSize.height > 150 {
                self.height.constant = 170
            } else {
                self.height.constant = self.dropView.tableView.contentSize.height
            }
            NSLayoutConstraint.activate([self.height])
            UIView.animate(withDuration: 0.5, delay: 0, usingSpringWithDamping: 0.5, initialSpringVelocity: 0.5, options: .curveEaseOut, animations: {
                self.dropView.layoutIfNeeded()
                self.dropView.center.y += self.dropView.frame.height / 2
            }, completion: nil)

        }else{ dismissDropDown() }
    }

    func dismissDropDown() {
        isOpen = false
        NSLayoutConstraint.deactivate([self.height])
        self.height.constant = 0
        NSLayoutConstraint.activate([self.height])
        UIView.animate(withDuration: 0.5, delay: 0, usingSpringWithDamping: 0.5, initialSpringVelocity: 0.5, options: .curveEaseOut, animations: {
            self.dropView.center.y -= self.dropView.frame.height / 2
            self.dropView.layoutIfNeeded()
        }, completion: nil)   
    }


    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
}

class dropDownView: UIView, UITableViewDelegate, UITableViewDataSource { 

    var dropDownOptions = [String]()
    var tableView = UITableView()
    var delegate: dropDownProtocol!

    override init(frame: CGRect) {
        super.init(frame: frame)

        tableView.backgroundColor = UIColor.darkGray
        tableView.delegate = self
        tableView.dataSource = self
        self.addSubview(tableView)
        tableView.translatesAutoresizingMaskIntoConstraints = false
        tableView.leftAnchor.constraint(equalTo: self.leftAnchor).isActive = true
        tableView.rightAnchor.constraint(equalTo: self.rightAnchor).isActive = true
        tableView.topAnchor.constraint(equalTo: self.topAnchor).isActive = true
        tableView.bottomAnchor.constraint(equalTo: self.bottomAnchor).isActive = true


    }

    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }

    func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
       return dropDownOptions.count
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = UITableViewCell()
        cell.textLabel?.text = dropDownOptions[indexPath.row]
        cell.backgroundColor = UIColor.darkGray
        return cell
    }

    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {

        self.delegate.dropDownPressed(string: dropDownOptions[indexPath.row])

        print(dropDownOptions[indexPath.row])

我已经尝试了很多检查按钮标题何时更改。像这样

 print(typeBTN.currentTitle!)
 print(typeBTN.titleLabel?.text! )
 print(typeBTN.title(for: .normal))
 //I get nothing when i pressed dropdown menu options?

因为我想这样做

if typeBTN.currentTitle == "dog" {
        //show some date at my mapview
    }

但是当我单击下拉菜单中的“狗”时

它永远无法工作

有人可以帮我吗?

1 个答案:

答案 0 :(得分:0)

您可以使用委派模式将标题更改通知给视图控制器。

添加协议:

protocol DropDownButtonDelegate: AnyObject {
    func titleDidChange(_ newTitle: String)
}

在DropDownButton类中添加一个委托属性:

weak var delegate: DropDownButtonDelegate?

然后在您的dropDownPressed函数中:

func dropDownPressed(string: String) {
    self.setTitle(string, for: .normal)
    self.dismissDropDown()
    delegate?.titleDidChange(string)
}

最后在您的视图控制器中实现DropDownButtonDelegate:

class ViewController: UIViewController, GMSMapViewDelegate {

    override func viewDidLoad() {
      super.viewDidLoad()

      let typeBTN = dropDownBtn()
      self.view.addSubview(typeBTN)
      typeBTN.delegate = self 
      typeBTN.setTitle("animal", for: .normal)
      typeBTN.dropView.dropDownOptions = ["dog", "cat", "cow", "boy"]
    }
}

extension ViewController: DropDownButtonDelegate {
    func titleDidChange(_ newTitle: String) {
        print(newTitle)
    }
}