UIButton高亮(highlighted)下的边框颜色(borderColor)
有時(shí)候可能會(huì)有這樣的需求,在button高亮(highlighted)的狀態(tài)下改變背景顏色(backgroundColor)或者邊框顏色(bordercolor)或者字體顏色,那么我們?cè)趺磥?lái)處理這個(gè)問(wèn)題呢?下面就以改變邊框顏色為例子,默認(rèn)邊框?yàn)榛疑?#xff0c;高亮狀態(tài)下為紅色,下面看看2種實(shí)現(xiàn)方式
1為button添加對(duì)應(yīng)的點(diǎn)擊事件,實(shí)現(xiàn)簡(jiǎ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)情況下,邊框?yàn)榛疑?#xff0c;當(dāng)我們按鈕按鈕的時(shí)候,邊框變?yōu)榧t色,當(dāng)松開按鈕時(shí)又回到正常灰色邊框,這里功能的實(shí)現(xiàn)需要明確按鈕事件的觸發(fā)時(shí)機(jī)。
touchDown,單點(diǎn)觸摸按下事件:用戶點(diǎn)觸屏幕,或者又有新手指落下的時(shí)候。?
touchUpInside.所有在控件之內(nèi)觸摸抬起事件。
touchUpInside在touchDown之后進(jìn)行調(diào)用,所以能夠?qū)崿F(xiàn)我們的需求。
2自定義UIButton,重寫isHighlighted屬性
重寫isHighlighted屬性,設(shè)置對(duì)應(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í)例,并且設(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)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: linux 限速命令,linux上传限速
- 下一篇: 计算机竞赛奖学金申请书,计算机专业奖学金