【Swift UIKit】UISegmentedControlの使い方!画像や色の変更方法

【Swift UIKit】UISegmentedControlの使い方!画像や色の変更方法

この記事からわかること

  • Swift/UIKitUISegmentedControl使用方法
  • Storyboardコードでの実装方法
  • 選択時に処理実行するには?
  • 画像表示させるには?

index

[open]

\ アプリをリリースしました /

みんなの誕生日

友達や家族の誕生日をメモ!通知も届く-みんなの誕生日-

posted withアプリーチ

公式リファレンス:UISegmentedControl

UISegmentedControlクラス

【Swift UIKit】UISegmentedControlの使い方!
@MainActor  class UISegmentedControl : UIControl

UISegmentedControlは上画像のような区切られたコントロールUIを構築できるクラスです。複数の項目を羅列することができ、選択すると滑らかに選択表示が移動してくれます。

UIButtonなどと同じくUIControlを継承しているため選択時などに任意のアクションなどを行わせることも可能になっています。

おすすめ記事
【Swift UIKit】addTargetメソッドの使い方と意味!UIControlとEventの種類
【Swift/UIKit】UIViewクラスとは?使い方やプロパティまとめ

Storyboardでの実装方法

実装するにはStoryboard(Interface Builder)とコードのみの2パターン方法があります。まずはStoryboardでの方法から見ていきます。

Segmented Controlを追加し、Attributesからセグメント数やタイトルなどを変更することができます。

【Swift UIKit】UISegmentedControlの使い方!

アクションを追加する

セグメントの項目がクリックされた時に任意の処理を実行させたい場合はコードを記述してアクションを追加します。まずはアウトレット変数を用意し紐付けしておきます。

続いてaddTargetメソッドを使用して任意の処理を登録していきます。

class ViewController: UIViewController {
    
    @IBOutlet  weak var segmented: UISegmentedControl!
    
    override func viewDidLoad() {
        super.viewDidLoad()
        segmented.addTarget(self, action: #selector(segmentChanged), for: .valueChanged)
    }
    
    // 選択された時に実行させたい処理
    @objc  func segmentChanged() {
        let selectedIndex = segmented.selectedSegmentIndex
        print(selectedIndex)
    }
}

selectedSegmentIndexプロパティから現在選択されているセグメント項目のインデックス番号を取得することができます。

またこのプロパティに値を格納することで最初に選択状態にする番号を指定することもできます。

segmented.selectedSegmentIndex = 2

コードでの実装方法

コードの場合はセグメントのタイトルを配列形式で定義しておきインスタンス化時に渡すことで簡単に設定することができます。

class ViewController: UIViewController {
    
    private var segmented:UISegmentedControl!
    
    override func viewDidLoad() {
        super.viewDidLoad()
        // タイトル配列
        let segmentTitle = ["First","Second","Third"]
        // インスタンス化
        segmented = UISegmentedControl(items: segmentTitle)
        // サイズ
        segmented.frame = CGRect(x:0, y:0, width:UIScreen.main.bounds.width  - 60, height:40)
        // 配置
        segmented.center = self.view.center
        // アクション
        segmented.addTarget(self, action: #selector(segmentChanged), for: .valueChanged)
        // 追加
        self.view.addSubview(segmented)
    }
    
    @objc  func segmentChanged() {
        let selectedIndex = segmented.selectedSegmentIndex
        print(selectedIndex)
    }
}

画像を表示させる

セグメントの項目には文字列だけでなく画像を表示させることも可能です。

let segmentImage = [UIImage(systemName: "iphone"),UIImage(systemName: "display"),UIImage(systemName: "laptopcomputer")]
segmented = UISegmentedControl(items: segmentImage)
【Swift UIKit】UISegmentedControlの使い方!

まだまだ勉強中ですので間違っている点や至らぬ点がありましたら教えていただけると助かります。

ご覧いただきありがとうございました。

searchbox

スポンサー

ProFile

ame

趣味:読書,プログラミング学習,サイト制作,ブログ

IT嫌いを克服するためにITパスを取得しようと勉強してからサイト制作が趣味に変わりました笑
今はCMSを使わずこのサイトを完全自作でサイト運営中〜

New Article

index