iOS11 导航栏UIBarButtonItem自定义按钮偏移问题

前言

最近iOS11 发放出来已经有一段时间了,不得不说每到9月,都是果粉兴奋,iOS代码狗抓狂的时候。。。。
iOS 11 放出来,于是各种各样的坑也就跟预留好了。。。
其中一个比较烦人的坑就是导航栏UIBarButtonItem自定义按钮偏移 在iOS11 系统下 通过以前的UIBarButtonSystemItemFixedSpace的方式已经无法修复了。。。。。
所以我们也是尝试了各种方法去填iOS11给我们挖的坑。。。

iOS11 和iOS11效果图如下:(响应范围可以自己亲测调试)

**左边是iOS11 5S, 右边是iOS10 SE**

目前网上比较流行的方法

方法一:iOS11 导航栏按钮位置问题的解决

作者:spicyShrimp
http://blog.csdn.net/spicyShrimp/article/details/77891717
附上地址,大家可以去看一下,利用各种黑魔法解决了这个bug,不论是修复点击范围,还是视图布局都做到了完美解决,但问题就是这个方案的代价比较大。

方法一:iOS11导航栏自定义按钮偏移问题

作者:可可西里的藏野驴
http://blog.csdn.net/guo4114/article/details/78053025
这个方法只是解决了视图问题,但还有一个实质问题尚未解决,就是返回按键的点击位置依旧没有改变,大家可以试一试。

我的方法

具体思路是: 先修改button 的视图布局,再修改button 的响应范围。

第一步:适配系统,iOS11 系统以下,依旧保持不变

 UIButton *backButton = [[UIButton alloc]initWithFrame:CGRectMake(0, 0, 40, 40)];
    [backButton setNormalImage:[UIImage imageNamed:@"mine_back_cheng"]];
    [backButton setHighlightedImage:[UIImage imageNamed:@"mine_back_white"]];
    [backButton addClickEventWithBlock:clickHandler];
    UIBarButtonItem *backItem = [[UIBarButtonItem alloc]initWithCustomView:backButton];
    //配置返回按钮距离屏幕边缘的距离
    UIBarButtonItem *spaceItem = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:nil action:nil];
    spaceItem.width = -10.0f;
    self.navigationItem.leftBarButtonItems = @[spaceItem,backItem];

第二步:iOS11 系统下,修改UI布局

依旧在上面的代码进行系统区分,修改布局

 UIButton *backButton = [[UIButton alloc]initWithFrame:CGRectMake(0, 0, 40, 40)];
    [backButton setNormalImage:[UIImage imageNamed:@"mine_back_cheng"]];
    [backButton setHighlightedImage:[UIImage imageNamed:@"mine_back_white"]];
    [backButton addClickEventWithBlock:clickHandler];
    UIBarButtonItem *backItem = [[UIBarButtonItem alloc]initWithCustomView:backButton];
    //配置返回按钮距离屏幕边缘的距离
    UIBarButtonItem *spaceItem = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:nil action:nil];
    spaceItem.width = -10.0f;
// iOS 11 系统,将Button的内容 和 图片根具体需求进行便处理
if (([[[UIDevice currentDevice] systemVersion] floatValue] >= 11.0)) {
        backButton.contentEdgeInsets =UIEdgeInsetsMake(0, -15,0, 0);
        backButton.imageEdgeInsets =UIEdgeInsetsMake(0, -15,0, 0);
    }
    self.navigationItem.leftBarButtonItems = @[spaceItem,backItem];

第三步:修改布局之后,修改UIBarButtonItem 的响应范围。

        backButton.contentEdgeInsets =UIEdgeInsetsMake(0, -15,0, 0);
        backButton.imageEdgeInsets =UIEdgeInsetsMake(0, -15,0, 0);

只是修改了 返回Button 的视图,没有对返回Button的实际响应范围进行修改。所以下面的实际修改范围 需要加入这个一段代码,来修改button的响应范围。

       // 修改返回**Button**的响应范围 ,往左边扩大6 个胆怯
        backButton.hitEdgeInsets =UIEdgeInsetsMake(0, -6, 0, 0);

WHAT?? hitEdgeInsets button 有这个东西吗???

确实没有。这个只是我们给UIButton利用分类Category,添加的一个属性,来修改button 的响应范围。
具体代码和方式参考:
UIButton 扩大按钮的响应区域(runtime)


最终代码:

由于修改的东西不多,我这里就把代码贴出来就好了:

- (void)viewDidLoad {
    [super viewDidLoad];
    self.title = @"注册";
    kDefineWeakSelf;
    [self showCustomLeftImgBarButton:^(UIButton *button) {
        [weakSelf.navigationController popViewControllerAnimated:YES];
    }];
    // Do any additional setup after loading the view.
}

-(void)showCustomLeftImgBarButton:(void (^)(UIButton *button))clickHandler{
    UIButton *backButton = [[UIButton alloc]initWithFrame:CGRectMake(0, 0, 40, 40)];
    [backButton setNormalImage:[UIImage imageNamed:@"mine_back_cheng"]];
    [backButton setHighlightedImage:[UIImage imageNamed:@"mine_back_white"]];
    [backButton addClickEventWithBlock:clickHandler];
    UIBarButtonItem *backItem = [[UIBarButtonItem alloc]initWithCustomView:backButton];
    //配置返回按钮距离屏幕边缘的距离
    UIBarButtonItem *spaceItem = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:nil action:nil];
    spaceItem.width =  kIOS11_OR_LATER? 0:fixSpacing;
    if (kIOS11_OR_LATER) {
        backButton.contentEdgeInsets =UIEdgeInsetsMake(0, -15,0, 0);
        backButton.imageEdgeInsets =UIEdgeInsetsMake(0, -15,0, 0);
        backButton.hitEdgeInsets =UIEdgeInsetsMake(0, -6, 0, 0);
    }
    self.navigationItem.leftBarButtonItems = @[spaceItem,backItem];
}

UIButton利用分类Category,添加的一个属性,来修改button 的响应范围。
具体代码和方式参考:
UIButton 扩大按钮的响应区域(runtime)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容