---恢复内容开始---

#### 封装了一个带有中间凸起的自定制Tabbar,包含4个普通按钮和中间的一个凸起按钮-

  1. 首先封装了一个UIButton,重新设置了UIButton的图片位置和label位置
  2. 使用便利构造器创建了一个带有imageview的构造方法,用来构造中间特殊的按钮
  3. 继承与UIView创建了一个自定制tabbar类,大小为屏幕宽度和49 高,
  4. 动态创建5个自定制的UIButton,对中间的按钮做了特殊处理,其中的位置大小可以根据需求设置。
  5. 设置一个全局的button存储高亮状态下的按钮
  6. 使用闭包进行了控制器于自定制tabbar之间的传值,实现了不同按钮切换不同界面的功能

使用方法:

  1. 实例化一个自定制TabBar let myTabbar = ZYF_Main_MyTabBar()
  2. 设置自定制TabBar的frame myTabbar.frame = CGRectMake(0, height - 49, width, 49)
  3. 调用方法,传入参数:标题数组、.Normal状态下的图片数组、.selected状态下的图片数组,每个按钮之间的间距

    tabbar.creatTabBar(title, imageNames: imageName, selectedImageNames: selectedImage, space: 83)

Github地址

上代码

封装UIButton,重置UIButton的图片位置和Label位置

class ZYF_MyTabBarButton: UIButton {
//重写构造方法
override init(frame: CGRect) {
super.init(frame: frame)
self.frame = CGRectMake(0, 0, 49, 49)
self.setTitleColor(UIColor.grayColor(), forState: .Normal)
self.setTitleColor(UIColor.redColor(), forState: .Selected)
self.titleLabel?.font = UIFont.systemFontOfSize(11)
self.titleLabel?.textAlignment = .Center
} required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
//重写button中图片的位置
override func imageRectForContentRect(contentRect: CGRect) -> CGRect {
return CGRectMake((contentRect.size.width - 30) / 2, 2, 30, 30)
}
//重写button中文本框的位置
override func titleRectForContentRect(contentRect: CGRect) -> CGRect {
return CGRectMake(0, contentRect.size.height - 17, contentRect.size.width, 15)
} //使用便利构造器构造中间特殊按钮
convenience init(frame: CGRect,image:String) {
self.init(frame:frame)
let imageView = UIImageView(frame: CGRectMake(0,0,70,70))
imageView.image = UIImage(named: image)
self.addSubview(imageView)
}
}

继承UIView制作MyTabBar

class ZYF_Main_MyTabBar: UIView {
//设置一个全局的button存储selected按钮
var button = UIButton()
//获得屏高
let height = UIScreen.mainScreen().bounds.size.height
//获得屏宽
let width = UIScreen.mainScreen().bounds.size.width //闭包传值,创建一个闭包,用来传递被选中的按钮,以实现页面的转换
var clickBlock:((selcted:Int) ->())? //重写构造方法
override init(frame: CGRect) {
super.init(frame: frame)
self.frame = CGRectMake(0, 0, width, 49)
self.backgroundColor = UIColor.blackColor()
//打开用户交互
self.userInteractionEnabled = true
} required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
//写一个制作方法,传图标题数组、图片名称数组、被选中状态下图片名称数组和每个按钮之间的间距
func creatTabBar(titNames:[String],imageNames:[String],selectedImageNames:[String],space:Int) {
//快速布局
for i in 0...titNames.count - 1 {
var btn = ZYF_MyTabBarButton(type: .Custom)
btn.frame = CGRectMake(20 + CGFloat(i) * 83, 0, 49, 49)
let image = UIImage(named: imageNames[i])
let selectedImage = UIImage(named: selectedImageNames[i]) //Mark*设置中间特殊按钮
if i == 2{ //Mark* 如果想设置凸起的话让pointY为负值 let pointY:CGFloat = 5
let pointX:CGFloat = 49 + abs(pointY)
btn = ZYF_MyTabBarButton.init(frame: frame, image: "ZYF-Login-Dou")
btn.frame = CGRectMake(183, pointY, width / 5, pointX)
} else {
btn.setImage(selectedImage, forState: .Selected)
btn.setImage(image, forState: .Normal)
} btn.setTitle(titNames[i], forState: .Normal)
self.addSubview(btn)
btn.tag = 10 + i
//为每个btn添加点击事件,以实现界面替换
btn.addTarget(self, action: #selector(self.btnClick(_:)), forControlEvents: .TouchUpInside) //设置默认第一个按钮为选中状态
if i == 0 {
btn.selected = true
self.button = btn
}
}
} //点击事件
func btnClick(sender:UIButton) {
//实现视图切换
print("视图切换")
//通过tag值获取点击的btn
let index = sender.tag - 10
if index < 2 {
//设置闭包中的值
if clickBlock != nil {
clickBlock!(selcted:index)
print("index<2")
}
} else if index > 2 {
if clickBlock != nil {
clickBlock!(selcted:index - 1)
}
} else {
clickBlock!(selcted:999)
return
} //设置选中按钮
self.button.selected = false
sender.selected = true
self.button = sender
}
}

使用方式


//获取屏宽
let width = UIScreen.mainScreen().bounds.size.width
//获取屏高
let height = UIScreen.mainScreen().bounds.size.height
//实例化自定制TabBar
let tabbar = ZYF_Main_MyTabBar()
//隐藏系统的tabbar
self.tabBar.hidden = true
//设置位置
tabbar.frame = CGRectMake(0, height - 49, width, 49)
//标题数组
let title = ["发现","关注","","消息","我的"] //图片名称数组
let imageName = ["find","focus","center","message","contact"] //选中图片名称数组
let selectedImage = ["sfind","sfocs","center","smessage","smy"] //创建按钮
tabbar.creatTabBar(title, imageNames: imageName, selectedImageNames: selectedImage, space: 83) //使用闭包中的值
tabbar.clickBlock = {(selcted:Int) in
if selcted == 999 {
print("点击了特殊按钮")
} else {
print(123)
self.selectedIndex = selcted
}
}
//将自定制tabbar加到主视图上
self.view.addSubview(tabbar)

效果图如下:

---恢复内容结束---

---恢复内容开始---

#### 封装了一个带有中间凸起的自定制Tabbar,包含4个普通按钮和中间的一个凸起按钮-

  1. 首先封装了一个UIButton,重新设置了UIButton的图片位置和label位置
  2. 使用便利构造器创建了一个带有imageview的构造方法,用来构造中间特殊的按钮
  3. 继承与UIView创建了一个自定制tabbar类,大小为屏幕宽度和49 高,
  4. 动态创建5个自定制的UIButton,对中间的按钮做了特殊处理,其中的位置大小可以根据需求设置。
  5. 设置一个全局的button存储高亮状态下的按钮
  6. 使用闭包进行了控制器于自定制tabbar之间的传值,实现了不同按钮切换不同界面的功能

使用方法:

  1. 实例化一个自定制TabBar let myTabbar = ZYF_Main_MyTabBar()
  2. 设置自定制TabBar的frame myTabbar.frame = CGRectMake(0, height - 49, width, 49)
  3. 调用方法,传入参数:标题数组、.Normal状态下的图片数组、.selected状态下的图片数组,每个按钮之间的间距

    tabbar.creatTabBar(title, imageNames: imageName, selectedImageNames: selectedImage, space: 83)

Github地址

上代码

封装UIButton,重置UIButton的图片位置和Label位置

class ZYF_MyTabBarButton: UIButton {
//重写构造方法
override init(frame: CGRect) {
super.init(frame: frame)
self.frame = CGRectMake(0, 0, 49, 49)
self.setTitleColor(UIColor.grayColor(), forState: .Normal)
self.setTitleColor(UIColor.redColor(), forState: .Selected)
self.titleLabel?.font = UIFont.systemFontOfSize(11)
self.titleLabel?.textAlignment = .Center
} required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
//重写button中图片的位置
override func imageRectForContentRect(contentRect: CGRect) -> CGRect {
return CGRectMake((contentRect.size.width - 30) / 2, 2, 30, 30)
}
//重写button中文本框的位置
override func titleRectForContentRect(contentRect: CGRect) -> CGRect {
return CGRectMake(0, contentRect.size.height - 17, contentRect.size.width, 15)
} //使用便利构造器构造中间特殊按钮
convenience init(frame: CGRect,image:String) {
self.init(frame:frame)
let imageView = UIImageView(frame: CGRectMake(0,0,70,70))
imageView.image = UIImage(named: image)
self.addSubview(imageView)
}
}

继承UIView制作MyTabBar

class ZYF_Main_MyTabBar: UIView {
//设置一个全局的button存储selected按钮
var button = UIButton()
//获得屏高
let height = UIScreen.mainScreen().bounds.size.height
//获得屏宽
let width = UIScreen.mainScreen().bounds.size.width //闭包传值,创建一个闭包,用来传递被选中的按钮,以实现页面的转换
var clickBlock:((selcted:Int) ->())? //重写构造方法
override init(frame: CGRect) {
super.init(frame: frame)
self.frame = CGRectMake(0, 0, width, 49)
self.backgroundColor = UIColor.blackColor()
//打开用户交互
self.userInteractionEnabled = true
} required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
//写一个制作方法,传图标题数组、图片名称数组、被选中状态下图片名称数组和每个按钮之间的间距
func creatTabBar(titNames:[String],imageNames:[String],selectedImageNames:[String],space:Int) {
//快速布局
for i in 0...titNames.count - 1 {
var btn = ZYF_MyTabBarButton(type: .Custom)
btn.frame = CGRectMake(20 + CGFloat(i) * 83, 0, 49, 49)
let image = UIImage(named: imageNames[i])
let selectedImage = UIImage(named: selectedImageNames[i]) //Mark*设置中间特殊按钮
if i == 2{ //Mark* 如果想设置凸起的话让pointY为负值 let pointY:CGFloat = 5
let pointX:CGFloat = 49 + abs(pointY)
btn = ZYF_MyTabBarButton.init(frame: frame, image: "ZYF-Login-Dou")
btn.frame = CGRectMake(183, pointY, width / 5, pointX)
} else {
btn.setImage(selectedImage, forState: .Selected)
btn.setImage(image, forState: .Normal)
} btn.setTitle(titNames[i], forState: .Normal)
self.addSubview(btn)
btn.tag = 10 + i
//为每个btn添加点击事件,以实现界面替换
btn.addTarget(self, action: #selector(self.btnClick(_:)), forControlEvents: .TouchUpInside) //设置默认第一个按钮为选中状态
if i == 0 {
btn.selected = true
self.button = btn
}
}
} //点击事件
func btnClick(sender:UIButton) {
//实现视图切换
print("视图切换")
//通过tag值获取点击的btn
let index = sender.tag - 10
if index < 2 {
//设置闭包中的值
if clickBlock != nil {
clickBlock!(selcted:index)
print("index<2")
}
} else if index > 2 {
if clickBlock != nil {
clickBlock!(selcted:index - 1)
}
} else {
clickBlock!(selcted:999)
return
} //设置选中按钮
self.button.selected = false
sender.selected = true
self.button = sender
}
}

使用方式


//获取屏宽
let width = UIScreen.mainScreen().bounds.size.width
//获取屏高
let height = UIScreen.mainScreen().bounds.size.height
//实例化自定制TabBar
let tabbar = ZYF_Main_MyTabBar()
//隐藏系统的tabbar
self.tabBar.hidden = true
//设置位置
tabbar.frame = CGRectMake(0, height - 49, width, 49)
//标题数组
let title = ["发现","关注","","消息","我的"] //图片名称数组
let imageName = ["find","focus","center","message","contact"] //选中图片名称数组
let selectedImage = ["sfind","sfocs","center","smessage","smy"] //创建按钮
tabbar.creatTabBar(title, imageNames: imageName, selectedImageNames: selectedImage, space: 83) //使用闭包中的值
tabbar.clickBlock = {(selcted:Int) in
if selcted == 999 {
print("点击了特殊按钮")
} else {
print(123)
self.selectedIndex = selcted
}
}
//将自定制tabbar加到主视图上
self.view.addSubview(tabbar)

效果图如下:

---恢复内容结束---

#### 封装了一个带有中间凸起的自定制Tabbar,包含4个普通按钮和中间的一个凸起按钮-

  1. 首先封装了一个UIButton,重新设置了UIButton的图片位置和label位置
  2. 使用便利构造器创建了一个带有imageview的构造方法,用来构造中间特殊的按钮
  3. 继承与UIView创建了一个自定制tabbar类,大小为屏幕宽度和49 高,
  4. 动态创建5个自定制的UIButton,对中间的按钮做了特殊处理,其中的位置大小可以根据需求设置。
  5. 设置一个全局的button存储高亮状态下的按钮
  6. 使用闭包进行了控制器于自定制tabbar之间的传值,实现了不同按钮切换不同界面的功能

使用方法:

  1. 实例化一个自定制TabBar let myTabbar = ZYF_Main_MyTabBar()
  2. 设置自定制TabBar的frame myTabbar.frame = CGRectMake(0, height - 49, width, 49)
  3. 调用方法,传入参数:标题数组、.Normal状态下的图片数组、.selected状态下的图片数组,每个按钮之间的间距

    tabbar.creatTabBar(title, imageNames: imageName, selectedImageNames: selectedImage, space: 83)

Github地址

上代码

封装UIButton,重置UIButton的图片位置和Label位置

class ZYF_MyTabBarButton: UIButton {
//重写构造方法
override init(frame: CGRect) {
super.init(frame: frame)
self.frame = CGRectMake(0, 0, 49, 49)
self.setTitleColor(UIColor.grayColor(), forState: .Normal)
self.setTitleColor(UIColor.redColor(), forState: .Selected)
self.titleLabel?.font = UIFont.systemFontOfSize(11)
self.titleLabel?.textAlignment = .Center
} required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
//重写button中图片的位置
override func imageRectForContentRect(contentRect: CGRect) -> CGRect {
return CGRectMake((contentRect.size.width - 30) / 2, 2, 30, 30)
}
//重写button中文本框的位置
override func titleRectForContentRect(contentRect: CGRect) -> CGRect {
return CGRectMake(0, contentRect.size.height - 17, contentRect.size.width, 15)
} //使用便利构造器构造中间特殊按钮
convenience init(frame: CGRect,image:String) {
self.init(frame:frame)
let imageView = UIImageView(frame: CGRectMake(0,0,70,70))
imageView.image = UIImage(named: image)
self.addSubview(imageView)
}
}

继承UIView制作MyTabBar

class ZYF_Main_MyTabBar: UIView {
//设置一个全局的button存储selected按钮
var button = UIButton()
//获得屏高
let height = UIScreen.mainScreen().bounds.size.height
//获得屏宽
let width = UIScreen.mainScreen().bounds.size.width //闭包传值,创建一个闭包,用来传递被选中的按钮,以实现页面的转换
var clickBlock:((selcted:Int) ->())? //重写构造方法
override init(frame: CGRect) {
super.init(frame: frame)
self.frame = CGRectMake(0, 0, width, 49)
self.backgroundColor = UIColor.blackColor()
//打开用户交互
self.userInteractionEnabled = true
} required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
//写一个制作方法,传图标题数组、图片名称数组、被选中状态下图片名称数组和每个按钮之间的间距
func creatTabBar(titNames:[String],imageNames:[String],selectedImageNames:[String],space:Int) {
//快速布局
for i in 0...titNames.count - 1 {
var btn = ZYF_MyTabBarButton(type: .Custom)
btn.frame = CGRectMake(20 + CGFloat(i) * 83, 0, 49, 49)
let image = UIImage(named: imageNames[i])
let selectedImage = UIImage(named: selectedImageNames[i]) //Mark*设置中间特殊按钮
if i == 2{ //Mark* 如果想设置凸起的话让pointY为负值 let pointY:CGFloat = 5
let pointX:CGFloat = 49 + abs(pointY)
btn = ZYF_MyTabBarButton.init(frame: frame, image: "ZYF-Login-Dou")
btn.frame = CGRectMake(183, pointY, width / 5, pointX)
} else {
btn.setImage(selectedImage, forState: .Selected)
btn.setImage(image, forState: .Normal)
} btn.setTitle(titNames[i], forState: .Normal)
self.addSubview(btn)
btn.tag = 10 + i
//为每个btn添加点击事件,以实现界面替换
btn.addTarget(self, action: #selector(self.btnClick(_:)), forControlEvents: .TouchUpInside) //设置默认第一个按钮为选中状态
if i == 0 {
btn.selected = true
self.button = btn
}
}
} //点击事件
func btnClick(sender:UIButton) {
//实现视图切换
print("视图切换")
//通过tag值获取点击的btn
let index = sender.tag - 10
if index < 2 {
//设置闭包中的值
if clickBlock != nil {
clickBlock!(selcted:index)
print("index<2")
}
} else if index > 2 {
if clickBlock != nil {
clickBlock!(selcted:index - 1)
}
} else {
clickBlock!(selcted:999)
return
} //设置选中按钮
self.button.selected = false
sender.selected = true
self.button = sender
}
}

使用方式


//获取屏宽
let width = UIScreen.mainScreen().bounds.size.width
//获取屏高
let height = UIScreen.mainScreen().bounds.size.height
//实例化自定制TabBar
let tabbar = ZYF_Main_MyTabBar()
//隐藏系统的tabbar
self.tabBar.hidden = true
//设置位置
tabbar.frame = CGRectMake(0, height - 49, width, 49)
//标题数组
let title = ["发现","关注","","消息","我的"] //图片名称数组
let imageName = ["find","focus","center","message","contact"] //选中图片名称数组
let selectedImage = ["sfind","sfocs","center","smessage","smy"] //创建按钮
tabbar.creatTabBar(title, imageNames: imageName, selectedImageNames: selectedImage, space: 83) //使用闭包中的值
tabbar.clickBlock = {(selcted:Int) in
if selcted == 999 {
print("点击了特殊按钮")
} else {
print(123)
self.selectedIndex = selcted
}
}
//将自定制tabbar加到主视图上
self.view.addSubview(tabbar)

效果图如下:

Swift-自定制带有特殊按钮TabBar的更多相关文章

  1. ios定制中间突出的tabBar

    我觉得有两个思路,一个是自己写tabBar  通过自定义实现,缺点呢就是比较麻烦,优点就是代码比较清楚,而且比较稳定. 另一个思路就是写个大按钮加在tabBar上 通过监听tabitem的点击来实现相 ...

  2. 定制Android透明按钮

    自己在学习和做例子的过程中,常常会需要按钮,由于系统自带按钮样式不太好看,所以需要我们自己来定制项目得按钮,我常常采用2中方法: 1.是制作9-patch的图片,这样能够匹配文字内容的长短. 2.是指 ...

  3. Android自定义控件实现带有清除按钮的EditText

    首先声明我也是参考了别人的思路,只是稍微做了下修改,增加显示密码与隐藏密码,没有输入字符串时让EditText进行抖动,废话少说这里附上效果图 效果很赞有木有 那么怎么实现这种效果呢?那就跟着我一起来 ...

  4. Swift - 修改导航栏“返回”按钮文字,图标

    Swift - 修改导航栏“返回”按钮文字,图标 2015-11-27 09:13发布:hangge浏览:4037   项目中常常会使用 UINavigationController 对各个页面进行导 ...

  5. Swift - 修改导航栏“返回”按钮文字和图标 /手势冲突解决/响应范围

    iOS11之前 修改导航栏“返回”按钮文字,图标 https://blog.csdn.net/u012701023/article/details/50264265 iOS11 完美解决导航栏按钮偏移 ...

  6. Android自定义View带有删除按钮的EditText

    转载请注明出处http://blog.csdn.net/xiaanming/article/details/11066685 今天给大家带来一个很实用的小控件ClearEditText,就是在Andr ...

  7. Swift 设置navigation左右两侧按钮

    我们以设置右侧按钮为例,左侧方法类似 方法一,直接自定义文字 let item=UIBarButtonItem(title: "分享", style: UIBarButtonIte ...

  8. Swift - 重写导航栏返回按钮

    // 重写导航栏返回按钮方法 func configBackBtn() -> Void { // 返回按钮 let backButton = UIButton(type: .custom) // ...

  9. Swift 统计项目中所有按钮的点击次数

    class Swizzle: NSObject { override class func load() { UIButton.xxx_swizzleSendAction() } } extensio ...

随机推荐

  1. setState详解

    我们都知道,React通过this.state来访问state,通过this.setState()方法来更新state.当this.setState()方法被调用的时候,React会重新调用rende ...

  2. JAVA基础补漏--内部类

    成员内部类 public class InnerClass { public static void main(String[] args) { System.out.println("++ ...

  3. Mysql导出导入数据库

    1. 导出数据库:mysqldump -u 用户名 -p 数据库名 > 导出的文件名 mysqldump -u root -p database > database.sql 2. 导入数 ...

  4. scala学习手记18 - Any和Nothing

    Any 前面已经有两次提到过:在scala中,Any类是所有类的超类. Any有两个子类:AnyVal和AnyRef.对应Java直接类型的scala封装类,如Int.Double等,AnyVal是它 ...

  5. Apache顶级项目 Calcite使用介绍

    什么是Calcite Apache Calcite是一个动态数据管理框架,它具备很多典型数据库管理系统的功能,比如SQL解析.SQL校验.SQL查询优化.SQL生成以及数据连接查询等,但是又省略了一些 ...

  6. ACM International Collegiate Programming Contest, Tishreen Collegiate Programming Contest (2018) Syria, Lattakia, Tishreen University, April, 30, 2018

    ACM International Collegiate Programming Contest, Tishreen Collegiate Programming Contest (2018) Syr ...

  7. 使用SpringMVC时报错HTTP Status 405 - Request method 'GET' not supported

    GET方法不支持.我出错的原因在于,在JSP中我希望超链接a以post方式提交,但是这里写js代码时出错. <script type="text/javascript"> ...

  8. android视图概述

    android视图概述 一.简介 数据和控件分开的作用: 便于引用 便于修改:修改的时候直接改一次数据就可以了

  9. easyui datagrid 行编辑功能

    datagrid现在具有行编辑能力了,使用时只须在columns中为需要编辑的列添加一个editor属性,编辑保存时同时具有数据校验能力. 看一个例子效果图: 代码如下: $('#tt').datag ...

  10. nyoj-5-kmp裸题

    题目链接: http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=5 kmp统计匹配串出现次数,贼尴尬好久没做字符串题目,一开始求得是文本串的next ...