ios 自定义带下划线的tab切换按钮
2017-04-30 17:51
295 查看
1. 创建2个tab栏切换的TabBar
//清除顶部的tabBar UI上的数据
- (void)clearTopTabBarSegment
{ //先将顶部的View移除掉,再去添加
UIButton *ljBtn = (UIButton*)[self.view viewWithTag:9999];
if (ljBtn) { [ljBtn removeFromSuperview]; }
UIButton *ljBtn1 = (UIButton*)[self.view viewWithTag:10000];
if (ljBtn1) { [ljBtn1 removeFromSuperview]; }
if(_segmentLineView) { [_segmentLineView removeFromSuperview]; _segmentLineView = nil; }}
2. 当从第一个页面里面的某一个button切换到第二个tab时,可以这样处理
#pragma mark -- 创建顶部Tab切换按钮 - (void)createTopTabBarSegment { if(!_segmentLineView) { _segmentLineView = [[UIView alloc] initWithFrame:CGRectMake((kDEVICEWIDTH - TOPTABBARWIDTH*2 - 35)/2.0, 20+38, TOPTABBARWIDTH, 2)]; _segmentLineView.backgroundColor = loadColor(@"0093ff"); [self.view addSubview:_segmentLineView]; } //多少个tab for (NSInteger i = 0; i < _segmentTitleArray.count; i++) { UIButton * segmentButton = [UIButton buttonWithType:UIButtonTypeCustom]; segmentButton.frame = CGRectMake((kDEVICEWIDTH - TOPTABBARWIDTH*2 - 35)/2.0 + TOPTABBARWIDTH*i, 20, TOPTABBARWIDTH, 40); segmentButton.tag = 9999 + i; [segmentButton setTitle:[_segmentTitleArray objectAtIndex:i] forState:UIControlStateNormal]; [segmentButton setTitle:[_segmentTitleArray objectAtIndex:i] forState:UIControlStateSelected]; [segmentButton setTitleColor:TFCOLOR_68758E forState:UIControlStateNormal]; [segmentButton setTitleColor:loadColor(@"0093ff") forState:UIControlStateSelected]; segmentButton.titleLabel.font = loadFont(18.f); [segmentButton addTarget:self action:@selector(didTopTabSelectClick:) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:segmentButton]; if (i == 0)//默认选中第一个tab { _selectedTabBtn = segmentButton; [segmentButton setSelected:YES]; } } } #pragma mark -- 顶部tab选择事件 - (void)didTopTabSelectClick:(UIButton*)sender { _segmentLineView.frame = CGRectMake((kDEVICEWIDTH - TOPTABBARWIDTH*2 - 35)/2.0 + TOPTABBARWIDTH * (sender.tag - 9999), 20+38, TOPTABBARWIDTH, 2); _selectedTabBtn.selected = !_selectedTabBtn.selected; sender.selected = !sender.selected; _selectedTabBtn = sender; if (sender.tag == 9999) { self.currentSelectedTabIndex = 0; } else if (sender.tag == 10000) {
self.currentSelectedTabIndex = 1;}}
//清除顶部的tabBar UI上的数据
- (void)clearTopTabBarSegment
{ //先将顶部的View移除掉,再去添加
UIButton *ljBtn = (UIButton*)[self.view viewWithTag:9999];
if (ljBtn) { [ljBtn removeFromSuperview]; }
UIButton *ljBtn1 = (UIButton*)[self.view viewWithTag:10000];
if (ljBtn1) { [ljBtn1 removeFromSuperview]; }
if(_segmentLineView) { [_segmentLineView removeFromSuperview]; _segmentLineView = nil; }}
2. 当从第一个页面里面的某一个button切换到第二个tab时,可以这样处理
#pragma mark -- 查看按钮点击 - (void)aroundClicked { CHDebugLog(@"%s",__FUNCTION__); if (_selectedTabBtn.tag == 9999) { if ([self respondsToSelector:@selector(didTopTabSelectClick:)]) { UIButton *ljBtn1 = (UIButton*)[self.view viewWithTag:10000];//将当前页面里面的第二个tab找到传过去 [self performSelector:@selector(didTopTabSelectClick:) withObject:ljBtn1]; } } }
相关文章推荐
- Android自定义控件2:自定义带下划线的文本或按钮、组合使用可切换tab
- 自定义可滑动的tab选项卡,可切换选项卡样式(下划线,仿小米三角形,方形背景)
- iOS 自定义tabtabbar 中间按钮凸起
- iOS自定义Tab按钮去掉按下效果
- IOS 自定义Tab切换 模仿网易新闻频道切换
- IOS学习之Tab Bar的使用和视图切换
- IOS学习之Tab Bar的使用和视图切换
- iOS创建不带nib文件的工程之四--在自定义view上添加按钮
- iOS中创建自定义的圆角按钮
- IOS 入门开发之导航栏按钮切换(三)
- 为数字键盘添加自定义按钮的方法(iOS所有版本适用
- IOS 入门开发之导航栏按钮切换(三)
- IOS学习之Tab Bar的使用和视图切换
- 激活对话框中 tab 键蓝色按钮切换
- Ios使用按钮自定义segmentcontrol
- iOS学习之Tab Bar的使用和视图切换
- 设置导航栏Edit 、自定义按钮 获取当前活动的Tab索引和UIViewController
- [iOS]一种可以让UINavigationBar在自定义背景和系统背景切换的办法
- IOS开发之UIButton同时设置图片文字以及出发按钮时文字图片的切换
- iOS-自定义单选复选按钮