ios开发框架封装(十):MBProgressHUD基本使用与二次封装

先放demo地址:github.com/KeWangKW/99...

  • 封装只是为了少写代码而已

(一)MBProgressHUD------使用:

    1. 默认展示
    • let hud = MBProgressHUD.showAdded(to: superView, animated: true)
    1. 默认展示 + 文字
    • hud.label.text = "Text"
    • hud.detailsLabel.text = "Deatil"

    1. 修改背景边框颜色
    • hud.bezelView.style = .solidColor//设置此属性,可随心随遇的设置背景色
    • hud.bezelView.color = UIColor.init(white: 0, alpha: 0.3)
    • 背景色透明度 alpha 为0时,也能隐藏背景框
    1. 修改动图和文字颜色
    • hud.contentColor = UIColor.red
    1. 修改内容 和 边框 之间的间距 ,margin默认值是20,以下是修改成5的样式
    • hud.margin = 5
    1. 展示 进度条 类型
    • hud.mode = .determinate //饼状进度条
    • hud.mode = .determinateHorizontalBar //线型进度条
    • hud.mode = .annularDeterminate //环状进度条
    • hud.progress = xxxx //设置进度
    • 如果要文字展示出进度,设置 hud.label.text = 即可

    1. 使用自定义图片
    • hud.mode = .customView
    • hud.customView = UIImageView(image: UIImage(named: "HUD_success") )
    • hud.mode = .customView
    • let imageView = UIImageView()
    • if let localGifURL = Bundle.main.url(forResource: "加载缓存", withExtension: "gif") {
      • imageView.sd_setImage(with: localGifURL, completed: nil)
    • }

(二)MBProgressHUD------封装:

一级封装:
  • 封装文件名:HUD.swift
  • 展示HUD方法名:showMBProgressHUD
  • 传递参数:
    • /// view:展示所在View
    • /// mode:类型:
      • /// MBProgressHUDModeIndeterminate:普通加载动图
      • /// MBProgressHUDModeDeterminate:饼状进度条
      • /// MBProgressHUDModeDeterminateHorizontalBar:水平进度条
      • /// MBProgressHUDModeAnnularDeterminate:圆环进度条
      • /// MBProgressHUDModeCustomView:显示自定义视图
      • /// MBProgressHUDModeText:只显示标签
    • /// bezelViewColor:边框的背景色
    • /// contentColor:普通加载动图、文字颜色
    • /// text:展示文字
    • /// detailText:展示详情文字
    • /// margin:内容到边框 最小边距 默认20
    • /// imageV:自定义图片
  • 隐藏HUD方法名:func hide(_ view: UIView? = nil)
二级封装【封装常用样式】:
  • 默认展示 可展示文字

    • HUD.show()
    • HUD.show(text: "233")
  • 展示纯文字 默认1.5秒后消失

    • HUD.showText(text: "23333")
  • 展示成功图片 可展示文字 默认1.5秒后消失

    • HUD.showSuccess()
    • HUD.showSuccess(text:"2333")
  • 展示失败图片 可展示文字 默认1.5秒后消失

    • 同上
  • 展示提示图片 可展示文字 默认1.5秒后消失

    • 同上
  • 展示进度条

    • let hud = HUD.showProgress(text: "进度")
    • hud.progress = 0.3 //设置进度
  • 以上方法中 view 参数是指要展示HUD的view,不传此参数默认展示在当前视图控制器上

  • 以上是我在自己项目中常用的样式,有其他样式时可在 extension HUD 扩展方法中添加,或者在一级封装的方法中添加属性

  • 封装后,调用展示仅用一行代码就能完成 如:HUD.showSuccess(text:"2333") 隐藏:HUD.hide()

  • GIF演示如下:

相关推荐
—Qeyser2 小时前
Flutter CustomScrollView 自定义滚动视图 - 完全指南
android·flutter·ios
—Qeyser3 小时前
Flutter ListView 列表组件完全指南
android·flutter·ios
游戏开发爱好者84 小时前
如何在 Windows 环境下测试 iOS App,实时日志,CPU监控
android·ios·小程序·https·uni-app·iphone·webview
ii_best6 小时前
免越狱!按键精灵鹰眼群控让电脑批量掌控 iOS 设备,功能介绍
ios·自动化·电脑
Swift社区1 天前
使用 MetricKit 监控应用性能
ios·swiftui·swift
LawrenceMssss1 天前
由于创建一个完整的App涉及到多个层面(如前端、后端、数据库等),并且每种语言通常有其特定的用途(如Java/Kotlin用于Android开发,Swift/Objective-C用于iOS开发,Py
android·java·ios
2501_915921431 天前
如何在苹果手机上面进行抓包?iOS代理抓包,数据流抓包
android·ios·智能手机·小程序·uni-app·iphone·webview
Boyang_1 天前
在 iOS 26 上@property 的一个小 bug
ios
七牛云行业应用1 天前
iOS 19.3 突发崩溃!Gemini 3 导致 JSON 解析失败的紧急修复
人工智能·ios·swift·json解析·大模型应用
初级代码游戏1 天前
iOS开发 SwiftUI 6 :List
ios·swiftui·swift