【Swift UIKit】UITableViewCellでセルの高さを変更する方法!固定値と可変値

この記事からわかること

  • SwiftUIKitリスト実装する方法
  • UITableViewCellセル高さ変更する方法
  • rowHeightプロパティtableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath)使い方
  • estimatedRowHeightとは?
  • UITableView.automaticDimensionとは?

index

[open]

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

みんなの誕生日

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

posted withアプリーチ

SwiftのUIKitでUITableViewCellのセルの高さを変更する方法をまとめていきます。UITableViewの使用方法については下記記事を参考にしてください。

UITableViewCellのセルの高さを変更する方法

【Swift UIKit】UITableViewの使い方!リストの作成方法

UITableViewCellのセルの高さを変更する方法は2種類あります。

  1. UITableViewのrowHeightプロパティに値を格納する
  2. UITableViewDelegateプロトコルに準拠させデリゲートメソッドを実装する

rowHeightプロパティに値を格納

StoryboardのTable Viewをコード内の変数と@IBOutletを使って紐付けることで、UITableViewrowHeightプロパティの値を変更することができます。

class ListLocatorViewController:UIViewController ,UITableViewDataSource, UITableViewDelegate {

    @IBOutlet  weak var tableView: UITableView!

    override func viewDidLoad() {
        super.viewDidLoad()
        tableView.rowHeight = 100
    }
}

UITableViewDelegateプロトコルに準拠させデリゲートメソッドを実装

TableViewのView ControllerがUITableViewDelegateプロトコルに準拠させている場合は、func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath)デリゲートメソッドを使用することでセルの高さを変更することができます。最終的に設定したい数値を返せばOKです。

class ListLocatorViewController:UIViewController ,UITableViewDataSource, UITableViewDelegate {

    @IBOutlet  weak var tableView: UITableView!

    override func viewDidLoad() {
        super.viewDidLoad()
    }

    func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        return 100
    }
}

セルの高さを可変的に設定する

セルの高さを固定値ではなく、文字量などによって自動計算されるようにするには以下の2つのプロパティに値を設定します。

estimatedRowHeightプロパティ

セルの高さの推定値を設定するプロパティ。設定しておくと自動計算でのパフォーマンスを向上させることができます。

UITableView.automaticDimension

セルの高さを自動計算するように設定する値。

override func viewDidLoad() {
    super.viewDidLoad()
    tableView.estimatedRowHeight = 50
    tableView.rowHeight = UITableView.automaticDimension
}

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

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

searchbox

スポンサー

ProFile

ame

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

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

自作iOSアプリ

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

mapping

自分だけの地図を作ろう!-mapping-

無料posted withアプリーチ

割り勘アプリ-bill-

旅行におすすめ!
割り勘アプリ-bill-

無料posted withアプリーチ

Imakoko

現在地を取得するアプリ!Imakoko

無料posted withアプリーチ

ふるログ

ふるさと納税管理アプリ-ふるログ-

無料posted withアプリーチ

Remind-シンプル通知アプリ-

シンプル通知アプリ-Remind-

無料posted withアプリーチ

CLIPURL

好きな記事をクリップしよう!-CLIPURL-

無料posted withアプリーチ

記録カレンダー

続けたを可視化できるアプリ!記録カレンダー

無料posted withアプリーチ

CART-共有できるお買い物リスト-

CART-共有できるお買い物リスト-

無料posted withアプリーチ

QuickPressPanel

早押しゲーム-QuickPressPanel-

無料posted withアプリーチ

貸し借り管理アプリ

友達とのお金の管理-貸し借り管理アプリ-

無料posted withアプリーチ

みんなの誕生日

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

posted withアプリーチ

Githubにて
iOSアプリのソースコードを公開中!

自作Webアプリ

子育て知識共有サイト-mikata-

子育て知識共有サイト-mikata-

New Article

index