自定义tarBar
使用tarBar大多数情况在我们都是默认的tarBarButton尺寸和位置但是如果我们想,希望像新浪微博那样的tarBar,就需要自定义了。
1、本质上其实就是通过我们的主控制器中以KVC的方式重新构造我们新的tarBar,(http://www.cnblogs.com/daomul/p/4581717.html)
//更换系统的tabBar(KVC的形式,即使是只读的也可以修改)
XBTabBar *tarBar = [[XBTabBar alloc]init];
tarBar.delegate = self;//这个代理主要是针对点击事件的
[self setValue:tarBar forKey:@"tabBar"];
2、重新构造tarBar之后,在initWithFrame里面添加一个按钮到我们的tarBar中,由于重新添加子控件,所以会自动调用layoutSubviews方法。在layoutSubviews方法中我们重新排列对应的子控件的位置和尺寸(这里需要注意的是子控件需要判断是UITarBarButton,其中还有两个其他类型的子控件)
3、对应的按钮的点击事件,在这里点击如果想弹出一个控制器,通过present是不行的,因为只能通过一个控制器去modal一个新的控制器,所以只能采用代理的方式,在调用这个XBTabBar 的时候告诉他有一个点击事件,让他代替我们去点击弹出。顺序是:plusClick ——>tabBarDidClickButton
#pragma mark -- XBTarBarDelegate代理方法(这里是对应的主控制器被调用的方法)
-(void)tabBarDidClickButton:(XBTabBar *)tarBar
{
UIViewController *VC = [[UIViewController alloc]init];
VC.view.backgroundColor = [UIColor redColor];
[self presentViewController:VC animated:YES completion:nil];
}
头文件:
//
// XBTabBar.h
// XibaTest
//
// Created by bos on 15-6-20.
// Copyright (c) 2015年 axiba. All rights reserved.
// #import <UIKit/UIKit.h> @class XBTabBar; //1、因为XBtabBar继承自UITarBar,所以如果想建立自己的代理,也需要实现UITaBar的代理协议UITabBarDelegate
@protocol XBTabBarDelegate <UITabBarDelegate> //2、设置可选的代理方法
@optional
-(void)tabBarDidClickButton:(XBTabBar *)tarBar; @end @interface XBTabBar : UITabBar //3、将协议作为一个属性放出来(代理弱指针)
@property (nonatomic,weak) id<XBTabBarDelegate> delegate; @end
代码文件:
//
// XBTabBar.m
// XibaTest
//
// Created by bos on 15-6-20.
// Copyright (c) 2015年 axiba. All rights reserved.
// #import "XBTabBar.h" @interface XBTabBar()
@property (nonatomic,weak) UIButton *composeBtn;
@end @implementation XBTabBar -(instancetype)initWithFrame:(CGRect)frame
{
self = [super initWithFrame:frame];
if (self) { //添加一个按钮到tabBar中
UIButton *composeBtn = [[UIButton alloc]init];
[composeBtn setBackgroundImage:[UIImage imageNamed:@"tabbar_compose_button"] forState:UIControlStateNormal];
[composeBtn setBackgroundImage:[UIImage imageNamed:@"tabbar_compose_button_highlighted"] forState:UIControlStateHighlighted]; [composeBtn setImage:[UIImage imageNamed:@"tabbar_compose_icon_add"] forState:UIControlStateNormal];
[composeBtn setImage:[UIImage imageNamed:@"tabbar_compose_icon_add_highlighted"] forState:UIControlStateHighlighted];
composeBtn.size = composeBtn.currentBackgroundImage.size;
[composeBtn addTarget:self action:@selector(plusClick) forControlEvents:UIControlEventTouchUpInside];
[self addSubview: composeBtn]; self.composeBtn = composeBtn;
}
return self;
} -(void)plusClick
{
//在这里点击如果想弹出一个控制器,通过present是不行的,因为只能通过一个控制器去modal一个新的控制器
//所以只能采用代理的方式,在调用这个XBTabBar 的时候告诉他有一个点击事件,让他代替我们去点击弹出
XBLog(@""); //先判断是否存在对应的代理方法,然后执行代理的方法
if ([self.delegate respondsToSelector:@selector(tabBarDidClickButton:)])
{
[self.delegate tabBarDidClickButton:self];
}
} -(void)layoutSubviews
{
[super layoutSubviews]; //1、新增加的中间的按钮
self.composeBtn.centerX = self.width *0.5;
self.composeBtn.centerY = self.height *0.5; //2、设置其他tabbarButton的尺寸和位置 CGFloat tabBarButtonW = self.width / ;
CGFloat tabBarButtonIndex = ;
for (UIView *childV in self.subviews)
{
//先判断是不是UITabBarButton的子控件(打印tarBar的子控件会发现还有其他两个子控件)
Class class = NSClassFromString(@"UITabBarButton");
if ([childV isKindOfClass:class]) { //重新设置TabBarButton子控件的宽度和X值(X值根据索引来定位值)
childV.width = tabBarButtonW;
childV.x = tabBarButtonIndex * tabBarButtonW; //增加索引,如果是第三个位置则跳过空一个位置给上面的Button
tabBarButtonIndex++;
if (tabBarButtonIndex == ) {
tabBarButtonIndex++;
}
}
}
} @end
自定义tarBar的更多相关文章
- uniapp 小程序实现自定义底部导航栏(tarbar)
在小程序开发中,默认底部导航栏很难满足实际需求,好在官方给出了自定义形式,效果如下: 话不多说,直接上代码 1.组件 custom-tarbar.vue文件 <template> < ...
- 自定义tabBar
★★★★自定义tabBar★★★★★★★ Demo下载地址:https://github.com/marlonxlj/tabBarCustom.git 前言: 有的时候需求要对tabBar进行自定义的 ...
- ios开发之NavBar和TarBar使用技巧
1 改变NavBar颜色:选中Navigation Bar 的Tint属性.选中颜色. 2 隐藏“back”按钮: self.navigationItem.hidesBackButton = YE ...
- ios NavBar+TarBar技巧
NavBar+TarBar iphone开发 NavBar+TarBar 1 改变NavBar颜色:选中Navigation Bar 的Tint属性.选中颜色. 2 隐藏“back”按钮: sel ...
- QT下自定义QQ聊天窗口tab控件
1.用继承pushbutton派生类来实现tab按钮,里面加一个QPushbutton关闭按钮:(自定义类:CCustomTabButton) 2.多个tab按钮用QHboxLayout做容器: 3. ...
- 小程序学习(冒泡,快速创建文件,以及tarbar)
1.关于小程序的事件冒泡机制 例如: <view catchtap="opp"> <text>当前内容</text> </view> ...
- 【小程序】小程序开发自定义组件的步骤>>>>>>>>>小程序开发过程中报错:jsEnginScriptError
报错:jsEnginScriptError VM6342: jsEnginScriptError Component is not found in path "component/spac ...
- 小程序自定义tabBar,动态控制tabBar
最近做项目的时候,突然来了个小特殊的需求,根据客户的类型来动态显示底部的tabBar菜单.当时我就有点小懵逼了,这个不是小程序自带的组件么?还要做成动态?这就有点尴尬了..... 不过也只是一时尴尬而 ...
- 07vue 自定义全局组件 通用流程
1.全局组件的目录 2.loading/index.js import LoadingComp from './Loaiding' const compName=LoadingComp.name // ...
随机推荐
- C语言界面显示水波纹效果
工具:VS+EasyX +素材图 EasyX首页 - EasyX Library for C++ https://www.easyx.cn/ 下载安装即可.
- 百度云高速下载Pandownload
对于一些文件大小比较小的文件,可以直接在网页分享中点击[下载]来下载: 但是,对于较大点的文件,点击[下载]会弹出百度云的桌面客户端软件来下载: 但但是,下载速度实在是太慢了,强迫症真真等不及啊~ 幸 ...
- 【转载】MongoDB集群和实战详解
1.概述 最近有同学和网友私信我,问我MongoDB方面的问题:这里我整理一篇博客来赘述下MongoDB供大家学习参考,博客的目录内容如下: 基本操作 CRUD MapReduce 本篇文章是基于Mo ...
- JVM垃圾回收机制之引用类型
一:引用的类型 javac编译器编译源文件后,生成字节码文件,在类加载器加载字节码文件到内存中时,在内存中开辟 空间,栈.堆以及方法区,来存放对象以及引用.引用可以分为四种: 强引用:平常我们在编写程 ...
- PHP日期知识
(1)date用法: date(格式,[时间]);如果没有时间参数,则使用当前时间. 格式是一个字符串,其中以下字符有特殊意义:U 替换成从一个起始时间(好象是1970年1月1日)以来的秒数 Y 替换 ...
- js获取图片原始大小
摘要: 浏览器中显示的图片大小未必是他真实的高和宽,比如像下面这样,我们给他加上宽和高的样式 <img src="IE.png" style="width:25px ...
- SQL优化|Java面试题
转载:https://www.cnblogs.com/Jacck/p/8030455.html 数据库的优化问题 一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂 ...
- InsertSql
declare @hobby table(hobbyID int,hName nvarchar(100));insert into @hobby(hobbyID,hName)Select 1,'爬山' ...
- MySQL开发面试题
……继上一篇MySQL的开发总结之后,适当的练习还是很有必要的…… SQL语法多变,不敢保证唯一,也不敢保证全对,如果错误欢迎指出,即刻修改. 一.现有表结构如下图 TABLENAME:afinfo ...
- 【安全开发】C/C++安全编码规范
C本质上是不安全的编程语言.例如如果不谨慎使用的话,其大多数标准的字符串库函数有可能被用来进行缓冲区攻击或者格式字符串攻击.但是,由于其灵活性.快速和相对容易掌握,它是一个广泛使用的编程语言.下面是针 ...