具体内容详情如下所示:
- 以分类的方式实现
代码
uitabbar+extenstion.swift
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
fileprivate let lxfflag: int = 666 extension uitabbar { // mark:- 显示小红点 func showbadgon(index itemindex: int , tabbaritemnums: cgfloat = 4.0) { // 移除之前的小红点 self.removebadgeon(index: itemindex) // 创建小红点 let bageview = uiview() bageview.tag = itemindex + lxfflag bageview.layer.cornerradius = 5 bageview.backgroundcolor = uicolor.red let tabframe = self.frame // 确定小红点的位置 let percentx: cgfloat = (cgfloat(itemindex) + 0.59) / tabbaritemnums let x: cgfloat = cgfloat(ceilf( float (percentx * tabframe.size.width))) let y: cgfloat = cgfloat(ceilf( float (0.115 * tabframe.size.height))) bageview.frame = cgrect(x: x, y: y, width: 10, height: 10) self.addsubview(bageview) } // mark:- 隐藏小红点 func hidebadg(on itemindex: int ) { // 移除小红点 self.removebadgeon(index: itemindex) } // mark:- 移除小红点 fileprivate func removebadgeon(index itemindex: int ) { // 按照tag值进行移除 _ = subviews.map { if $0.tag == itemindex + lxfflag { $0.removefromsuperview() } } } } |
使用
1
2
3
4
|
// 默认4个tabbaritem self.tabbarcontroller?.tabbar.showbadgon(index: 2) // 如果不是则用这个方法 // self.tabbarcontroller?.tabbar.showbadgon(index: int, tabbaritemnums: cgfloat) |
效果
小红点
以上所述是小编给大家介绍的ios 中swift仿微信添加提示小红点功能(无数字),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:http://www.jianshu.com/p/807cddad469a