42
37

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

SwiftでTableViewいろいろ -> No.1

Last updated at Posted at 2016-04-26

#はじめに
Swift初心者です。
複数回にわたってUITableViewについて色々書いて見ます。<-- 備忘録です。

今回は、No.1ということで基本的な部分。
次の2点について書きます。
・セクション分けして表示
・ヘッダー,フッターを表示

#StoryboardでTableViewを配置
まずはTableViewを配置し、更にTableViewCellを配置します。
スクリーンショット 2016-04-27 1.05.00.png

次にTableViewCellのIdentifierを設定します。(ここでは"Cell"としています。)
スクリーンショット 2016-04-27 1.00.36.png

#Source Code
1.Model.swift
UITableViewDataSource,UITableViewDelegateの実装

Model.swift
import Foundation
import UIKit

class Model: NSObject, UITableViewDataSource, UITableViewDelegate {
    
    let mView = View()

    // セクション名
    var foods = ["Vegetables", "Fruits"]
    
    // セルに表示するテキスト
    var vegetables = ["Pumpkin", "Cabbage", "Potato", "Ginger", "Onion", "Carrot", "Garlic"]
    var fruits = ["Apple", "Strawberry", "Cherry", "Banana", "Grape", "Peach", "Melon"]
    
//MARK:UITableViewDataSource
    
    /**
     テーブルビューのセクション数を返すメソッド
     */
    func numberOfSectionsInTableView(tableView: UITableView) -> Int {
        return foods.count;
    }
    
    /**
     セクション毎のタイトルをヘッダーに表示
     */
    func tableView(tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
        return foods[section]
    }
    
    /**
     セクション毎のセル数を指定するメソッド
     */
    func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        switch section {
        case 0:
            return vegetables.count
        case 1:
            return fruits.count
        default:
            return 0
        }
    }
    
    /**
     セルの内容を変更するメソッド
     */
    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        
        // Storyboardで設定したIdentifierでUITableViewCellのインスタンスを生成
        let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath)
        
        // StoryboardでCellを作成しない場合
        // let cell: UITableViewCell = UITableViewCell(style: UITableViewCellStyle.Subtitle, reuseIdentifier: "Cell")
        
        // セルにテキストを設定
        switch indexPath.section {
        case 0:
            cell.textLabel?.text = vegetables[indexPath.row]
        case 1:
            cell.textLabel?.text = fruits[indexPath.row]
        default:
            break
        }
        
        return cell
    }
    
//MARK:UITableViewDelegate
    
    /**
     Footerを設定するメソッド
     */
    func tableView(tableView: UITableView, viewForFooterInSection section: Int) -> UIView? {
        return mView.createFooterLabel()
    }

}

2.View.swift
フッターに表示するView

View.swift
import Foundation
import UIKit

class View : UIView {
    
    func createFooterLabel() -> UILabel {
        let footerLabelSize = CGRectMake(0, 0, 200, 20)
        let footerLabelText = "FooterFooter"
        
        let footerLabel = UILabel(frame: footerLabelSize)
        footerLabel.text = footerLabelText
        footerLabel.textAlignment = .Center
        footerLabel.backgroundColor = UIColor.cyanColor()
        
        return footerLabel
    }
    
}

3.ViewController.swift
コントローラ

ViewController.swift
import UIKit

class ViewController: UIViewController {

    @IBOutlet weak var tableView: UITableView!
    let mModel = Model()
    
//MARK:UIViewController
    override func viewDidLoad() {
        super.viewDidLoad()
        tableView.dataSource = mModel
        tableView.delegate = mModel
    }
    
    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }
}

#実行結果
Simulator Screen Shot 2016.04.27 2.03.19.png

#最後に
今回は、
TableViewの基本的な実装として
・セクション分けして表示
・ヘッダー,フッターを表示
について記載しました。

次回は、
・セルの右側にチェックマーク等のマークを表示
・タップ時のイベント処理の実装
について記載しようと思っています。

42
37
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
42
37

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?