导航栏左侧或右侧添加多个item

本文介绍了两种在iOS应用中实现自定义导航栏按钮的方法:一是使用系统提供的UIBarButtonItem类;二是通过创建自定义UIView并将其设置为UIBarButtonItem的customView属性来实现更灵活的布局。文章详细展示了如何设置按钮的位置、大小及点击事件。

这里写图片描述

实现左侧或右侧两个item
以实现左侧为例子
一,系统方法实现
此种方法实现后两个按钮间隔很大

    UIBarButtonItem *leftBar=[[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed:@"navSearch"] style:UIBarButtonItemStylePlain target:self action:@selector(navClick1:)];
    UIBarButtonItem *leftBar2=[[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed:@"navEdit"] style:UIBarButtonItemStylePlain target:self action:@selector(navClick2:)];
    [self.navigationItem setRightBarButtonItems:[NSArray arrayWithObjects:leftBar,leftBar2,nil]];

二,我采用的自定义方式实现的

    //创建自定义视图
    UIView *leftBtnView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 60, 40)];
    leftBtnView.backgroundColor = [UIColor clearColor];
    //加载自定义视图
    self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc] initWithCustomView:leftBtnView];

    //后退按钮
    UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom];
    [btn setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];
    btn.titleLabel.font = H_FONT15;
    btn.frame = CGRectMake(0, 10, 20, 20);
    [btn setImage:[UIImage imageNamed:@"returnImage"] forState:UIControlStateNormal];
    [btn addTarget:self action:@selector(navClick1:) forControlEvents:UIControlEventTouchUpInside];
    [leftBtnView addSubview:btn];

    //关闭按钮
    UIButton *btn2 = [UIButton buttonWithType:UIButtonTypeCustom];
    [btn2 setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];
    btn2.titleLabel.font = H_FONT15;
    btn2.frame = CGRectMake(30, 10, 20, 20);
    [btn2 setImage:[UIImage imageNamed:@"closeImage"] forState:UIControlStateNormal];
    [btn2 addTarget:self action:@selector(navClick2:) forControlEvents:UIControlEventTouchUpInside];
    [leftBtnView addSubview:btn2];
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值