• 自定义tabbaritem上的badeg


    项目需求,希望当用户存在未读消息的时候在对应的UITabBarItem上显示小红点。发现IOS自带的UITabBarItem的badgeValue尺寸偏大,不满足项目需求。

    第一步,建一个UITabBar的category类别。

    这里写图片描述

    第二步,编写代码。

    .h文件

    #import <UIKit/UIKit.h>
    
    @interface UITabBar (badge)
    
    - (void)showBadgeOnItemIndex:(int)index;   //显示小红点
    
    - (void)hideBadgeOnItemIndex:(int)index; //隐藏小红点
    
    @end
    
    //显示小红点
    - (void)showBadgeOnItemIndex:(int)index{  
        //移除之前的小红点
        [self removeBadgeOnItemIndex:index];
    
        //新建小红点
        UIView *badgeView = [[UIView alloc]init];
        badgeView.tag = 888 + index;
        badgeView.layer.cornerRadius = 5;//圆形
        badgeView.backgroundColor = [UIColor redColor];//颜色:红色
        CGRect tabFrame = self.frame;
    
        //确定小红点的位置
        float percentX = (index +0.6) / TabbarItemNums;
        CGFloat x = ceilf(percentX * tabFrame.size.width);
        CGFloat y = ceilf(0.1 * tabFrame.size.height);
        badgeView.frame = CGRectMake(x, y, 10, 10);//圆形大小为10
        [self addSubview:badgeView];
    }
    
    //隐藏小红点
    - (void)hideBadgeOnItemIndex:(int)index{
        //移除小红点
        [self removeBadgeOnItemIndex:index];
    }
    
    //移除小红点
    - (void)removeBadgeOnItemIndex:(int)index{
        //按照tag值进行移除
        for (UIView *subView in self.subviews) {
            if (subView.tag == 888+index) {
                [subView removeFromSuperview];
            }
        }
    }
    
    @end
    

     第三步,引入到需要使用的类中。

    #import "UITabBar+badge.h"
    

     引用代码如下:

    //显示
    [self.tabBarController.tabBar showBadgeOnItemIndex:2];
    //隐藏
    [self.tabBarController.tabBar hideBadgeOnItemIndex:2]
    

     大功告成,接下来看看效果。

    这里写图片描述

  • 相关阅读:
    Python合集之Python循环语句(二)
    io流2
    io流
    集合工具类
    泛型
    Map
    VSCode_Extensions
    C++ in VSCode
    C# 私有字段前缀 _ 的设置(VS2019, .editorconfig)
    dotnet 跨平台编译发布
  • 原文地址:https://www.cnblogs.com/boyuanmeng/p/5177350.html
Copyright © 2020-2023  润新知