Upv*_*ote 82 uitabbaritem ios swift
简单的问题,如何删除标签栏项目文本并仅显示图像?
我想要在Instagram应用中喜欢的酒吧项目:

在xcode 6中的检查器中,我删除标题并选择@ 2x(50px)和@ 3x(75px)图像.但是,图像不使用已删除文本的可用空间.任何想法如何实现相同的标签栏项目图像,如在instagram应用程序?
mus*_*afa 127
你应该玩的imageInsets财产UITabBarItem.这是示例代码:
let tabBarItem = UITabBarItem(title: nil, image: UIImage(named: "more")
tabBarItem.imageInsets = UIEdgeInsets(top: 9, left: 0, bottom: -9, right: 0)
里面的值UIEdgeInsets取决于您的图像大小.这是我的应用程序中的代码的结果:

ddi*_*ego 77
// Remove the titles and adjust the inset to account for missing title
for(UITabBarItem * tabBarItem in self.tabBar.items){
    tabBarItem.title = @"";
    tabBarItem.imageInsets = UIEdgeInsetsMake(6, 0, -6, 0);
}
tes*_*sla 38
如果在视图控制器中设置,则使用将每个UITabBarItems title属性设置为""
和更新的方法imageInsets将无法正常工作self.title.例如,如果self.viewControllers嵌入了UITabBarController,则UINavigationController需要在导航栏上显示标题.在这种情况下,UINavigationItem直接使用设置标题self.navigationItem.title,而不是self.title.
kor*_*gx9 27
Swift版本的ddiego回答
与iOS 11兼容
在设置viewController的标题后,在viewControllers的每个第一个子节点的viewDidLoad中调用此函数
最佳实践:
可选择@daspianist在评论中提出
创建类此类BaseTabBarController的子类:UITabBarController,UITabBarControllerDelegate并将此函数放在子类的viewDidLoad中
func removeTabbarItemsText() {
    var offset: CGFloat = 6.0
    if #available(iOS 11.0, *), traitCollection.horizontalSizeClass == .regular {
        offset = 0.0
    }
    if let items = tabBar.items {
        for item in items {
            item.title = ""
            item.imageInsets = UIEdgeInsets(top: offset, left: 0, bottom: -offset, right: 0)
        }
    }
}
Mar*_*cas 23
如果你正在使用故事板,这将是你最好的选择.它遍历所有标签栏项目,并且每个项目标题都设置为空,并使图像全屏显示.(您必须在故事板中添加图像)
for tabBarItem in tabBar.items!
{
   tabBarItem.title = ""
   tabBarItem.imageInsets = UIEdgeInsetsMake(6, 0, -6, 0)
}
atl*_*lwx 14
iOS 11在许多这些解决方案中都存在问题,所以我只是通过继承UITabBar并覆盖layoutSubviews来修复iOS 11上的问题.
class MainTabBar: UITabBar {
    override func layoutSubviews() {
        super.layoutSubviews()
        // iOS 11: puts the titles to the right of image for horizontal size class regular. Only want offset when compact.
        // iOS 9 & 10: always puts titles under the image. Always want offset.
        var verticalOffset: CGFloat = 6.0
        if #available(iOS 11.0, *), traitCollection.horizontalSizeClass == .regular {
            verticalOffset = 0.0
        }
        let imageInset = UIEdgeInsets(
            top: verticalOffset,
            left: 0.0,
            bottom: -verticalOffset,
            right: 0.0
        )
        for tabBarItem in items ?? [] {
            tabBarItem.title = ""
            tabBarItem.imageInsets = imageInset
        }
    }
}
Fou*_*our 12
我在BaseTabBarController的viewDidLoad中使用了以下代码.请注意,在我的示例中,我有5个选项卡,所选图像将始终为base_image +"_ select".
// Get tab bar and set base styles
let tabBar = self.tabBar;
tabBar.backgroundColor = UIColor.whiteColor()
// Without this, images can extend off top of tab bar
tabBar.clipsToBounds = true
// For each tab item..
let tabBarItems = tabBar.items?.count ?? 0
for i in 0 ..< tabBarItems {
    let tabBarItem = tabBar.items?[i] as UITabBarItem
    // Adjust tab images (Like mstysf says, these values will vary)
    tabBarItem.imageInsets = UIEdgeInsetsMake(5, 0, -6, 0);
    // Let's find and set the icon's default and selected states
    // (use your own image names here)
    var imageName = ""
    switch (i) {
    case 0: imageName = "tab_item_feature_1"
    case 1: imageName = "tab_item_feature_2"
    case 2: imageName = "tab_item_feature_3"
    case 3: imageName = "tab_item_feature_4"
    case 4: imageName = "tab_item_feature_5"
    default: break
    }
    tabBarItem.image = UIImage(named:imageName)!.imageWithRenderingMode(.AlwaysOriginal)
    tabBarItem.selectedImage = UIImage(named:imageName + "_selected")!.imageWithRenderingMode(.AlwaysOriginal)
}
Jos*_*ent 10
Swift 4方法
我能够通过实现一个带TabBarItem并对其进行一些格式化的函数来完成这个技巧.
稍微向下移动图像以使其更加居中,并隐藏选项卡栏的文本.比将其标题设置为空字符串更好,因为当你有一个NavigationBar时,TabBar在选中时重新获得viewController的标题
func formatTabBarItem(tabBarItem: UITabBarItem){
    tabBarItem.imageInsets = UIEdgeInsets(top: 6, left: 0, bottom: -6, right: 0)
    tabBarItem.setTitleTextAttributes([NSAttributedStringKey.foregroundColor:UIColor.clear], for: .selected)
    tabBarItem.setTitleTextAttributes([NSAttributedStringKey.foregroundColor:UIColor.clear], for: .normal)
}
Swift中一个最小的,安全的UITabBarController扩展(基于@ korgx9答案):
extension UITabBarController {
  func removeTabbarItemsText() {
    tabBar.items?.forEach {
      $0.title = ""
      $0.imageInsets = UIEdgeInsets(top: 6, left: 0, bottom: -6, right: 0)
    }
  }
}
除了最佳答案,这是一种更好,更简单的方法:
[[UITabBarItem appearance] setTitleTextAttributes:@{NSForegroundColorAttributeName: [UIColor clearColor]}
                                         forState:UIControlStateNormal];
[[UITabBarItem appearance] setTitleTextAttributes:@{NSForegroundColorAttributeName: [UIColor clearColor]}
                                         forState:UIControlStateHighlighted];
将其放入您的应用中,AppDelegate.didFinishLaunchingWithOptions以便在应用程序的整个生命周期中影响所有选项卡栏按钮。
| 归档时间: | 
 | 
| 查看次数: | 57101 次 | 
| 最近记录: |