新浪微博客户端(2)-自定义导航控制器,统一NavigationItem

本文介绍如何通过继承UINavigationController并重写pushViewController方法来自定义导航栏按钮。实现包括自定义左上角返回按钮及右上角首页按钮,并展示了最终效果。

 

继承系统提供的UINavigationViewController,拦截并重写其push方法。

#import "DJNavigationController.h"

@implementation DJNavigationController




- (void)pushViewController:(UIViewController *)viewController animated:(BOOL)animated {

    
    
    if (self.viewControllers.count > 0) {
        
        // 自定义左上角按钮
        UIButton *backBtn = [UIButton buttonWithType:UIButtonTypeCustom];
        [backBtn setBackgroundImage:[UIImage imageNamed:@"navigationbar_back"] forState:UIControlStateNormal];
        [backBtn setBackgroundImage:[UIImage imageNamed:@"navigationbar_back_highlighted"] forState:UIControlStateHighlighted];
        backBtn.size = backBtn.currentBackgroundImage.size;
        [backBtn addTarget:self action:@selector(back) forControlEvents:UIControlEventTouchUpInside];
        
        
        UIBarButtonItem *leftItem = [[UIBarButtonItem alloc] initWithCustomView:backBtn];
        viewController.navigationItem.leftBarButtonItem = leftItem;
        
        // 自定义右上角按钮
        UIButton *homeBtn = [UIButton buttonWithType:UIButtonTypeCustom];
        [homeBtn setBackgroundImage:[UIImage imageNamed:@"navigationbar_more"] forState:UIControlStateNormal];
        [homeBtn setBackgroundImage:[UIImage imageNamed:@"navigationbar_more_highlighted"] forState:UIControlStateHighlighted];
        homeBtn.size = homeBtn.currentBackgroundImage.size;
        [homeBtn addTarget:self action:@selector(home) forControlEvents:UIControlEventTouchUpInside];
        
        UIBarButtonItem *rightItem = [[UIBarButtonItem alloc] initWithCustomView:homeBtn];
        viewController.navigationItem.rightBarButtonItem = rightItem;
        
        viewController.hidesBottomBarWhenPushed = YES;
        
    }
    
    
    [super pushViewController:viewController animated:animated];
}



// 弹出当前控制器
- (void)back {
    
    [self popViewControllerAnimated:YES];
    
}


// 弹出到根控制器
- (void)home {

    [self popToRootViewControllerAnimated:YES];

}



@end

 

最终效果:

 

 

转载于:https://www.cnblogs.com/yongdaimi/p/5958275.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值