【问题标题】:Insert Icon in Navigation Bar / make BarButtonItem not clickable Swift iOS在导航栏中插入图标​​/使 BarButtonItem 不可点击 Swift iOS
【发布时间】:2019-09-05 18:15:34
【问题描述】:

我想在导航栏中放置一个蓝牙图标,以显示连接/断开状态。

我尝试添加一个 BarButtonItem,将图像设置为我的蓝牙图标,然后禁用和启用此按钮。到目前为止,这工作正常,对我来说看起来还不错,但我不想让这个按钮可以点击,这样它就不会在点击图标时改变颜色。

这可能吗,或者有没有办法将 UIImageView 放入导航栏?

谢谢!

【问题讨论】:

    标签: ios swift icons navigationbar


    【解决方案1】:

    尝试使用以下方法禁用触摸事件:

    myBarButtonItem.isUserInteractionEnabled = false
    

    【讨论】:

    • 不幸的是,UIBarButtonItems 似乎没有 isUserInteractionEnabled 属性:(
    【解决方案2】:

    navigationItem.rightBarButtonItem?.isEnabled = false

    【讨论】:

    • 我使用 isEnabled = false 来显示未连接状态。这很好用,但我也想显示连接状态,但是一旦禁用,我就无法更改 tintColor,这就是我需要解决方法的原因。
    • 将其转换为自定义 UIButton? rightNavButton = UIButton(type: .custom) 然后这样自定义?
    【解决方案3】:

    添加以下代码将解决您的问题。

    let btnBluetooth = UIButton()
    btnBluetooth.setImage(#imageLiteral(resourceName: "icon_bluetooth"), for: .normal)
    btnBluetooth.setImage(#imageLiteral(resourceName: "icon_bluetooth"), for: .highlighted)
    btnBluetooth.tintColor = .red
    
    let barButton = UIBarButtonItem(customView: btnBluetooth)
    self.navigationItem.rightBarButtonItem = barButton
    

    此代码将添加自定义按钮,您可以在其中管理正常和突出显示模式的图像。对于蓝牙状态管理,将您在UIBarButtonItem 中添加的UIButton 中的tintColor 更改为自定义视图。

    如果你点击按钮,这不会改变图像的颜色。

    如果您不想添加UIButton,可以通过以下代码添加UIImageView

    let imgBluetooth = UIImageView(image: #imageLiteral(resourceName: "icon_bluetooth"))
    imgBluetooth.tintColor = .red
    
    let barButton = UIBarButtonItem(customView: imgBluetooth)
    self.navigationItem.rightBarButtonItem = barButton
    

    另外,请确保您已选择 Render As 作为 Template Image 用于添加到 Assets.xcassets 内以影响 tintColor 的蓝牙图标。否则图像将显示为原始图像。见下文:

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-03-28
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多