swift 创建类方法(扩展)和便利构造函数

本文介绍了如何在SwiftUI中通过扩展UIButton类来定制按钮样式,包括设置按钮的背景图片和图标,以及如何使用这些定制按钮。此外,还展示了如何在MainViewController中设置和展示这些按钮。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

https://blog.youkuaiyun.com/zhengyanfeng1989/article/details/60867795

  1. import UIKit

  2.  
  3. //UIButton的类方法扩展

  4. extension UIButton {

  5.  
  6. //这里的类方法相当于OC中的加号方法

  7. class func creatButtonWithImageName(imageName : String , bgImageName : String) -> UIButton {

  8.  
  9. //创建按钮

  10. let button = UIButton()

  11.  
  12. //设置按钮的背景图片

  13. button.setBackgroundImage(UIImage(named: bgImageName), for: UIControlState.normal)

  14. button.setBackgroundImage(UIImage(named: bgImageName + "_highlighted"), for: UIControlState.highlighted)

  15.  
  16. //设置按钮的图片

  17. button.setImage(UIImage(named: imageName), for: UIControlState.normal)

  18. button.setImage(UIImage(named: imageName + "_highlighted"), for: UIControlState.highlighted)

  19.  
  20. //按照背景图片初始化按钮尺寸

  21. button.sizeToFit()

  22.  
  23.  
  24. //返回按钮

  25. return button

  26.  
  27.  
  28. }

  29.  
  30.  
  31.  
  32. /*

  33. convenience : 便利,使用convenience修饰的构造函数叫做便利构造函数

  34. 便利构造函数通常在对系统的类进行构造函数的扩充时使用

  35. 便利构造函数的特点

  36. 1.便利构造函数通常是写在extension中

  37. 2.便利构造函数init前面需要加载convenience

  38. 3.在便利构造函数中需要明确调用self.init

  39. */

  40. convenience init(imageName : String , bgImageName : String) {

  41. self.init()

  42. //设置按钮的图片

  43. setImage(UIImage(named: imageName), for: UIControlState.normal)

  44. setImage(UIImage(named: imageName + "_highlighted"), for: UIControlState.highlighted)

  45. //设置按钮的背景图片

  46. setBackgroundImage(UIImage(named: bgImageName), for: UIControlState.normal)

  47. setBackgroundImage(UIImage(named: bgImageName + "_highlighted"), for: UIControlState.highlighted)

  48.  
  49. //按照背景图片初始化按钮尺寸

  50. sizeToFit()

  51.  
  52. }

  53.  
  54. }

 

  1. <code class="language-objc">//  
  2. //  MainViewController.swift  
  3. //  ZYFWB  
  4. //  
  5. //  Created by fe on 2017/3/7.  
  6. //  Copyright © 2017年 fe. All rights reserved.  
  7. //  
  8.   
  9. import UIKit  
  10.   
  11. class MainViewController: UITabBarController {  
  12.   
  13.     //懒加载tabBar选中图片的数组  
  14.     lazy var selectImages = ["tabbar_home","tabbar_message_center","","tabbar_discover","tabbar_profile"]  
  15.   
  16.     //懒加载中间的发布按钮(使用类方法)  
  17.     //lazy var composeBtn : UIButton = UIButton(imageName : "tabbar_compose_icon_add" , bgImageName : "tabbar_compose_button")  
  18.       
  19.     //懒加载中间的发布按钮(使用构造方法)  
  20.     lazy var composeBtn : UIButton = UIButton.creatButtonWithImageName(imageName : "tabbar_compose_icon_add"  , bgImageName : "tabbar_compose_button")  
  21.       
  22.     //系统调用函数  
  23.     override func viewDidLoad() {  
  24.         super.viewDidLoad()  
  25.           
  26.         //设置发布按钮  
  27.         setupComposeBtn()  
  28.   
  29.           
  30.     }  
  31.       
  32.     //系统调用函数  
  33.     override func viewWillAppear(_ animated: Bool) {  
  34.         super.viewWillAppear(animated)  
  35.         //调整tabBar的显示细节问题需要在该方法中,如果在viewDidLoad中调整,则在该方法中会被调整回来  
  36.         setupTabBarItems()  
  37.           
  38.     }  
  39.   
  40.     override func didReceiveMemoryWarning() {  
  41.         super.didReceiveMemoryWarning()  
  42.         // Dispose of any resources that can be recreated.  
  43.     }  
  44.   
  45. }  
  46.   
  47. // MARK:-设置UI界面  
  48. extension MainViewController {  
  49.     func setupComposeBtn() {  
  50.           
  51.         //设置发布按钮位置  
  52.         composeBtn.center = CGPoint(x: tabBar.center.x, y: tabBar.frame.size.height * 0.5)  
  53.           
  54.         //添加发布按钮到tabBar  
  55.         tabBar.addSubview(composeBtn)  
  56.     }  
  57.       
  58.     //调整tabbaritems  
  59.     func setupTabBarItems() {  
  60.         //遍历tabBarItem  
  61.         for i in 0..<tabBar.items!.count{  
  62.               
  63.             //拿到item  
  64.             let item = tabBar.items![i]  
  65.               
  66.             //如果i为2则控制item不能点击  
  67.             if i == 2 {  
  68.                 item.isEnabled = false  
  69.                 continue  
  70.             }  
  71.               
  72.             //设置item的选中图片  
  73.             item.selectedImage = UIImage(named: selectImages[i] + "_selected")  
  74.               
  75.         }  
  76.   
  77.     }  
  78. }  
  79. </code>

https://blog.youkuaiyun.com/ZhengYanFeng1989/article/details/60867795

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值