前言:

本文由DevDiv社区@Vincent 原创,转载请注明出处!

http://www.devdiv.com/iOS_iPhone-ios_ios_uibarbuttonitem_-thread-206858-1-1.html

问题引入:

iOS7中导航栏按钮图片会有左右偏移,比如leftBarButtonItem可能会向右偏移10几个像素。

解决办法1:

自定义一个Button,代码如下:

1

@interface BarItemButton : UIButton

2

3

@end

实现如下方法:

01

- (UIEdgeInsets)alignmentRectInsets

02

{

03

UIEdgeInsets insets;

04

if([[[UIDevice currentDevice] systemVersion] floatValue] >= 7.0)

05

{

06

if([self isLeftButton])

07

{

08

insets = UIEdgeInsetsMake(0, 13, 0, 0);

09

}

10

else

11

{

12

insets = UIEdgeInsetsMake(0, 0, 0, 13);

13

}

14

}

15

else

16

{

17

insets = UIEdgeInsetsZero;

18

}

19

20

return
insets;

21

}

22

23

- (BOOL)isLeftButton

24

{

25

return
self.frame.origin.x < (self.superview.frame.size.width / 2);

26

}

然后把这样一个Button作为left button,代码如下:

1

UIButton* btn = [BarItemButton buttonWithType:UIButtonTypeCustom];

2

btn.frame = CGRectMake(0, 0, 45, 40);

3

[btn setImage:[UIImage imageNamed:@"come_back.png"] forState:UIControlStateNormal];

4

[btn addTarget:self action:@selector(handleBack:) forControlEvents:UIControlEventTouchUpInside];

5

self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc] initWithCustomView:btn];

这样可以解决问题,但并不完美,

如果我们我们从一个controller跳转到这样一个controller中:

[self.navigationController pushViewController:[[TestViewController alloc] init] animated:YES];

那么你会发现这个left button位置一开始并不正确,然后通过一个动画移动到我们希望的位置上。

大致效果是这样,controller启动时候有一个明显的动画,蓝色的view在移动,而导航栏上的button也在移动

启动完成后button才回到正确的位置,如下图

而这个动画显然不是我们需要的!

解决办法2:

去掉button的alignmentRectInsets方法实现,

将left button设置代码修改如下:

1

self.view.backgroundColor = [UIColor blueColor];

2

UIButton* btn = [BarItemButton buttonWithType:UIButtonTypeCustom];

3

btn.frame = CGRectMake(0, 0, 45, 40);

4

[btn setImage:[UIImage imageNamed:@"come_back.png"] forState:UIControlStateNormal];

5

btn.imageEdgeInsets = UIEdgeInsetsMake(0, -13, 0, 0);

6

[btn addTarget:self action:@selector(handleBack:) forControlEvents:UIControlEventTouchUpInside];

7

self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc] initWithCustomView:btn];

这里最重要是的我们设置了button的imageEdgeInsets,让它在构造的时候就在-13这个位置固定住,而不是layout的时候才移动到我们希望的位置上。

iOS7新特性-完美解决iOS7关于自定义导航条UIBarButtonItem偏移的问题的更多相关文章

  1. IOS7 新特性(针对同样讨厌更新后IOS7的开发者)

    本文转载至 http://blog.csdn.net/hanbing861210/article/details/13614211 您还未登录!|登录|注册|帮助 首页 业界 移动 云计算 研发 论坛 ...

  2. iOS- 给App添加内购& 验证购买iOS7新特性

    1.内购——应用内购买 我所说的内购——也可以说是应用内购买 大家都知道通过苹果应用程序商店有三种主要赚钱的方式: 1.直接收费(与国内大部分用户的消费习惯相悖,如果要收费,直接收高的,别收6块钱) ...

  3. IOS7 新特性

    相关ios7新特性 帖子.挺全的.一定要看看哪 http://www.devdiv.com/iOS_iPhone-ios_ui_uikit_text_kit_-thread-203631-1-1.ht ...

  4. iOS11自定义导航条上移处理

    image.png 在自定义导航条时,通常会继承系统的UINavigationBar,但如上图,在iOS11上,导航条改动了.自定义导航条代码 -(MBNavigationBar *)myNavBar ...

  5. jQuery Mobile 自定义导航条图标

    1.jQuery Mobile 自定义导航条图标

  6. ios7新特性1-UI变化、UIKit动态行为支持与Text Kit新接口

    iOS 7.0新特性1 iOS 7的UI经过了重新设计.另外,iOS7中引入了新的动画系统,便于创建2D和2.5D的游戏.多任务支持提升,点对点通讯以及其他重要的特征使iOS7相对于以往的SDK来说发 ...

  7. ios7新特性实践

    一 iOS 7 新特性:视图控制器切换API 二 iOS 7系列译文:认识 TextKit 三 iOS 7系列译文:iOS7的多任务处理 四 iOS7 最佳实践:一个天气应用案例(上) 五 iOS7 ...

  8. ios7新特性3-Map Kit新特性

    Map Kit 框架 (MapKit.framework) 包含了大量的改进以及为基于地图的程序提供了新特性.利用地图显示位置信息的应用现在可以使用Maps这个程序用到的3D地图,包括控制程序控制视线 ...

  9. React Native中自定义导航条

    这是2017年年初开始的公司的项目,对于导航条的要求很高,Android和iOS上必须用一致的UI,按钮位置还有各种颜色都有要求,而且要适应各种奇葩要求. 尝试了一下当时React Native自带的 ...

随机推荐

  1. !!!myeclipse 上加载本地图片问题,无法加载问题

    出现无法加载本地图片的问题, 原因就是把图片放到了本地项目中的image了,但是myeclipse上没有刷新 这样以后 本地的图片比在线的要快 低级错误,诶!

  2. Python3实用编程技巧进阶✍✍✍

    Python3实用编程技巧进阶  整个课程都看完了,这个课程的分享可以往下看,下面有链接,之前做java开发也做了一些年头,也分享下自己看这个视频的感受,单论单个知识点课程本身没问题,大家看的时候可以 ...

  3. 2019 HDU 多校赛第二场 HDU 6598 Harmonious Army 构造最小割模型

    题意: 有n个士兵,你可以选择让它成为战士还是法师. 有m对关系,u和v 如果同时为战士那么你可以获得a的权值 如果同时为法师,你可以获得c的权值, 如果一个为战士一个是法师,你可以获得b的权值 问你 ...

  4. js实现图片资源、blob、base64的各种场景转换

    文件转babase64 function getImgToBase64(url,callback){//将图片转换为Base64 var canvas = document.createElement ...

  5. WIN10安装CUDA10 cuDNN

    文章目录 CPU和GPU 什么是CUDA 什么是cuDNN WIN10安装CUDA10 WIN10安装cuDNN CPU和GPU CPU和GPU是不一样的计算机设备,CPU作为计算机心脏一直被人们所认 ...

  6. android studio toolbar遮挡住下面控件内容

    只需要在该控件布局(content_***.xml)加入: app:layout_behavior="@string/appbar_scrolling_view_behavior" ...

  7. QQ聊天机器人 Delphi代码

    QQ聊天机器人     前几日,看到杂志上有一篇关于开发QQ聊天机器人的文章.谈到了对QQ循环发送消息内容,感觉倒也很好玩,于是拿起Delphi开始了我的QQ聊天机器人之路. 首先要明白自己要做什么, ...

  8. (转)C# 使用UDP组播实现局域网桌面共享

    转:http://www.cnblogs.com/mobwiz/p/3715743.html 最近需要在产品中加入桌面共享的功能,暂时不用实现远程控制:参考了园子里的一些文章,加入了一些自己的修改. ...

  9. Keras+Yolo 目标检测

    参考:https://www.cnblogs.com/tensorflownews/p/8922359.html Github:https://github.com/qqwweee/keras-yol ...

  10. iOS开发之SceneKit框架--SCNScene.h

    1.SCNScene SCNScene是一个场景图——具有附加几何形状.光照.摄像机和其他属性的节点的层次结构,共同形成可显示的3D场景. 2.相关API简介 初始化方法 //懒加载 + (insta ...