iOS 导航栏自定义返回按钮

本文介绍如何在iOS应用中自定义导航栏的返回按钮,包括全局设置、单独设置和继承导航栏的方法,以及如何调整按钮的位置。


方法一:
// 缺陷是图片显示成纯色的
// 设置全局导航栏返回按钮指示图
UINavigationBar *navBar = [UINavigationBar appearance];
UIImage *image = [UIImage imageNamed:@"back"];
//以下两个必须同时设置
navBar.backIndicatorImage = image;
navBar.backIndicatorTransitionMaskImage = image;

//在viewController里面将backItem的title设成"", 主要作用是没有显示内容
UIBarButtonItem *backItem = [[UIBarButtonItem alloc] init];
backItem.title = @"";
self.navigationItem.backBarButtonItem = backItem;

方法二:
// 缺陷是向左滑动时不能作为返回操作使用
// 设置viewController的 leftBarButtonItem
UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom];
UIImage *backImage = [UIImage imageNamed:@"back"];
[btn setImage:backImage forState:UIControlStateNormal];
[btn addTarget:self action:@selector(btnBackClick) forControlEvents:UIControlEventTouchUpInside];
self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc] initWithCustomView:btn];

//以上方法,返回按钮不太靠边,可以使用重写以下方法达到效果
//.h文件
@interface UINavigationItem (DM)

@end

//.m文件
@implementation UINavigationItem (DM)

- (void)setLeftBarButtonItem:(UIBarButtonItem *)leftBarButtonItem
{
    if (iOS7UP && leftBarButtonItem.customView)
    {
        UIBarButtonItem *negativeSeperator = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:nil action:nil];
        
        negativeSeperator.width = -7.0;//此处修改到边界的距离
        
        if (leftBarButtonItem) 
        {
            [self setLeftBarButtonItems:@[negativeSeperator, leftBarButtonItem]];
        } 
        else 
        {
            [self setLeftBarButtonItems:@[negativeSeperator]];
        }
    } 
    else 
    {
        [self setLeftBarButtonItem:leftBarButtonItem animated:NO];
    }
}

- (void)setRightBarButtonItem:(UIBarButtonItem *)rightBarButtonItem
{
    if (iOS7UP && rightBarButtonItem.customView) 
    {
        UIBarButtonItem *negativeSeperator = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:nil action:nil];
        negativeSeperator.width = -7.0;//此处修改到边界的距离
        if (rightBarButtonItem) 
        {
            [self setRightBarButtonItems:@[negativeSeperator, rightBarButtonItem]];
        } 
        else 
        {
            [self setRightBarButtonItems:@[negativeSeperator]];
        }
    } 
    else 
    {
        [self setRightBarButtonItem:rightBarButtonItem animated:NO];
    }
}

@end

方法三:
// 继承导航栏,将导航栏隐藏,自定义导航栏





iOS 自定义导航栏返回按钮通常用于 UINavigationController 的场景中,当你想要改变标准的系统 UINavigationBar 中的“Back”箭头样式或添加额外的功能时。你可以通过以下步骤来实现自定义: 1. 首先,在需要定制导航栏的 UIViewController 上遵守 `UINavigationControllerDelegate` 和 `UIViewControllerTransitioningDelegate` 协议。 ```swift class YourViewController: UIViewController, UINavigationControllerDelegate, UIViewControllerTransitioningDelegate { ``` 2. 在 Interface Builder 或 Storyboard 中设置该视图控制器为当前的根视图控制器,并给 navigation controller 设置代理。 3. 创建一个新的 UIButton 作为返回按钮,然后将其添加到自定义视图或者 UIView 中,如 UIButton 或 UIImageView,然后将其设置为 UIBarButtonItem。 ```swift let customButton = UIButton(type:.system) let backBarButtonItem = UIBarButtonItem(customView: customButton) navigationItem.backBarButtonItem = backBarButtonItem ``` 4. 对于自定义按钮的行为,可以在 `backBarButtonItem` 的代理方法里处理,例如点击事件、显示动画等。 ```swift override func viewDidLoad() { super.viewDidLoad() customButton.addTarget(self, action: #selector(buttonTapped), for: .touchUpInside) } @objc private func buttonTapped() { // 这里可以编写你要自定义返回操作逻辑 } ``` 5. 如果你想让返回按钮支持手势或动态变化,可以创建一个自定义的 UIBarButtonItem 实现或使用第三方库,如 Swifty Navigation Bar 控件。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值