iOS 自定义TabBarController
转自:http://blog.csdn.net/xn4545945/article/details/35994863
一、自定义的思路
iOS中的TabBarController确实已经很强大了,大部分主流iOS应用都会采用。但是往往也不能满足全部的需求,因此需要自定义TabBar,自定义需要对系统的TabBar工作方式有很好的理解,自定义需要勇气。
自定义TabBar的原则:尽量利用系统自带TabBar,只改需要改的地方。
三、细节很重要
XNTabBarController.h
- #import <UIKit/UIKit.h>
@interface
@end
XNTabBarController.m
- //
// XNTabBarController.m
//
//
// Created by neng on 14-6-19.
// Copyright (c) 2014年 neng. All rights reserved.
//#import "XNTabBarController.h"
#import "Common.h"
#import "XNTabBarButton.h"@interface
/** - * 设置之前选中的按钮
- */
@propertynonatomicUIButton
@end@implementation
void
super]; - // NSLog(@"%s",__func__);
// NSLog(@"%@",self.view.subviews); //能打印出所有子视图,和其frameself);
- self.frame
self removeFromSuperview - UIView]];
- = rect;
- = [UIColor];
- self addSubview
forint; i < ; i++) {
- XNTabBarButton]];
- NSString:, i +];
- NSString:, i +];
- :[UIImage:imageName]:UIControlStateNormal];
- :[UIImage:imageNameSel]:UIControlStateSelected];
- i.size / ;
- = CGRectMake(x, , myView.size / , myView.size);
- :btn];
- = i;
- :self:@selector forControlEvents
- if == i) {
- = YES
self = btn; - /**
- * 自定义TabBar的按钮点击事件
- */
voidUIButton - self.selectedNO
- = YES
- self = button;
- self = button;
- @end
XNTabBarButton.h
- #import <UIKit/UIKit.h>
@interface
@end
XNTabBarButton.m
- #import "XNTabBarButton.h"
@implementation
/**什么也不做就可以取消系统按钮的高亮状态*/
voidBOOL
// [super setHighlighted:highlighted];@end
五、代码重构
(hidebottombaronpush)
XNTabBar.h
- #import <UIKit/UIKit.h>
@class@protocol
/** - * 工具栏按钮被选中, 记录从哪里跳转到哪里. (方便以后做相应特效)
- */
void tabBarXNTabBar:(NSInteger) from:(NSInteger)to; - @end
@interface
@propertynonatomicid
/** - * 使用特定图片来创建按钮, 这样做的好处就是可扩展性. 拿到别的项目里面去也能换图片直接用
- *
- * @param image 普通状态下的图片
- * @param selectedImage 选中状态下的图片
- */
voidUIImage:(UIImage
@end
XNTabBar.m
- //
// XNTabBar.m
//
// Created by neng on 14-6-19.
// Copyright (c) 2014年 neng. All rights reserved.
//#import "XNTabBar.h"
#import "XNTabBarButton.h"@interface
/** - * 设置之前选中的按钮
- */
@propertynonatomicUIButton
@end@implementation
/**
- * 在这个方法里写控件初始化的东西, 调用init方法时会调用
- */
//- (id)initWithFrame:(CGRect)frame {
// if (self = [super initWithFrame:frame]) {
// //添加按钮
// for (int i = 0; i < 5; i++) { //取消掉特定的数字
// //UIButton *btn = [[UIButton alloc] init];
// XNTabBarButton *btn = [[XNTabBarButton alloc] init];
//
// NSString *imageName = [NSString stringWithFormat:@"TabBar%d", i + 1];
// NSString *imageNameSel = [NSString stringWithFormat:@"TabBar%dSel", i + 1];
//
// [btn setImage:[UIImage imageNamed:imageName] forState:UIControlStateNormal];
// [btn setImage:[UIImage imageNamed:imageNameSel] forState:UIControlStateSelected];
//
// [self addSubview:btn];
//
// btn.tag = i; //设置按钮的标记, 方便来索引当前的按钮,并跳转到相应的视图
//
// //带参数的监听方法记得加"冒号"
// [btn addTarget:self action:@selector(clickBtn:) forControlEvents:UIControlEventTouchUpInside];
//
// if (0 == i) {
// [self clickBtn:btn];
// }
// }
// }
// return self;
//}voidUIImage:(UIImage
UIButton]]; - :image:UIControlStateNormal];
- :selectedImage:UIControlStateSelected];
- self:btn];
- :self:@selector forControlEvents
- ifself.count) {
- self:btn];
- /**专门用来布局子视图, 别忘了调用super方法*/
void
super]; - intself.count
forint; i < count; i++) { - UIButtonself[i];
- = i;
- iself.size / count;
- ;
- self.size / count;
- self.size;
- = CGRectMake(x, y, width, height);
- /**
- * 自定义TabBar的按钮点击事件
- */
voidUIButton - self.selectedNO
- = YES
- self = button;
- ifself respondsToSelector@selector
self tabBarself:self.tag:button]; - @end
原先的XNTabBarController.m经过修改后,注释了原先的代码。
- //
// XNTabBarController.m
//
// Created by neng on 14-6-19.
// Copyright (c) 2014年 neng. All rights reserved.
//#import "XNTabBarController.h"
#import "XNTabBarButton.h"
#import "XNTabBar.h"@interface
/** - * 设置之前选中的按钮
- */
@propertynonatomicUIButton
@end@implementation
void
super]; - // NSLog(@"%s",__func__);
// NSLog(@"%@",self.view.subviews); //能打印出所有子视图,和其frame
// LogFun;
// LogSubviews(self.view); - self.bounds
- self);
- XNTabBar]];
- = self
- = rect;
- self addSubview
- forint; i<self.count
- NSString:, i +];
- NSString:, i +];
- UIImage:imageName];
- UIImage:imageNameSel];
- :image:imageSel];
- // //添加按钮
// for (int i = 0; i < 5; i++) {
// //UIButton *btn = [[UIButton alloc] init];
// XNTabBarButton *btn = [[XNTabBarButton alloc] init];
//
// NSString *imageName = [NSString stringWithFormat:@"TabBar%d", i + 1];
// NSString *imageNameSel = [NSString stringWithFormat:@"TabBar%dSel", i + 1];
//
// [btn setImage:[UIImage imageNamed:imageName] forState:UIControlStateNormal];
// [btn setImage:[UIImage imageNamed:imageNameSel] forState:UIControlStateSelected];
//
// CGFloat x = i * myView.frame.size.width / 5;
// btn.frame = CGRectMake(x, 0, myView.frame.size.width / 5, myView.frame.size.height);
//
// [myView addSubview:btn];
//
// btn.tag = i;//设置按钮的标记, 方便来索引当前的按钮,并跳转到相应的视图
//
// //带参数的监听方法记得加"冒号"
// [btn addTarget:self action:@selector(clickBtn:) forControlEvents:UIControlEventTouchUpInside];
//
// //设置刚进入时,第一个按钮为选中状态
// if (0 == i) {
// btn.selected = YES;
// self.selectedBtn = btn; //设置该按钮为选中的按钮
// }
// }/**永远别忘记设置代理*/
voidXNTabBar:(NSInteger)from:(NSInteger)to { - self = to;
- /**
- * 自定义TabBar的按钮点击事件
- */
//- (void)clickBtn:(UIButton *)button {
// //1.先将之前选中的按钮设置为未选中
// self.selectedBtn.selected = NO;
// //2.再将当前按钮设置为选中
// button.selected = YES;
// //3.最后把当前按钮赋值为之前选中的按钮
// self.selectedBtn = button;
//
// //4.跳转到相应的视图控制器. (通过selectIndex参数来设置选中了那个控制器)
// self.selectedIndex = button.tag;
//}@end
自定义后的效果图:
例子源码下载 :http://download.csdn.net/detail/xn4545945/7572263
转载请注明出处:http://blog.csdn.net/xn4545945
iOS 自定义TabBarController的更多相关文章
- iOS 自定义tabBarController(中间弧形)
效果图 1.在继承自UITabBarController的自定义controller中调用以下方法(LZCustomTabbar为自定义的tabbar) - (void)viewDidAppear:( ...
- 【iOS自定义键盘及键盘切换】详解
[iOS自定义键盘]详解 实现效果展示: 一.实现的协议方法代码 #import <UIKit/UIKit.h> //创建自定义键盘协议 @protocol XFG_KeyBoardDel ...
- iOS自定义的UISwitch按钮
UISwitch开关控件 开关代替了点选框.开关是到目前为止用起来最简单的控件,不过仍然可以作一定程度的定制化. 一.创建 UISwitch* mySwitch = [[ UISwitchalloc] ...
- 如何实现 iOS 自定义状态栏
给大家介绍如何实现 iOS 自定义状态栏 Sample Code: 01 UIWindow * statusWindow = [[UIWindow alloc] initWithFrame:[UIAp ...
- iOS自定义组与组之间的距离以及视图
iOS自定义组与组之间的距离以及视图 //头视图高度 - (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(N ...
- iOS 自定义转场动画
代码地址如下:http://www.demodashi.com/demo/12955.html 一.总效果 本文记录分享下自定义转场动画的实现方法,具体到动画效果:新浪微博图集浏览转场效果.手势过渡动 ...
- iOS 自定义转场动画浅谈
代码地址如下:http://www.demodashi.com/demo/11612.html 路漫漫其修远兮,吾将上下而求索 前记 想研究自定义转场动画很久了,时间就像海绵,挤一挤还是有的,花了差不 ...
- iOS自定义转场动画实战讲解
iOS自定义转场动画实战讲解 转场动画这事,说简单也简单,可以通过presentViewController:animated:completion:和dismissViewControllerA ...
- iOS 实现Tabbarcontroller中间自定义样式 最简单的方法
先上图: 如果我们要实现中间按钮自定义样式,方法应该蛮多,这里介绍一种最简单的. 1.创建类继承:UITabBarController,如下代码都是写在该类的 .m文件里 2.定义最中间的自定义样式, ...
随机推荐
- IntelliJ IDEA 中设置左菜单字体, 编辑器字体和控制台的字体
IntelliJ IDEA 中设置左菜单字体大小 File-Settings,然后选择appearance,下图右侧红色边框中的内容即设置菜单的字体和大小 IntelliJ IDEA 中设置当前编 ...
- python机器学习——使用scikit-learn训练感知机模型
这一篇我们将开始使用scikit-learn的API来实现模型并进行训练,这个包大大方便了我们的学习过程,其中包含了对常用算法的实现,并进行高度优化,以及含有数据预处理.调参和模型评估的很多方法. 我 ...
- python中的集合、元组和布尔
#元组,元组跟列表一样,只不过列表可读可写,而元组一般用来只读,不修改#python中不允许修改元组的数据,也包括不能删除其中的元素. t1 = ('a','b','c','d','s','a') & ...
- Eclipse中修改tomcat的部署路径deploypath
在eclipse上面部署web项目后,它没有将你的项目文件放到tomcat 的目录下面.而是放在了你的工作目录下面. 在tomcat上右键选择“stop” .停止eclipse内的Tomcat服务器 ...
- T-SQL Part X: UNION, EXCEPT and INTERSECT
MSDN上关于EXCEPT和INTERSECT的文档.MSDN上关于UNION的文档. 值得注意的是,UNION其实有两种,一种是普通的UNION,另外一种是UNION ALL.加上EXCEPT和IN ...
- PHP 核心特性 - 匿名函数
提出 在匿名函数出现之前,所有的函数都需要先命名才能使用 function increment($value) { return $value + 1; } array_map('increment' ...
- 分组取topN
假设有这样一个文件,文件内容如下 class1 class2 class1 class1 class2 class2 class1 class2 class1 class2 要求按照班级分组取出每个班 ...
- (二)初识NumPy库(数组的操作和运算)
本章主要介绍的是ndarray数组的操作和运算! 一. ndarray数组的操作: 操作是指对数组的索引和切片.索引是指获取数组中特定位置元素的过程:切片是指获取数组中元素子集的过程. 1.一维数组的 ...
- JVM浅谈
**前言** 由于先前也遇到过一些性能问题,OOM算是其中的一大类了.因此也对jvm产生了一些兴趣.自己对jvm略做了些研究.后续继续补充. **从oom引申出去** 既然说到oom,首先需要知道oo ...
- 接口测试之-postman
在使用postman进行接口测试的时候,对于有些接口字段需要时间戳加密,这个时候我们就遇到2个问题,其一是接口中的时间戳如何得到?其二就是对于现在常用的md5加密操作如何在postman中使用代码实现 ...