swift не может щелкнуть uibutton, расположенную внутри нескольких подпредставлений - PullRequest
0 голосов
/ 24 октября 2018

Я не получаю при нажатии arrowButton, даже print("toggleWhiteMenu pressed") не печатает в консоли?Я искал другие вопросы, подобные этому, но, похоже, они не помогли.

 let card: UIView = {
        let tsl = UIView()
        tsl.backgroundColor = UIColor.black
        tsl.alpha = 0.9
        return tsl
    }()


let yellowCard: UIView = {
    let tsl = UIView()
    tsl.backgroundColor = UIColor.yellow
    //tsl.alpha = 1
     tsl.isUserInteractionEnabled = false
    return tsl
}()



  lazy var arrowButton: UIButton = {
    let button = UIButton(type: .system)

    button.setImage(#imageLiteral(resourceName: "down arrow"), for: .normal)
    button.tintColor = UIColor.black
    button.titleLabel?.font = UIFont.boldSystemFont(ofSize: 14)
    button.addTarget(self, action: #selector(self.toggleWhiteMenu), for: .touchUpInside)
    return button
}()


func toggleWhiteMenu() {
    print("toggleWhiteMenu pressed")
    UIView.animate(withDuration: 1, animations: {

        self.whiteMenu.transform = CGAffineTransform(scaleX: 11, y: 11)
    }) { (true) in
        print("really sick")
    }
}


let whiteMenu: UIView = {
    let tsl = UIView()
    tsl.backgroundColor = UIColor.white
    tsl.alpha = 1
    tsl.isUserInteractionEnabled = false
    return tsl
}()



    let containerView: UIView = {
        let v = UIView()
        v.translatesAutoresizingMaskIntoConstraints = false
        v.backgroundColor = .yellow
        v.isUserInteractionEnabled = false
        return v
    }()

    let scrollView: UIScrollView = {
        let v = UIScrollView()
        v.translatesAutoresizingMaskIntoConstraints = false
        v.backgroundColor = .white
        return v
    }()


let backgroundImageView: UIImageView = {
    let imageView = UIImageView()
    imageView.image = UIImage(named: "eiffel tower")
    imageView.translatesAutoresizingMaskIntoConstraints = false
     imageView.isUserInteractionEnabled = false
    imageView.layer.masksToBounds = true
    imageView.contentMode = .scaleAspectFill

    return imageView
}()


func setUpViews() { 
        self.view.addSubview(scrollView)
        scrollView.addSubview(containerView)

        containerView.addSubview(backgroundImageView)
        backgroundImageView.addSubview(card)
        backgroundImageView.addSubview(yellowCard)

        yellowCard.addSubview(whiteMenu)
        yellowCard.addSubview(arrowButton)

        ///i have left out constraints except for the arrowbutton's constraints as i don't deem them necessary for this question

        arrowButton.anchor(top: nil, left: nil, bottom: nil, right: nil, paddingTop: 0, paddingLeft: 0, paddingBottom: 0, paddingRight: 0, width: view.frame.width/6, height: view.frame.width/6)

        arrowButton.clipsToBounds = true

        arrowButton.centerXAnchor.constraint(equalTo: whiteMenu.centerXAnchor).isActive = true
        arrowButton.centerYAnchor.constraint(equalTo: whiteMenu.centerYAnchor).isActive = true
}

Ответы [ 2 ]

0 голосов
/ 24 октября 2018

Вы устанавливаете:

.isUserInteractionEnabled = false

в нескольких представлениях, а затем добавляете кнопку в качестве подпредставления.isUserInteractionEnabled, установленный на false в родительском представлении, будет каскадно распространяться на все подпредставления, , включая кнопки и другие элементы управления.

0 голосов
/ 24 октября 2018

Пожалуйста, добавьте @objc с помощью метода селектора, как показано ниже.

 @objc func toggleWhiteMenu() {
    print("toggleWhiteMenu pressed")
    UIView.animate(withDuration: 1, animations: {

        self.whiteMenu.transform = CGAffineTransform(scaleX: 11, y: 11)
    }) { (true) in
        print("really sick")
    }
    }
...