打造一款灵活的导航栏

栏目: IOS · 发布时间: 5年前

内容简介:前言:项目中经常会遇到功能样式各种各样的导航栏,使用系统的也能达到需求,但是改动方面比较麻烦,特别是对于改动的时机把控问题较多,所以很多情况下都是隐藏系统的导航栏,自定义一个view区代替导航栏,导航栏的样式无非以下几种:文字,图片,与图文混合,这几种的组合那么如何打造一款适用的导航栏呢?笔者在项目中的需求,导航栏风格迥异,还牵扯到一些控件的渐变和隐藏效果,下面就来具体讲解下封装的过程。

前言:项目中经常会遇到功能样式各种各样的导航栏,使用系统的也能达到需求,但是改动方面比较麻烦,特别是对于改动的时机把控问题较多,所以很多情况下都是隐藏系统的导航栏,自定义一个view区代替导航栏,导航栏的样式无非以下几种:

文字,图片,与图文混合,这几种的组合

那么如何打造一款适用的导航栏呢?笔者在项目中的需求,导航栏风格迥异,还牵扯到一些控件的渐变和隐藏效果,下面就来具体讲解下封装的过程。

笔者想到的封装结构如下图所示:

打造一款灵活的导航栏
打造一款灵活的导航栏
打造一款灵活的导航栏

总体设计如上图所示, LWNavigationBarItem 主要是对单体 item 的相关设置,包括item样式,文字,图片和其相关样式的定制等 LWNavigationBar 是承载 LWNavigationBarItem 的容器,对外提供增加,修改相关 item 的接口,内部实现对 item 的布局,下面我截取相关样式的图片:

1.标题渐变

打造一款灵活的导航栏
打造一款灵活的导航栏
打造一款灵活的导航栏

2.带下划线的item

打造一款灵活的导航栏

3.动态修改item的隐藏显示和内容

打造一款灵活的导航栏
打造一款灵活的导航栏
打造一款灵活的导航栏

还有其他组合这里就不一一列举,可以自行下载尝试

4.使用方面

这层封装仅仅是对导航栏的定制进行设置的,如果想要和业务结合,生成不同的导航栏,最好进行二次封装一次,我这里仅仅截取一个二次封装的方法,如下:

/*左右皆为图片,中间标题为文字,图片文字皆可为空
 */
+ (LWNavigationBar *)yg_createNavigationBarWithBarStyle:(YGNavigationBarStyle)style
                                              target:(UIViewController *)target
                                              leftImage:(UIImage * _Nullable)leftImage
                                              titleText:(NSString * _Nullable )titleText
                                             rightImage:(UIImage * _Nullable )rightImage
                                              barHeight:(CGFloat)barHeight {
    
    LWNavigationBarItem *leftItem = [[LWNavigationBarItem alloc] initWithItemType:LWNavigationBarItemOnlyImage];
    [leftItem setItemImage:leftImage];
    [leftItem setItemImageSize:CGSizeMake(20 * kXX, 20 * kXX)];
    if ([target respondsToSelector:@selector(p_didClickLeftItemAction)]) {
        [leftItem addTarget:target action:@selector(p_didClickLeftItemAction) forControlEvents:UIControlEventTouchUpInside];
    }
    
    LWNavigationBarItem *rightItem = [[LWNavigationBarItem alloc] initWithItemType:LWNavigationBarItemOnlyImage];
    [rightItem setItemImage:rightImage];
    [rightItem setItemImageSize:CGSizeMake(20 * kXX, 20 * kXX)];
    if ([target respondsToSelector:@selector(p_didClickRightItemAction)]) {
        [rightItem addTarget:target action:@selector(p_didClickRightItemAction) forControlEvents:UIControlEventTouchUpInside];
    }
    
    LWNavigationBarItem *titleItem = [[LWNavigationBarItem alloc] initWithItemType:LWNavigationBarItemOnlyText];
    [titleItem setItemTitleColor:(style == YGNavigationBarStyleDefault ? [UIColor convertHexValueToColor:@"#2f2f2f"] : [UIColor whiteColor])];
    [titleItem setItemTitle:titleText];
    [titleItem setItemTitleFont:[UIFont fifteenOfSystem]];
    
    LWNavigationBar *bar = [[LWNavigationBar alloc] init];
    bar.backgroundColor = (style == YGNavigationBarStyleDefault ? [UIColor whiteColor] : [UIColor createNavigationColor]);
    [bar setBarContentInset:15 * kXX];
    [bar addItemToTitle:titleItem];
    [bar addItemToRight:rightItem];
    [bar addItemToLeft:leftItem];
    [bar setItemLineViewColor:YGViews_RGBA(182, 182, 182, 1.0)];
    bar.frame = CGRectMake(0, 0, kScreenW, barHeight);
    [bar reloadItems];
    [target.view addSubview:bar];
    return bar;
}
复制代码

总体而言,这些已经能满足大多数需求,这里我附上 Github链接 ,如果感兴趣,可以通过上述传送门下载看一下,此外, LWNavigationBar 也支持pod,使用方式 pod 'LWNavigationBar' 即可,如果觉得满足你的需求,还望不吝一颗:sparkles: ,谢谢


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Linux内核设计的艺术

Linux内核设计的艺术

新设计团队 / 机械工业出版社华章公司 / 2011-6-20 / 79.00元

关于Linux内核的书已经不计其数,但这本书却是独树一帜的,它的内容代表着Linux内核研究成果的世界顶尖级水平,它在世界范围内首次提出并阐述了操作系统设计的核心指导思想——主奴机制,这是所有操作系统研究者的一笔宝贵财富。本书可能也代表着同类图书的顶尖水平,是一本真正能引导我们较为容易地、极为透彻地理解Linux内核的经典之作,也可能是当前唯一能从本质上指引我们去设计和开发拥有自主知识产权的操作系......一起来看看 《Linux内核设计的艺术》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

URL 编码/解码
URL 编码/解码

URL 编码/解码

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具