`

(转)UITabBarController、TabBar背景颜色设置、TabBarItem颜色处理

    博客分类:
  • IOS
阅读更多

转自: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
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
分享到:
评论

相关推荐

    ios-更换 tabBarItem的背景颜色.zip

    然而,为了实现更个性化的用户体验或者匹配应用的整体设计风格,开发者常常需要自定义TabBarItem的背景颜色。本教程将详细讲解如何在iOS应用中更换TabBarItem的背景颜色。 首先,我们需要了解iOS中的UIAppearance...

    OC-高度自定义封装tabbar框架

    这通常涉及到创建一个新的自定义类,继承自UITabBar,然后重写其方法,如`- (void)layoutSubviews`,在这个方法中可以定制TabBar的布局、颜色、选中状态的图标和文字等。此外,我们还可以利用`- (UIView *)hitTest:...

    ios-自定义tabbar.zip

    3. 背景颜色:自定义背景色可以通过设置`backgroundColor`属性实现,而在点击时改变背景色可能需要添加额外的逻辑处理。 4. 图标:除了文字,TabBar还可以包含图标,可以使用`image`和`selectedImage`属性分别设置...

    IOS UITabBarController 使用示例

    在 `UITabBarControllerDemo` 文件中,你可能会找到一个实际的例子,展示了如何设置 `UITabBarController`、自定义 `UITabBar` 以及处理 `UITabBarItem` 的方法。通过查看和运行这个示例,你可以更好地理解这些概念...

    自定义tabbar 例子

    默认情况下,TabbarItem的图标和文字颜色会根据选中或未选中的状态自动改变。但是,如果我们想要实现更个性化的效果,比如动态的图标、自定义字体、背景图片等,就需要自定义Tabbar。 自定义Tabbar主要有以下几个...

    TabBar的纯代码实现

    本教程将详细讲解如何使用纯代码实现一个自定义的TabBar,包括调整大小、设置图片、改变背景颜色以及动态添加TabBarItem。我们将主要关注Swift编程语言,但基本原理在Objective-C中同样适用。 首先,我们需要创建一...

    IOS 用户自定义TabBar

    - **颜色和背景**:可以修改TabBar的颜色和背景图片,通过`tintColor`和`barTintColor`属性进行设置。 - **动画效果**:添加过渡动画可以使TabBar更具吸引力。例如,可以使用`UIView.animate(withDuration:)`方法...

    UITabBarController

    2. **自定义TabBar外观**:如果需要全局改变TabBar的颜色、背景或者样式,可以重写`UITabBarController`的`- (void)setupTabBar`方法,使用`tabBar.barTintColor`、`tabBar.tintColor`和`tabBar.shadowImage`等属性...

    UItabbarController 简单使用Demo

    在iOS应用开发中,`UITabBarController`是一个非常重要的组件,它用于...通过创建并配置视图控制器、设置`tabBarItem`,以及将`UITabBarController`设置为应用的根视图控制器,你就可以轻松实现标签页面的切换功能。

    自定义UITabBarController的badge的外观

    别忘了在`tabBar`的`layoutSubviews` 方法中更新自定义徽标的frame,确保其在`tabBarItem` 的正确位置。 5. **添加动画效果** 为了增加用户体验,还可以添加一些动画效果,比如徽标出现和消失时的渐显渐隐动画,...

    iOS tabbar图片资源

    这可以通过设置UIViewController的tabBarItem属性或者在UITabBarController的viewControllers数组中添加它们。 3. **自定义Appearance**:通过UIAppearance协议,可以全局设置TabBar的颜色、字体、背景等属性。比如...

    swift-在系统UITabBarController的基础上实现安卓版微信TabBar的滑动切换功能

    在iOS应用开发中,我们经常需要使用到`UITabBarController`来实现底部导航栏的功能,类似于安卓版微信的TabBar。然而,原生的`UITabBarController`并未提供滑动切换子控制器的功能,而是通过点击TabBar上的按钮来...

    tabBar使用

    2. **设置`tabBarItem`**:在每个子类中,你需要设置`tabBarItem`属性,这包括图标和标题。例如: ```swift override func viewDidLoad() { super.viewDidLoad() self.tabBarItem.title = "首页" self.tabBar...

    ios TabBar + Navigation纯代码实现

    在这个类中,我们将设置TabBar的各个标签项(TabBarItem)。每个标签项通常对应一个ViewController,因此我们需要为每个标签创建对应的VC实例,并将其添加到tabBar.viewControllers数组中。例如: ```swift class ...

    自定义TabBar

    - 颜色和字体:可以修改文字颜色和字体,通过`tabBar.tintColor`设置选中时的文字颜色,通过`tabBarItem.titleTextAttributes`设置文字的样式。 2. **自定义UIAppearance** - `UIAppearance`协议允许开发者为整个...

    自定义UITabBarController

    1. **自定义TabBarItem**:默认的`UITabBarItem`只提供基本的图标和标题,但我们可以修改它的图像、颜色、字体、动画等。这通常通过设置`tabBarItem.title`、`tabBarItem.image`和`selectedImage`属性完成,还可以...

    ios-自定义UITabBarController,完美的搭建框架,可以直接用在项目中,还有完美的UIwebView.zip

    3. **设置TabBarItem**:为每个子控制器设置自定义的TabBarItem,可以使用`setTabBarItem:`方法或者在子控制器的`tabBarItem`属性中直接设置。 4. **处理点击事件**:可以重写`tabBar:didSelectItem:`方法,以便在...

    swift自定义tabbar

    在Swift中,我们可以使用`UITabBarItem`类来创建和配置这些项目,而`UITabBarController`负责管理这些ViewControllers以及它们与TabBarItem的关联。 在标准的TabBar中,所有按钮的大小和样式都是统一的。然而,为了...

    自定义tabBar

    1. **创建自定义TabBarItem** - 可以通过创建自定义`UITabBarItem`子类,重写`- (void)setSelected:(BOOL)selected`方法来自定义选中和未选中的状态。 - 使用`UIImage`的`withRenderingMode:`方法设置图片渲染模式...

    swift-一个简单实用的自定义tabBar点击tabbar有动画效果

    // 为选中的tabBarItem添加放大动画 let item = tabBar.items![selectedIndex] UIView.animate(withDuration: 0.2, animations: { item.image?.withRenderingMode(.alwaysOriginal) item.image = item.image?....

Global site tag (gtag.js) - Google Analytics