プログラムを書こう!

実務や自作アプリ開発で習得した役に立つソフトウェア技術情報を発信するブログ

SwiftでXLFormのセグメントコントロールを使用する。

この記事は2018年11月11日に投稿しました。

f:id:paveway:20190914064630j:plain

目次

  1. はじめに
  2. 前提
  3. XLFormのセグメイントコントロールを使用する
  4. おわりに

絶対に挫折しないiPhoneアプリ開発「超」入門 増補第6版【Swift 4 & iOS 11】完全対応 (Informatics&IDEA)

絶対に挫折しないiPhoneアプリ開発「超」入門 増補第6版【Swift 4 & iOS 11】完全対応 (Informatics&IDEA)

1. はじめに

こんにちは、iOSのエディタアプリPWEditorの開発者の二俣です。
今回はPWEditorで使用しているXLFormライブラリのセグメントコントロールの使用方法です。

目次へ

2. 前提

この記事を参考にXLFormを使用できるようにしておいてください。

paveway.hatenablog.com

目次へ

3. XLFormのセグメントコントロールを使用する

この記事を参考にViewControllerを実装してください。

paveway.hatenablog.com

ボタンセル(row)の部分を、今回のセグメントコントロールのセルに差し替えてください。

/**
 セグメントコントロールのセルを作成します。
 */
func createSegmentControlRow() -> XLFormRowDescriptor {
    // タグを設定します。
    // 設定値は任意の文字列でかまいませんが、一意の文字列にしてください。
    let tag = "segmentControl"

    // XLFormRowDescriptorTypeをセグメントコントロールとします。
    let rowType = XLFormRowDescriptorTypeSelectorSegmentedControl

    // タイトルは表示できないので空文字列を指定します。
    let title = ""
    
    // セグメントコントロールのセルを作成します。
    let row = XLFormRowDescriptor(tag: tag, rowType: rowType, title: title)

    // セグメントコントロールに表示する項目を設定します。
    // 例ではフォントタイプを設定しています。
    var fontTypeList = [String]()
    fontTypeList.append("標準")
    fontTypeList.append("斜体")
    fontTypeList.append("太字")
    fontTypeList.append("太字斜体")

    // 選択オプションオブジェクトリストを作成します。
    var selectorOptions = [XLFormOptionsObject]()
    let count = fontTypeList.count
    for i in 0 ..< count {
        // 選択オプションオブジェクトは、表示名がフォントタイプ、値は0からの連番にしています。
        let title = fontTypeList[i]
        guard let option = XLFormOptionsObject(value: i, displayText: title) else {
            continue
        }
        selectorOptions.append(option)
    }
    row.selectorOptions = selectorOptions

    // 先頭が選択された状態にします。
    row.value = selectorOptions[0]

    // セグメントコントロールが選択された時の処理を設定する。
    // 選択されたセグメントを選択しても、呼び出されないので注意してください。
    row.onChangeBlock = { oldValue, newValue, rowDescriptor in
        // 選択されたセグメントにより処理を行います。
        guard let newOptionsObject = newValue as? XLFormOptionsObject else {
            return
        }
        let newFormValue = newOptionsObject.formValue()
        guard let newIntValue = newFormValue as? Int else {
            return
        }
        switch newIntValue {
        case 0:
            // 標準の場合
            // 標準が選択された時の処理を記述します。
            break

        case 1:
            // 斜体の場合
            // 斜体が選択された時の処理を記述します。
            break

        case 2:
            // 太字の場合
            // 太字が選択された時の処理を記述します。
            break

        case 3:
            // 太字斜体の場合
            // 太字斜体が選択された時の処理を記述します。
            break

        default:
            // 上記以外
            // 何もしません。
            break
        }
    }
    return row
}

目次へ

3. おわりに

PWEditorでは、フォントインポート画面で選択されたフォントタイプをクリアする時に使用しました。
他のコントロールに比べ、セグメントコントロールは使用箇所を選ぶかもしれません。

エンジニアのためのQ&Aサイト【teratail】

詳細!Swift 4 iPhoneアプリ開発 入門ノート Swift 4+Xcode 9対応

詳細!Swift 4 iPhoneアプリ開発 入門ノート Swift 4+Xcode 9対応

紹介している一部の記事のコードはGitlabで公開しています。
興味のある方は覗いてみてください。

目次へ


私が勤務しているニューラルでは、主に組み込み系ソフトの開発を行っております。
弊社製品のハイブリッドOS Bi-OSは高い技術力を評価されており、特に制御系や通信系を得意としています。
私自身はiOSモバイルアプリウィンドウズアプリを得意としております。
ソフトウェア開発に関して相談などございましたら、お気軽にご連絡ください。

また一緒に働きたい技術者の方も随時募集中です。
興味がありましたらご連絡ください。

EMAIL : info-nr@newral.co.jp / m-futamata@newral.co.jp
TEL : 042-523-3663
FAX : 042-540-1688

目次へ