自定义tabBar能够解决自定义图片无法显示(只显示一块颜色)这个弊端,自定义tabBar要继承UITabBarController

原图片:

(1), (2),(3), (4),(5)

下面是自定义了一个TabBar ,每个按钮可以显示图片(自定义避免了图片无法显示只显示一块颜色)

效果图:



代码实现:

一, 首先创建一个继承UIButton的类CustomTabBar,

在.h文件中:

//指定协议是为了实现点击button显示相应地页面,像系统的tabBar一样

@protocol CustomTabBarDelegate <NSObject>

-(void)didSelectBarItemAtIndex:(NSInteger)index;

@end

@interface CustomTabBar : UIButton
@property(nonatomic,assign) NSInteger index;
@property (nonatomic,retain) id<CustomTabBarDelegate> delegate;
- (id)initWithFrame:(CGRect)frame WithImage:(UIImage *)p_w_picpath AndSelectedImage:(UIImage *)p_w_picpath;
@end



在.m文件中


#import "CustomTabBar.h"

@interface CustomTabBar ()

@end
@implementation CustomTabBar

- (id)initWithFrame:(CGRect)frame
{
self = [super initWithFrame:frame];
if (self) {
// Initialization code

}
return self;
}

- (id)initWithFrame:(CGRect)frame WithImage:(UIImage *)p_w_picpath AndSelectedImage:(UIImage *)selectedImage{
self = [super initWithFrame:frame];
if (self) {
self.frame = frame;
[self setAdjustsImageWhenHighlighted:NO];
[self setImage:p_w_picpath forState:UIControlStateNormal];
[self setImage:selectedImage forState:UIControlStateSelected];
[self addTarget:self action:@selector(click:) forControlEvents:UIControlEventTouchUpInside];
}
return self;
}

-(void)click:(UIButton *)btn{
if ([self.delegate respondsToSelector:@selector(didSelectBarItemAtIndex:)]) {
[self.delegate didSelectBarItemAtIndex:self.index];
}
switch ((int)(btn.selected)) {
case 0:
btn.selected = YES;
break;
case 1:
btn.selected = NO;
break;
default:
break;
}
}


@end


二, 创建一个类CustomizedTabBarController继承UITabBarController


在.m文件中

- (void)loadViewController
{
CoverCollectionViewController *coverVC = [[CoverCollectionViewController alloc] init];
//coverVC.title = @"每日封面";
CustomizedNavigationController *coverNaVC = [[CustomizedNavigationController alloc] initWithRootViewController:coverVC];
coverNaVC.navigationItem.title = @"iDailyWATCh";

NewsTableViewController *newsVC = [[NewsTableViewController alloc] init];
//newsVC.title = @"腕表杂志";
CustomizedNavigationController *newsNaVC = [[CustomizedNavigationController alloc] initWithRootViewController:newsVC];

BrandsTableViewController *brandsVC = [[BrandsTableViewController alloc] init];
//brandsVC.title = @"品牌维基";
CustomizedNavigationController *brandsNaVC = [[CustomizedNavigationController alloc] initWithRootViewController:brandsVC];

VideosCollectionViewController *videosVC = [[VideosCollectionViewController alloc] init];
//videosVC.title = @"视频";
CustomizedNavigationController *videosNaVC = [[CustomizedNavigationController alloc] initWithRootViewController:videosVC];

MoreViewController *moreVC = [[MoreViewController alloc] init];
//moreVC.title = @"更多";
CustomizedNavigationController *moreNaVC = [[CustomizedNavigationController alloc] initWithRootViewController:moreVC];

self.viewControllers = @[coverNaVC, newsNaVC, brandsNaVC, videosNaVC, moreNaVC];
self.selectedIndex = 0;
RELEASE_SAFE(coverNaVC);
RELEASE_SAFE(coverVC);
RELEASE_SAFE(brandsNaVC);
RELEASE_SAFE(brandsVC);
RELEASE_SAFE(videosNaVC);
RELEASE_SAFE(videosVC);
RELEASE_SAFE(moreNaVC);
RELEASE_SAFE(moreVC);
}


- (void)setupTabBar
{
for (int i = 0 ; i < 5; i++) {
if (i < 3) {
CustomTabBar *bar = [[CustomTabBar alloc]initWithFrame:CGRectMake(0 + 80 * i, 0, 80, 49) WithImage: [UIImage p_w_picpathNamed:[NSString stringWithFormat:@"%d", i + 100]]AndSelectedImage:[UIImage p_w_picpathNamed:[NSString stringWithFormat:@"%d", i + 130]]];
bar.index = i;
bar.delegate = self;
bar.backgroundColor = RGB(245, 245, 245);
[self.tabBar addSubview:bar];
[bar release];
if (i == 0) {
bar.selected = YES;
}
} else {
CustomTabBar *bar = [[CustomTabBar alloc]initWithFrame:CGRectMake(0 + 40 * (i + 3), 0, 40, 49) WithImage: [UIImage p_w_picpathNamed:[NSString stringWithFormat:@"%d", i + 100]]AndSelectedImage:[UIImage p_w_picpathNamed:[NSString stringWithFormat:@"%d", i + 130]]];
bar.index = i;
bar.delegate = self;
bar.backgroundColor = RGB(245, 245, 245);
[self.tabBar addSubview:bar];
[bar release];
}
}
}


-(void)didSelectBarItemAtIndex:(NSInteger)index{
[self resignBatState];
self.selectedViewController = self.viewControllers[index];
}
-(void)resignBatState{
NSArray *arr = [self.tabBar subviews];
for (CustomTabBar *bar in arr) {
if ([bar isKindOfClass:[CustomTabBar class]]) {
bar.selected = NO;
}
}
}

- (void)changeViewController:(UIButton *)button
{
self.selectedIndex = button.tag;
}

- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}