IOS导航tabbar 自定义图片显示

一、做4个控制器时,添加导航,自定义tabbar的UITabBarItem图片;第一次进入或返回时 UITabBarItem的图片消失;如图


代码如下:

//创建4个UITabBarItem

   UITabBarItem * TabBar0 = [[UITabBarItem alloc] init];
    //[TabBar0 setTitle:@"消息"];
    [TabBar0 setFinishedSelectedImage:[UIImage imageNamed:@"oneSelected1.png"] withFinishedUnselectedImage:[UIImage imageNamed:@"oneSelect1.png"]];
    TabBar0.imageInsets = UIEdgeInsetsMake(4, 0, -4, 0);


二、我希望 如下效果


修改代码如下:

//创建4个UITabBarItem

   UITabBarItem * TabBar0 = [[UITabBarItem alloc] init];
    //[TabBar0 setTitle:@"消息"];
    [TabBar0 setFinishedSelectedImage:[[UIImage imageNamed:@"oneSelected1.png"] imageWithRenderingMode: UIImageRenderingModeAlwaysOriginal ]withFinishedUnselectedImage:[[UIImage imageNamed:@"oneSelect1.png"]imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal ]];
    TabBar0.imageInsets = UIEdgeInsetsMake(4, 0, -4, 0);


三、原因如下说明:

设置UIImage的渲染模式:UIImage.renderingMode
着色(Tint Color)是iOS7界面中的一个.设置UIImage的渲染模式:UIImage.renderingMode重大改变,你可以设置一个UIImage在渲染时是否使用当前视图的Tint Color。UIImage新增了一个只读属性:renderingMode,对应的还有一个新增方法:imageWithRenderingMode:,它使用UIImageRenderingMode枚举值来设置图片的renderingMode属性。该枚举中包含下列值:
  1. UIImageRenderingModeAutomatic  // 根据图片的使用环境和所处的绘图上下文自动调整渲染模式。  
  2. UIImageRenderingModeAlwaysOriginal   // 始终绘制图片原始状态,不使用Tint Color。  
  3. UIImageRenderingModeAlwaysTemplate   // 始终根据Tint Color绘制图片,忽略图片的颜色信息。  
 
renderingMode属性的默认值是UIImageRenderingModeAutomatic,即UIImage是否使用Tint Color取决于它显示的位置

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值