触摸开始时突出显示多个按钮

Posted

技术标签:

【中文标题】触摸开始时突出显示多个按钮【英文标题】:Make multiple buttons highlight when touch begins 【发布时间】:2017-03-16 12:46:17 【问题描述】:

我在一个视图中放置了三个按钮,每个按钮都有不同的个人资料图片。当触摸开始对任何单个按钮进行触摸时,我需要所有三个按钮都突出显示,以便三个按钮一起看起来是一个按钮。我已经尝试了以下代码,但它不起作用。有什么想法吗?

    let tapGesture = UITapGestureRecognizer(target: self, action: #selector(normalTap))
    tapGesture.numberOfTapsRequired = 1
    friendsBtn1.addGestureRecognizer(tapGesture)

    func normalTap(sender: UITapGestureRecognizer)
        if sender.state == .began 
            friendsBtn2.isHighlighted = true
            friendsBtn3.isHighlighted = true
        
        if sender.state == .ended 
            friendsBtn2.isHighlighted = false
            friendsBtn3.isHighlighted = false
        
        print("Normal tap")
    

【问题讨论】:

你为friendsBtn2和friendsBtn3设置了高亮图像吗? 结帐更新的答案。 【参考方案1】:

我认为不需要UITapGesture 你可以这样管理。 首先,您需要将突出显示的图像设置为按钮和设置按钮事件,如下所示。

override func viewDidLoad() 
        super.viewDidLoad()

        friendsBtn2.setImage(UIImage(named: "highlighted.png"), for: .highlighted)
        friendsBtn3.setImage(UIImage(named: "highlighted.png"), for: .highlighted)

        friendsBtn1.addTarget(self, action: #selector(YourViewController.touchDownEvent), for: .touchDown)
        friendsBtn1.addTarget(self, action: #selector(YourViewController.touchUpInsideEvent), for: .touchUpInside)
    

之后在 ViewController 中添加方法 touchDownEvent(),touchUpInsideEvent()

func touchDownEvent() 
    self.allButtonHighlighted(fleg: true)


func touchUpInsideEvent() 
    self.allButtonHighlighted(fleg: false)


func allButtonHighlighted( fleg: Bool) 
    friendsBtn2.isHighlighted = fleg
    friendsBtn3.isHighlighted = fleg

我希望它会起作用。

【讨论】:

我只是在 Xcode 8.2.1 中使用按钮的常规突出显示,而不是直接设置突出显示的图像。我确实尝试按照您所说的进行设置,但问题仍然是我的代码没有将其他按钮设置为突出显示。 首先使用断点并检查您的代码“friendsBtn2.isHighlighted = true”是否执行?【参考方案2】:

我确实解决了这个问题。这是代码。

[friendsBtn1, friendsBtn2, friendsBtn3].forEach  button in
        button?.addTarget(self, action:#selector(highlightAllButtons(sender:)), for: .touchDown)
        button?.addTarget(self, action:#selector(unhighlightAllButtons(sender:)), for: [.touchUpInside, .touchUpOutside])
    

func highlightAllButtons(sender: UIButton) 
    [friendsBtn1, friendsBtn2, friendsBtn3].forEach  button in
        button.isHighlighted = true
    

func unhighlightAllButtons(sender: UIButton) 
    [friendsBtn1, friendsBtn2, friendsBtn3].forEach  button in
        button.isHighlighted = false
    

【讨论】:

【参考方案3】:

为按钮操作中的所有三个按钮尝试[button setSelected:YES];

【讨论】:

以上是关于触摸开始时突出显示多个按钮的主要内容,如果未能解决你的问题,请参考以下文章

UIButton 在单元格被触摸时也会突出显示

点击时突出显示 tableview 单元格,按下警报控制器操作按钮时取消突出显示

如何选择/突出显示列表视图中的项目而不触摸它?

MobileSafari 的正确触摸按钮行为

UIControl 跟踪在不同 UIControl 上开始的触摸

c_cpp 方形按钮与背景动画触摸向下和向上(突出显示)