设置Nav自定义返回按钮一个有趣的bug

需求

项目中需要用到一个只有返回图片的返回按钮

bug演示

录屏.gif

说明:这个bug其实之前就已经存在了,只是现在得到了领导的重视.各种调试,搞了一上午才找到问题所在.
记录一下顺便提供实现自定义返回按钮的方法.

1.网上搜罗的一个方法,也是造成这个bug的主要原因:

项目一般会重写一个继承UINavigationController的导航控制器 ,然后实现两个方法:

+ (void)initialize{
    UIImage *backButtonImage = [UIImage imageNamed:@"back_normal"];//返回按钮的图片
    
    [[UIBarButtonItem appearance] setBackButtonBackgroundImage:backButtonImage forState:UIControlStateNormal barMetrics:UIBarMetricsDefault];
    
    [[UIBarButtonItem appearance] setBackButtonTitlePositionAdjustment:UIOffsetMake(NSIntegerMin, NSIntegerMin) forBarMetrics:UIBarMetricsDefault];
}

- (BOOL)navigationBar:(UINavigationBar *)navigationBar shouldPushItem:(UINavigationItem *)item{
    
    UIBarButtonItem *back = [[UIBarButtonItem alloc] initWithTitle:@"" style:UIBarButtonItemStylePlain target:nil action:nil];
    
    item.backBarButtonItem = back;
    
    return YES;
    
}

使用以上的方法确实可以实现我们的需求,但是bug 就是最上面gif图中的情况.

原因分析:

主要问题在于这个方法:

[[UIBarButtonItem appearance] setBackButtonTitlePositionAdjustment:UIOffsetMake(NSIntegerMin, NSIntegerMin) forBarMetrics:UIBarMetricsDefault];

NSIntegerMin 是一个负数,而且数量级很大的一个负数.这个其实是搞的返回按钮的title的偏移量,NSIntegerMin = LONG_MIN = -9223372036854775808; 当时提供方法的人写这个值估计是为了保险吧😂😂😂😂😂
参数UIOffset的定义:

typedef struct UIEdgeInsets {
    CGFloat top, left, bottom, right;  // specify amount to inset (positive) for each of the edges. values can be negative to 'outset'
} UIEdgeInsets;//这个我们倒是经常用

typedef struct UIOffset {
    CGFloat horizontal, vertical; // specify amount to offset a position, positive for right or down, negative for left or up 指定的偏移位置  右下是正数 左上是负数.
} UIOffset;

这个方法到底是怎么给我们捣乱的呢? 我把参数写小一点的情况:
比如参数都传-100 或者 100:

[[UIBarButtonItem appearance] setBackButtonTitlePositionAdjustment:UIOffsetMake(100, 100) forBarMetrics:UIBarMetricsDefault];
截图1 ![截图2.png](http://upload-images.jianshu.io/upload_images/3284263-917eaf328ec43bc8.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240) .png

后台列表所显示的视图应该不是当前viewController的view直接显示,而是经过系统内部处理过的(具体怎么处理,技术有限,摊手~),本人试过,偏移量超过-1000 其实就已经会造成gif图中的bug了,

为了不出现gif图中的bug,有两种解决方式
1.不使用NSIntegerMin那么大数量级的负数 用 个-100就行了.
2.不设置title的偏移量 而是在我们的基类控制器的viewDidLoad中实现以下方法.

self.navigationItem.backBarButtonItem =  [[UIBarButtonItem alloc] initWithTitle:@"" style:UIBarButtonItemStylePlain target:nil action:nil];
截图3.png

连title都没有了,清爽😉

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,172评论 25 709
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 11,713评论 0 17
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 14,195评论 4 61
  • 到深夜,心更远;到无声,话更响。 总是独自思着,想不明白就带到梦里去想。 我以为我想的够远了,能想明白, 可我忘了...
    木土有阿杜阅读 3,532评论 1 3
  • 一个人静静看日出,云清云淡,海浪拍打,有何可悔有何可争?日出日落,潮起潮落。日复一日,新更替旧。
    Balalaba阅读 1,794评论 0 0