UIButton高亮(highlighted)下的边框颜色(borderColor)
有時候可能會有這樣的需求,在button高亮(highlighted)的狀態(tài)下改變背景顏色(backgroundColor)或者邊框顏色(bordercolor)或者字體顏色,那么我們怎么來處理這個問題呢?下面就以改變邊框顏色為例子,默認(rèn)邊框為灰色,高亮狀態(tài)下為紅色,下面看看2種實現(xiàn)方式
1為button添加對應(yīng)的點擊事件,實現(xiàn)簡單,直接看代碼
class ViewController: UIViewController {@IBOutlet weak var button: UIButton!override func viewDidLoad() {super.viewDidLoad()button.layer.borderColor = UIColor.gray.cgColorbutton.layer.borderWidth = 2button.addTarget(self, action: #selector(highlightBorder), for: .touchDown)button.addTarget(self, action: #selector(normalBorder), for: .touchUpInside)}func highlightBorder() {print("highlightBorder")button.layer.borderColor = UIColor.red.cgColor}func normalBorder() {print("normalBorder")button.layer.borderColor = UIColor.gray.cgColor} }
分析:默認(rèn)情況下,邊框為灰色,當(dāng)我們按鈕按鈕的時候,邊框變?yōu)榧t色,當(dāng)松開按鈕時又回到正常灰色邊框,這里功能的實現(xiàn)需要明確按鈕事件的觸發(fā)時機。
touchDown,單點觸摸按下事件:用戶點觸屏幕,或者又有新手指落下的時候。?
touchUpInside.所有在控件之內(nèi)觸摸抬起事件。
touchUpInside在touchDown之后進(jìn)行調(diào)用,所以能夠?qū)崿F(xiàn)我們的需求。
2自定義UIButton,重寫isHighlighted屬性
重寫isHighlighted屬性,設(shè)置對應(yīng)的邊框顏色
class MyButton: UIButton {override var isHighlighted: Bool {didSet {switch isHighlighted {case true:layer.borderColor = UIColor.red.cgColorcase false:layer.borderColor = UIColor.gray.cgColor}}} }ViewController僅僅是持有MyButton實例,并且設(shè)置默認(rèn)邊框顏色
class ViewController: UIViewController {@IBOutlet weak var myButton: MyButton!override func viewDidLoad() {super.viewDidLoad()myButton.layer.borderColor = UIColor.gray.cgColormyButton.layer.borderWidth = 2} }
總結(jié)
以上是生活随笔為你收集整理的UIButton高亮(highlighted)下的边框颜色(borderColor)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux 限速命令,linux上传限速
- 下一篇: 计算机竞赛奖学金申请书,计算机专业奖学金