第一种:文字和下划线颜色相同
private lazy var checkReasonBtn : UIButton = { let btn = JYUIModel.createBtn() btn.addTarget(self, action: #selector(clickCheckReasonBtn), for: UIControl.Event.touchUpInside) var attributedString = NSMutableAttributedString(string:"查看原因") var range = NSRange() range.location = 0 range.length = attributedString.length attributedString.addAttributes([NSAttributedString.Key.underlineStyle : NSNumber(value: NSUnderlineStyle.single.rawValue),NSAttributedString.Key.foregroundColor:UIColor.init(hexString: "#4A90E2")], range: range) btn.setAttributedTitle(attributedString, for: UIControl.State.normal) return btn }()
第二种, 文字和下划线颜色不同
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 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 | import UIKit /// 带下划线的Button class UnderlineButton: JYBaseButton { /// 下划线高度 var underLineHeight:CGFloat = 2{ didSet{ //保护 if (underLineHeight > self.bounds.size.height/2) || (underLineHeight < 0){ underLineHeight = 2 } self.draw(self.bounds) } } /// 默认下划线颜色 var normalUnderColor:UIColor = UIColor.clear /// 选中下划线颜色 var selectedUnderColor:UIColor = UIColor.init(hexString: "#FF8437" ) convenience init(normalUnderColor:UIColor, selectedUnderColor:UIColor, underLineHeight:CGFloat){ self.init() self.normalUnderColor = normalUnderColor self.selectedUnderColor = selectedUnderColor self.underLineHeight = underLineHeight } override var isSelected: Bool{ didSet{ self.draw(self.bounds) } } override func draw(_ rect: CGRect) { let textRect : CGRect = self.titleLabel?.frame ?? CGRect.zero if let contect : CGContext = UIGraphicsGetCurrentContext(){ switch isSelected { case true : contect.setStrokeColor((selectedUnderColor.cgColor)) case false : contect.setStrokeColor((normalUnderColor.cgColor)) } contect.move(to: CGPoint(x: textRect.origin.x, y: self.bounds.size.height - underLineHeight) ) contect.addLine(to: CGPoint(x: textRect.origin.x + textRect.size.width, y: self.bounds.size.height - underLineHeight)) contect.setLineWidth(underLineHeight) contect.closePath() contect.drawPath( using : CGPathDrawingMode.stroke) } } } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现