iOS7新特性-完美解决iOS7关于自定义导航条UIBarButtonItem偏移的问题
前言:
本文由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 |
|
21 |
} |
|
22 |
|
23 |
- (BOOL)isLeftButton |
|
24 |
{ |
|
25 |
return |
|
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偏移的问题的更多相关文章
- IOS7 新特性(针对同样讨厌更新后IOS7的开发者)
本文转载至 http://blog.csdn.net/hanbing861210/article/details/13614211 您还未登录!|登录|注册|帮助 首页 业界 移动 云计算 研发 论坛 ...
- iOS- 给App添加内购& 验证购买iOS7新特性
1.内购——应用内购买 我所说的内购——也可以说是应用内购买 大家都知道通过苹果应用程序商店有三种主要赚钱的方式: 1.直接收费(与国内大部分用户的消费习惯相悖,如果要收费,直接收高的,别收6块钱) ...
- IOS7 新特性
相关ios7新特性 帖子.挺全的.一定要看看哪 http://www.devdiv.com/iOS_iPhone-ios_ui_uikit_text_kit_-thread-203631-1-1.ht ...
- iOS11自定义导航条上移处理
image.png 在自定义导航条时,通常会继承系统的UINavigationBar,但如上图,在iOS11上,导航条改动了.自定义导航条代码 -(MBNavigationBar *)myNavBar ...
- jQuery Mobile 自定义导航条图标
1.jQuery Mobile 自定义导航条图标
- ios7新特性1-UI变化、UIKit动态行为支持与Text Kit新接口
iOS 7.0新特性1 iOS 7的UI经过了重新设计.另外,iOS7中引入了新的动画系统,便于创建2D和2.5D的游戏.多任务支持提升,点对点通讯以及其他重要的特征使iOS7相对于以往的SDK来说发 ...
- ios7新特性实践
一 iOS 7 新特性:视图控制器切换API 二 iOS 7系列译文:认识 TextKit 三 iOS 7系列译文:iOS7的多任务处理 四 iOS7 最佳实践:一个天气应用案例(上) 五 iOS7 ...
- ios7新特性3-Map Kit新特性
Map Kit 框架 (MapKit.framework) 包含了大量的改进以及为基于地图的程序提供了新特性.利用地图显示位置信息的应用现在可以使用Maps这个程序用到的3D地图,包括控制程序控制视线 ...
- React Native中自定义导航条
这是2017年年初开始的公司的项目,对于导航条的要求很高,Android和iOS上必须用一致的UI,按钮位置还有各种颜色都有要求,而且要适应各种奇葩要求. 尝试了一下当时React Native自带的 ...
随机推荐
- identityserver4 对接钉钉
参考了https://www.cnblogs.com/sheldon-lou/p/10643267.html
- SQLAlchemy连接数据库创建表
# 连接数据库,创建表 def create_all(): engine = create_engine( 'mysql+pymysql://root:123456@127.0.0.1:3306/sq ...
- dubbo视频分享
一.基础篇 第001节--课程介绍 第01节--使用Dubbo对传统工程进行服务化改造的思路介绍 第02节--使用Dubbo对传统工程进行服务化改造 第03节--ZooKeeper注册中心安装 第04 ...
- pandas中series求交集
在进行数据探索的时候会遇到求交集的情况,比如说:优惠卷预测的时候,有多张表,表1有用户id,表2也有用户id,但是不能确定表1的用户有多少出现在表2当中. un_id1,un_id2 为两个 Seri ...
- PHP算法之回文数
判断一个整数是否是回文数.回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数. 示例 1: 输入: 121输出: true示例 2: 输入: -121输出: false解释: 从左向右读, ...
- MySQL安装pdf介绍
pdf地址:https://files.cnblogs.com/files/pygo/mysql%E5%AE%89%E8%A3%85.pdf
- Python 学习杂项
#print("Hello World!") #name = "nihfjkds" age = 454 num1 = 1 num2 = 2 #print(nam ...
- java反射快速入门
笔记记在了掘金,发现掘金的markdown编辑器比博客园样式要好看不少 https://juejin.im/post/5d4e575af265da03e4674e9f
- ImageMagick convert多张照片JPG转成pdf格式,pdfunite合并PDF文件
在认识ImageMagick之前,我***的图像浏览软件是KuickShow,截图软件是KSnapShot,这两款软件都是KDE附带的软件,用起来也是蛮方便的.在一次偶然的机会中,我遇到了Imag ...
- idea运行tomcat,控制台中文乱码
加入参数:-Dfile.encoding=UTF-8