開關 UISwitch
UISwitch 適用於設定一個功能要開啟或關閉,是一個很常見的元件。
本節的目標如下,建立一個預設顏色的 UISwitch ,以及一個自定義顏色的 UISwitch ,並設定切換開關時變換底色:
首先在 Xcode 裡,新建一個 Single View Application 類型的專案,取名為 ExUISwitch 。
一開始在viewDidLoad
中建立一個預設狀態的 UISwitch :
// 建立一個 UISwitch
var mySwitch = UISwitch()
// 設置位置並放入畫面中
mySwitch.center = CGPoint(
x: fullScreenSize.width * 0.5,
y: fullScreenSize.height * 0.3)
self.view.addSubview(mySwitch)
接著在viewDidLoad
中建立一個自定義顏色的 UISwitch ,並設定切換開關時變換底色:
// 建立另一個 UISwitch
mySwitch = UISwitch()
// 設置滑桿鈕的顏色
mySwitch.thumbTintColor = UIColor.orange
// 設置未選取時( off )的外觀顏色
mySwitch.tintColor = UIColor.blue
// 設置選取時( on )的外觀顏色
mySwitch.onTintColor = UIColor.brown
// 設置切換 UISwitch 時執行的動作
mySwitch.addTarget(
self,
action:
#selector(ViewController.onChange),
for: .valueChanged)
// 設置位置並放入畫面中
mySwitch.center = CGPoint(
x: fullScreenSize.width * 0.5,
y: fullScreenSize.height * 0.5)
self.view.addSubview(mySwitch)
最後為ViewController
新增一個切換開關時執行動作的方法:
// UISwitch 切換時 執行動作的方法
@objc func onChange(_ sender: AnyObject) {
// 取得這個 UISwtich 元件
let tempSwitch = sender as! UISwitch
// 依據屬性 isOn 來為底色變色
if tempSwitch.isOn {
self.view.backgroundColor =
UIColor.black
} else {
self.view.backgroundColor =
UIColor.white
}
}
Hint
- 因為 UISwitch 元件的尺寸是固定的,所以範例便沒有為它設定新的尺寸,實際上如果設置新的尺寸也不會改變它的大小。
以上便為本節範例的內容。
範例
本節範例程式碼放在 uikit/uiswitch