转自:https://www.jianshu.com/p/cf9db8bc057c
下面创建项目并搭建UITabBarController + UINavigationController架构,最终的架构如图:
为每个nav的item添加文字、图片和selectedImage。然后运行可以看到如下图:
现在我们来改变tabBar的背景颜色
设置tabBar的背景色
创建类ANTabBarController继承自UITabBarController,并与storyBoard中的TabBarController关联。在viewDidLoad中添加如下代码:[[UITabBar appearance] setBackgroundColor:[UIColor redColor]];,运行结果如图:
但这个红色并不是真正的红色,而是系统处理过的红色,修改首页界面颜色为红色来做个对比:
所以直接通过[[UITabBar appearance] setBackgroundColor:[UIColor redColor]];(此处写错,应该是[[UITabBar appearance] setBarTintColor:[UIColor redColor]];在demo中是写对的,只是这里写错了)。来改变tabar的颜色是不能得到想要的颜色的。如果想要得到想要的颜色需要再另外添加一句:[UITabBar appearance].translucent = NO;这句表示取消tabBar的透明效果。
第二种方法是你可以在tabBar上添加一个有颜色的View:
这样也可以实现相同的效果
还有第三种方法就是使用背景图片:
[[UITabBar appearance] setBackgroundImage:[UIImage imageNamed:@"tabBarBackgroundImage"]];
[UITabBar appearance].translucent = NO;
但同样需要[UITabBar appearance].translucent = NO;
接下来需要处理的第二个问题就是:tabBarItem
设置tabBarItem
首先很多运用中需要在点击某个item后,需要改变背景色,可以通过tabBar的selectionIndicatorImage属性来实现。
第一种方式就是让美工切出符合的图直接放上去,但这种方式美工需要切多个不同尺寸的图,不方便,如果背景色改变,全部图又要重新切,很麻烦。
第二种方式就是自己画,画好后,如果背景色需要改变只需要修改颜色就可以了,不用切图代码实现:
现在选中颜色已经改变了,如图:
好了,tabBarItem的选中时的背景颜色已经弄好了。解决下一个问题
tabBarItem图标文字颜色修改
应该发现了tabBarItem的图标和文字的默认颜色是灰色,选中颜色是蓝色。这是系统默认给图标、文字修改成了灰色和蓝色。如果要改变选中item的颜色可以直接使用tabBar的tintColor来实现,但是如果图标换成别的颜色了又要重新修改tintColor,很不方便。所以重写一个继承与UITabBarItem的自定义类,在initWithCoder:方法中实现如下代码:
mostColorWithImage:方法是自定义的获取图片主颜色的方法,具体代码:
这样就完成了。
作者:Anchlate
链接:https://www.jianshu.com/p/cf9db8bc057c
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
相关推荐
然而,为了实现更个性化的用户体验或者匹配应用的整体设计风格,开发者常常需要自定义TabBarItem的背景颜色。本教程将详细讲解如何在iOS应用中更换TabBarItem的背景颜色。 首先,我们需要了解iOS中的UIAppearance...
这样做的好处是它可以与`UITabBarController`的其他`tabBarItem`无缝集成,但可能需要额外处理选中状态。 在项目`PYJTabBar`中,很可能包含了实现这一功能的代码示例或者库。你可以查看源码,学习其中的实现方式,...
这通常涉及到创建一个新的自定义类,继承自UITabBar,然后重写其方法,如`- (void)layoutSubviews`,在这个方法中可以定制TabBar的布局、颜色、选中状态的图标和文字等。此外,我们还可以利用`- (UIView *)hitTest:...
3. 背景颜色:自定义背景色可以通过设置`backgroundColor`属性实现,而在点击时改变背景色可能需要添加额外的逻辑处理。 4. 图标:除了文字,TabBar还可以包含图标,可以使用`image`和`selectedImage`属性分别设置...
在 `UITabBarControllerDemo` 文件中,你可能会找到一个实际的例子,展示了如何设置 `UITabBarController`、自定义 `UITabBar` 以及处理 `UITabBarItem` 的方法。通过查看和运行这个示例,你可以更好地理解这些概念...
默认情况下,TabbarItem的图标和文字颜色会根据选中或未选中的状态自动改变。但是,如果我们想要实现更个性化的效果,比如动态的图标、自定义字体、背景图片等,就需要自定义Tabbar。 自定义Tabbar主要有以下几个...
本教程将详细讲解如何使用纯代码实现一个自定义的TabBar,包括调整大小、设置图片、改变背景颜色以及动态添加TabBarItem。我们将主要关注Swift编程语言,但基本原理在Objective-C中同样适用。 首先,我们需要创建一...
- **颜色和背景**:可以修改TabBar的颜色和背景图片,通过`tintColor`和`barTintColor`属性进行设置。 - **动画效果**:添加过渡动画可以使TabBar更具吸引力。例如,可以使用`UIView.animate(withDuration:)`方法...
// 为选中的tabBarItem添加放大动画 let item = tabBar.items![selectedIndex] UIView.animate(withDuration: 0.2, animations: { item.image?.withRenderingMode(.alwaysOriginal) item.image = item.image?....
2. **自定义TabBar外观**:如果需要全局改变TabBar的颜色、背景或者样式,可以重写`UITabBarController`的`- (void)setupTabBar`方法,使用`tabBar.barTintColor`、`tabBar.tintColor`和`tabBar.shadowImage`等属性...
- **创建Badge实例**:对于每个TabBarItem,创建一个BadgeView实例,并设置其属性,如文字、颜色、字体等。 - **添加到TabBarItem**:将BadgeView添加为TabBarItem的子视图,定位在适当的位置,通常是在Item的右上角...
在iOS应用开发中,`UITabBarController`是一个非常重要的组件,它用于...通过创建并配置视图控制器、设置`tabBarItem`,以及将`UITabBarController`设置为应用的根视图控制器,你就可以轻松实现标签页面的切换功能。
别忘了在`tabBar`的`layoutSubviews` 方法中更新自定义徽标的frame,确保其在`tabBarItem` 的正确位置。 5. **添加动画效果** 为了增加用户体验,还可以添加一些动画效果,比如徽标出现和消失时的渐显渐隐动画,...
这可以通过设置UIViewController的tabBarItem属性或者在UITabBarController的viewControllers数组中添加它们。 3. **自定义Appearance**:通过UIAppearance协议,可以全局设置TabBar的颜色、字体、背景等属性。比如...
在iOS应用开发中,我们经常需要使用到`UITabBarController`来实现底部导航栏的功能,类似于安卓版微信的TabBar。然而,原生的`UITabBarController`并未提供滑动切换子控制器的功能,而是通过点击TabBar上的按钮来...
2. **设置`tabBarItem`**:在每个子类中,你需要设置`tabBarItem`属性,这包括图标和标题。例如: ```swift override func viewDidLoad() { super.viewDidLoad() self.tabBarItem.title = "首页" self.tabBar...
在这个类中,我们将设置TabBar的各个标签项(TabBarItem)。每个标签项通常对应一个ViewController,因此我们需要为每个标签创建对应的VC实例,并将其添加到tabBar.viewControllers数组中。例如: ```swift class ...
- 颜色和字体:可以修改文字颜色和字体,通过`tabBar.tintColor`设置选中时的文字颜色,通过`tabBarItem.titleTextAttributes`设置文字的样式。 2. **自定义UIAppearance** - `UIAppearance`协议允许开发者为整个...
1. **自定义TabBarItem**:默认的`UITabBarItem`只提供基本的图标和标题,但我们可以修改它的图像、颜色、字体、动画等。这通常通过设置`tabBarItem.title`、`tabBarItem.image`和`selectedImage`属性完成,还可以...
3. **设置TabBarItem**:为每个子控制器设置自定义的TabBarItem,可以使用`setTabBarItem:`方法或者在子控制器的`tabBarItem`属性中直接设置。 4. **处理点击事件**:可以重写`tabBar:didSelectItem:`方法,以便在...