今天通过给导航条添加图片来举例说明
我们先看下系统给我们开出来的方法
这里封装采用自定义view,通过分类方式实现。目的为了调用方便。当然这是项目源码,可放心使用。直接上代码
/**
系统导航条按钮UIBarButtonItem封装
@param imageName 图片名字
@param target 当前Controller
@param action 方法名
@return 返回根据图片可定制UIBarButtonItem
*/
+(instancetype)itemWithImageNamed:(NSString *)imageName
target:(id)target
action:(SEL)action;
这是分类.h里边的方法。上边是调用示例,下边为开出来的方法。注释比较详细。代码可创建分类后直接拷贝过去使用
.m实现方法
/**
系统导航条按钮UIBarButtonItem封装
@param imageName 图片名字
@param target 当前Controller
@param action 方法名
@return 返回根据图片可定制UIBarButtonItem
*/
+(instancetype)itemWithImageNamed:(NSString *)imageName
target:(id)target
action:(SEL)action{
UIButton * Barbutton = [[UIButton alloc]init];
[Barbutton setImage:[UIImage imageNamed:imageName] forState:UIControlStateNormal];
[Barbutton addTarget:target action:action forControlEvents:UIControlEventTouchUpInside];
[Barbutton sizeToFit];
return [[UIBarButtonItem alloc]initWithCustomView:Barbutton];
}
调用示例。在Controller里边直接调用即可
/**
系统导航条按钮封装,
可直接倒入头文件使用
调用示例
右侧导航条按钮,
self.navigationItem.rightBarButtonItem = [UIBarButtonItem itemWithImageNamed:@"message_pic"
target:self
action:@selector(didSelectRightNavButton)];
左侧导航条按钮
self.navigationItem.leftBarButtonItem = [UIBarButtonItem itemWithImageNamed:@"message_pic"
target:self
action:@selector(didSelectRightNavButton)];
*/
很实用的小技巧。每天进步一点点