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.定义最中间的自定义样式, ...
随机推荐
- Redis 的底层数据结构(压缩列表)
上一篇我们介绍了 redis 中的整数集合这种数据结构的实现,也谈到了,引入这种数据结构的一个很大的原因就是,在某些仅有少量整数元素的集合场景,通过整数集合既可以达到字典的效率,也能使用远少于字典的内 ...
- Scrapy进阶知识点总结(三)——Items与Item Loaders
一.Items 抓取的主要目标是从非结构化源(通常是网页)中提取结构化数据.Scrapy蜘蛛可以像Python一样返回提取的数据.虽然方便和熟悉,但Python缺乏结构:很容易在字段名称中输入拼写错误 ...
- PHP防止客户端多次点击
PHP防止客户端多次点击 第一种用ip判断 第二种就是用 用户名第三种就是cookie仅限 H5第四种 用swoole 用swoole id
- redhat 配置eth0网卡
redhat 找不到eth0等网卡设备 Serenity关注 ...
- jenkins里的定时构建
1. 定时构建语法:* * * * * (五颗星,多个时间点,中间用逗号隔开)第一个*表示分钟,取值0~59第二个*表示小时,取值0~23第三个*表示一个月的第几天,取值1~31第四个*表示第几月,取 ...
- nyoj 458-小光棍数 (471)
458-小光棍数 内存限制:64MB 时间限制:1000ms 特判: No 通过数:6 提交数:6 难度:1 题目描述: 最近Topcoder的XD遇到了一个难题,倘若一个数的三次方的后三位是111, ...
- linux与Windows进程控制
进程管理控制 这里实现的是一个自定义timer用于统计子进程运行的时间.使用方式主要是 timer [-t seconds] command arguments 例如要统计ls的运行时间可以直接输入t ...
- 领扣(LeetCode)删除排序数组中的重复项 个人题解
给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度. 不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成. 示例 1 ...
- 领扣(LeetCode)字符串相加 个人题解
给定两个字符串形式的非负整数 num1 和num2 ,计算它们的和. 注意: num1 和num2 的长度都小于 5100. num1 和num2 都只包含数字 0-9. num1 和num2 都不包 ...
- CentOS7和Ubuntu下安装Docker & Docker-Compose
本篇介绍如何在CentOS 7.6和Ubuntu 16.04下安装Docker & Docker-Compose. CentOS篇 安装Docker # cat /etc/redhat-rel ...