前言:
本文由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的时候才移动到我们希望的位置上。