我们在写代码自定义UIBarButtonItem的时候,一般是像下面这样来定义的:
self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed:@"qr-code"] style:UIBarButtonItemStylePlain target:self action:nil];
这样创建就产生了一个问题,就是创建的这个UIBarButtonItem它的高度是充满UINavigationBar的,有一次PM就觉得这样上下充满UINavigationBar不是很好看,要我把这个UIBarButtonItem的尺寸调小一点(当然PM不知道这是UIBarButtonItem,它只知道这是个控件哈哈)。
下面讲的就是如何调整UIBarButtonItem的size。
步骤:
- 1.创建一个自定义的控件,比如UIButton,后面我们需要用这个Button来创建UIBarButtonItem。
- 2.约束这个Button的size。
- 3.利用这个button来创建UIBarButtonItem。
创建一个自定义的控件,这里以UIButon为例
这一步和创建普通的控件没有区别:
UIButton *button = [UIButton buttonWithType:UIButtonTypeCustom];
UIImage *image = [UIImage imageNamed:@"小qr-code"];
[button setImage:image forState:UIControlStateNormal];
[button addTarget:self action:@selector(weChatScanlogin) forControlEvents:UIControlEventTouchUpInside];
约束这个控件的size
测试的时候发现给这个Button设置frame是没有用的,仍然会充满UINavigationBar,我们需要通过下列方式来约束控件的width和height:
[button.widthAnchor constraintEqualToConstant:35].active = YES;
[button.heightAnchor constraintEqualToConstant:35].active = YES;
利用这个控件来创建UIBarButtonItem
UIBarButtonItem有一个实例方法:
- (instancetype)initWithCustomView:(UIView *)customView
这个方法可以用来通过自定义的控件创建UIBarButtonItem。
IBarButtonItem *buttonItem = [[UIBarButtonItem alloc] initWithCustomView:button];
网友评论