I have a problem with tabBarItem icon.Here is a screenshot of a part of my storyboard.
There is a basic viewController with some buttons. When one of these buttons is touched up, a tabBarController with three tabs appears.In iOS 8,icons of tabBarItems does not appear initially.If i change view controller,both icons of previous and current view controller appear.if i select the third tab,then all icons of tabBarItems appear.Here is a screenshot of my problem:
First Appearance of TabBarController :
If i change tab:
Here is the code that i use to set icons(all icons are 30x30) of tabBarItems into viewDidLoad method of first viewController of TabBarController:
[[[self.tabBarController.viewControllers objectAtIndex:0] tabBarItem] setFinishedSelectedImage:[UIImage imageNamed:@"1d1.png"] withFinishedUnselectedImage:[UIImage imageNamed:@"1b1.png"]];
[[[self.tabBarController.viewControllers objectAtIndex:1] tabBarItem] setFinishedSelectedImage:[UIImage imageNamed:@"2d1.png"] withFinishedUnselectedImage:[UIImage imageNamed:@"2b1.png"]];
[[[self.tabBarController.viewControllers objectAtIndex:2] tabBarItem] setFinishedSelectedImage:[UIImage imageNamed:@"3d1.png"] withFinishedUnselectedImage:[UIImage imageNamed:@"3b1.png"]];
Here is a screenshot of iOS 7 that it works properly:
Can anyone help me with this??
After some hours of searching and reading different answers including @Zala's answer,this part of code into viewDidLoad of first viewController of TabBarController made the difference and finally worked.
if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 7.0)
{
UITabBarItem *tabBarItem = [self.tabBarController.tabBar.items objectAtIndex:0];
UIImage *unselectedImage = [UIImage imageNamed:@"1b1.png"];
UIImage *selectedImage = [UIImage imageNamed:@"1d1.png"];
[tabBarItem setImage: [unselectedImage imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal]];
[tabBarItem setSelectedImage:[selectedImage imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal]];
UITabBarItem *tabBarItem1 = [self.tabBarController.tabBar.items objectAtIndex:1];
UIImage *unselectedImage1 = [UIImage imageNamed:@"2b1.png"];
UIImage *selectedImage1 = [UIImage imageNamed:@"2d1.png"];
[tabBarItem1 setImage: [unselectedImage1 imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal]];
[tabBarItem1 setSelectedImage: [selectedImage1 imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal]];
UITabBarItem *tabBarItem2 = [self.tabBarController.tabBar.items objectAtIndex:2];
UIImage *unselectedImage2 = [UIImage imageNamed:@"3b1.png"];
UIImage *selectedImage2 = [UIImage imageNamed:@"3d1.png"];
[tabBarItem2 setImage: [unselectedImage2 imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal]];
[tabBarItem2 setSelectedImage:[selectedImage2 imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal]];
[tabBarItem setTitle:@"Φωτογραφίες"];
[tabBarItem2 setTitle:@"360° Φωτογραφία"];
[tabBarItem1 setTitle:@"Βίντεο"];
}
else
{
[[[self.tabBarController.viewControllers objectAtIndex:0] tabBarItem] setFinishedSelectedImage:[UIImage imageNamed:@"1d1.png"] withFinishedUnselectedImage:[UIImage imageNamed:@"1b1.png"]];
[[[self.tabBarController.viewControllers objectAtIndex:1] tabBarItem] setFinishedSelectedImage:[UIImage imageNamed:@"2d1.png"] withFinishedUnselectedImage:[UIImage imageNamed:@"2b1.png"]];
[[[self.tabBarController.viewControllers objectAtIndex:2] tabBarItem] setFinishedSelectedImage:[UIImage imageNamed:@"3d1.png"] withFinishedUnselectedImage:[UIImage imageNamed:@"3b1.png"]];
[[[self.tabBarController.viewControllers objectAtIndex:0] tabBarItem] setTitle:@"Φωτογραφίες"];
[[[self.tabBarController.viewControllers objectAtIndex:2] tabBarItem] setTitle:@"360° Φωτογραφία"];
[[[self.tabBarController.viewControllers objectAtIndex:1] tabBarItem] setTitle:@"Βίντεο"];
}
setFinishedSelectedImage:withFinishedUnselectedImage:
is deprecated from iOS 7 use image
and selectedImage
property of UITabBarItem
instead.
To set the custom image:
UITabBarItem *tabBarItem1 = [tabBar.items objectAtIndex:0];
if ([self iOS7OrAbove])
{
//use UIImageRenderingModeAlwaysOriginal to set the custom image for ios 7 and above.
tabBarItem1.selectedImage = [[UIImage imageNamed:@"SelectedImage"] imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
tabBarItem1.image = [[UIImage imageNamed:@"UnselectedImage"] imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
}
else
{
[tabBarItem1 setFinishedSelectedImage:[UIImage imageNamed:@"SelectedImage"] withFinishedUnselectedImage:[UIImage imageNamed:@"UnselectedImage"]];
}
Hope this works fine.
Even if setFinishedSelectedImage:withFinishedUnselectedImage:
is deprecated in iOS7, it is working fine in iOS7 but not in 8.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With