iOS中自定义TabBar小红点

最近项目里有遇到给tabBarItem添加类似小红点功能,由于系统自带的小红点只能完成数字,简易红点等功能,远远不能满足产品所需的图片,颜色等,如图:


然后我试着查看了UITabBarItem,它并不继承于UIView,我想应该是它的一个属性继承的UIView,然后我试着用运行时打印了UITabBarItem的属性和方法,结果分别如下:


UITabBarItem的属性列表


UITabBarItem方法列表

幸运的是,我可以清楚的看到我要的“view”和“setView”,然后我试着用kvc取出view

UIView *barButtonView= [item1 valueForKeyPath:@"view"];

NSLog(@"%@",barButtonView);

然后再打印出了barButtonView的子控件UITabBarSwappableImageView,这个view就是我需要的用于自定义小红点的view,于是我写了下面这个分类:

//  UITabBar+DLBadge.h       头文件中

@property(nonatomic,assign) CGSize badgeSize;        //小红点size

@property(nonatomic,strong)UIImage *badgeImage;      //小红点图片

@property(nonatomic,strong)UIColor *badgeColor;      //小红点颜色

//显示小红点

- (void)showBadgeOnItemIndex:(NSUInteger )index;

//隐藏小红点

- (void)hiddenRedPointOnIndex:(NSUInteger )index animation:(BOOL )animation;

@end

//  UITabBar+DLBadge.m           源文件中

#define badgeTag(index) (1000 + index)

static char *kBadgeSize = "kBadgeSize";

static char *kBadgeColor = "kBadgeColor";

static char *kBadgeImage = "kBadgeImage";

@implementation UITabBar (DLBadge)

//运行时处理分类属性

- (void)setBadgeSize:(CGSize)badgeSize

{

objc_setAssociatedObject(self, &kBadgeSize,[NSValue valueWithCGSize:badgeSize], OBJC_ASSOCIATION_RETAIN_NONATOMIC);

}

- (CGSize)badgeSize

{

return [objc_getAssociatedObject(self, &kBadgeSize) CGSizeValue];

}

- (void)setBadgeImage:(UIImage *)badgeImage

{

objc_setAssociatedObject(self, &kBadgeImage, badgeImage, OBJC_ASSOCIATION_RETAIN_NONATOMIC);

}

- (UIImage *)badgeImage

{

return objc_getAssociatedObject(self, &kBadgeImage);

}

- (void)setBadgeColor:(UIColor *)badgeColor

{

objc_setAssociatedObject(self, &kBadgeColor, badgeColor, OBJC_ASSOCIATION_RETAIN_NONATOMIC);

}

- (UIColor *)badgeColor

{

return objc_getAssociatedObject(self, &kBadgeColor);

}

//显示小红点

- (void)showBadgeOnItemIndex:(NSUInteger )index

{

//移除

[self removeRedPointOnIndex:index animation:NO];

//默认值设置

if (CGSizeEqualToSize(self.badgeSize, CGSizeZero))

{

self.badgeSize = CGSizeMake(12, 12);

}

if (!self.badgeColor)

{

self.badgeColor = [UIColor redColor];

}

//badgeView(小红点)

CGSize badgeSize = self.badgeSize;

UIView *badgeView = [[UIView alloc]init];

badgeView.backgroundColor = self.badgeColor;

badgeView.layer.cornerRadius = badgeSize.width / 2;

badgeView.tag = badgeTag(index);

//barButtonView(里面包含文字和图片)

UIView *barButtonView = [self getBarButttonViewWithIndex:index];

//(图片的imageView)

UIView *iconView = nil;

for (UIView *swappableImageView  in barButtonView.subviews)

{

if ([swappableImageView isKindOfClass:[UIImageView class]])

{

iconView = swappableImageView;

break;

}

}

CGSize iconViewSize = iconView.frame.size;

badgeView.frame = CGRectMake(iconViewSize.width - badgeSize.width / 2, - badgeSize.width / 2, badgeSize.width, badgeSize.height);

//添加图片到小红点上

UIImageView *imageview = [[UIImageView alloc]initWithFrame:badgeView.bounds];

imageview.image = self.badgeImage;

if (self.badgeImage)

{

self.badgeColor = [UIColor clearColor];

}

[badgeView addSubview:imageview];

//添加小红点到系统图层上

[iconView addSubview:badgeView];

}

//隐藏小红点

- (void)hiddenRedPointOnIndex:(NSUInteger )index animation:(BOOL )animation

{

[self removeRedPointOnIndex:index animation:animation];

}

- (void)removeRedPointOnIndex:(NSUInteger )index animation:(BOOL )animation

{

//获取对应的barButtonView(里面包含文字和图片)

UIView *barButtonView = [self getBarButttonViewWithIndex:index];

for (UIView *swapView in barButtonView.subviews)

{

if ([swapView isKindOfClass:[UIImageView class]])      //遍历出图片类的uiview图层_iconView

{

for (UIView *view in swapView.subviews)

{

if (view.tag == badgeTag(index))                //找到了小红点

{

if (animation)

{

[UIView animateWithDuration:0.2 animations:^{

view.transform = CGAffineTransformScale(view.transform, 2, 2);

view.alpha = 0;

} completion:^(BOOL finished) {

[view removeFromSuperview];

}];

}else

{

[view removeFromSuperview];

}

}

}

}

}

}

//获取barButtonView

- (UIView *)getBarButttonViewWithIndex:(NSUInteger )index

{

UIBarButtonItem *item = (UIBarButtonItem *)[self.items  objectAtIndex:index];

//通过runtime和KVC找到UIBarBottunItem的View,至于为什么是“view”,可在 viewController中使用【self test】方法进行调试打印

UIView *barButtonView = [item valueForKey:@"view"];

return barButtonView;

}

引入该分类,可在控制器中直接使用,使用方法如下:

self.myTabBar.badgeSize = CGSizeMake(14, 14);          //不设置默认为12

self.myTabBar.badgeColor = [UIColor orangeColor];      //不设置默认为红色

self.myTabBar.badgeImage = [UIImage imageNamed:@"补贴"]; //不设置只显示小红点

//!!!最重要的一句代码

[self.myTabBar showBadgeOnItemIndex:2];                //传入你所需要显示红点的index即可显示,此处demo点击屏幕,红点消失


demo下载地址:https://github.com/shineDongDongEr/UITabBar-DLBadge

iOS小白,行走在路上,大神路过,欢迎赐教!   QQ:542155086

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容