我正在使用Storyboarding,我有一个带有五个标签的标签栏控制器。在故事板中,我可以设置标签栏项目的图像。 Apple文档建议每个标签栏项目有两个图标 - 一个用于选定状态,另一个用于未选择状态。
我无法弄清楚如何使用故事板来做到这一点。
答案 0 :(得分:145)
您可以使用故事板设置标签栏的选定图像。我试过,它对我有用。 选择UITabbarItem并添加运行时属性'selectedImage',选择Type作为'Image'并将图像名称作为其值。
我正在使用XCode 6.0,我的最低部署目标是iOS 8.0。
答案 1 :(得分:19)
以下是Tabbar For XCode中选定/未选中图片的完整解决方案> = 8:
答案 2 :(得分:11)
是的,使用故事板无法做到这一点 - 需要编写代码。
在UINavigationViewController
的{{1}}方法中,我们可以编写以下代码 -
viewDidLoad
答案 3 :(得分:11)
答案 4 :(得分:7)
您现在可以在故事板中轻松完成此操作。在您拥有的每个tabview控制器上,它应该在层次结构中包含一个Tab Bar项(看起来像一个小蓝星),单击此按钮,右侧的设置应如下图所示。标签栏标题&图像可以在这里更改。
答案 5 :(得分:5)
答案 6 :(得分:5)
在新的Xcode 8中,您可以在Storyboard中进行操作,而无需像高级答案中所建议的那样定义运行时属性。
不要忘记图片应该具有以下尺寸:
答案 7 :(得分:3)
应在相应的视图控制器中设置图标。执行此操作时,您可以自由重新排列故事板主选项卡控制器中视图控制器的顺序,而无需更改每个图标的代码(objectAtIndex:0
)。
将以下行放入viewDidLoad
方法:
if (self.navigationController.viewControllers.count < 2)
self.navigationController.tabBarItem.selectedImage = [UIImage imageNamed:@"image-selected.png"];
if
条件确保仅为最顶层的视图控制器更改按钮。当您将导航层次结构中的视图控制器重用为子视图控制器时,这是必需的。
答案 8 :(得分:3)
SWIFT 3.0 - &gt; 设置标签栏按钮图像的理想方法如下:
首先设置要用于按钮的图像:
let homeImage = UIImage(named: "TabHome")
let homeTappedImage = UIImage(named: "TabHomeRed")
然后设置UITabButtonItem类型的按钮:
let homeButton = UITabBarItem(title: homeText, image: homeImage, selectedImage: homeTappedImage)
//with this method you set the image when the button is not selected
homeButton.image = homeImage?.withRenderingMode(UIImageRenderingMode.alwaysOriginal)
//with this method you set the image when the button is selected
homeButton.selectedImage = homeTappedImage?.withRenderingMode(.alwaysOriginal)