Why not login to Qiita and try out its useful features?

We'll deliver articles that match you.

You can read useful information later.

0
0

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 1 year has passed since last update.

collectionViewCellにチェックマークをつける

Last updated at Posted at 2023-02-05

はじめに

今日できた実装の記録として書いているので説明はざっくりとしてます
これから少しずつ直したり,補足したりしていきます!
言語はSwiftで,Xcodeのバージョンは14.0.1です
collectionViewの実装ができていることを前提にして書いていきます〜

1. 新しくUICollectionViewCellがサブクラスのファイルをつくる

① 写真のようにフォルダマークの項目の上を指2本でクリック→New File(新規ファイル)をクリック

IMG_5691.PNG

② 写真のとおりに選択してNext

スクリーンショット 2023-02-05 22.23.18.png

③ 写真のとおりに設定してNext → その後表示されるウィンドウの右下のCreateクリック

スクリーンショット 2023-02-05 22.24.44.png

2. CustomCellファイルに書き込む

「1. 新しくUICollectionViewCellがサブクラスのファイルをつくる」で作ったファイルにプログラムを書いていきます

準備: チェックマークの画像をネットで見つけて保存 → XcodeのAssetに入れる

画像の形を正方形にしておくこと!(あとでチェックマークの大きさを調整する時に楽)

① 以下のプログラムを書く

Swift
import UIKit

class CustomCell: UICollectionViewCell {
    let checkmarkImage: UIImage = UIImage(named: "check")!
    var checkmarkView: UIImageView!
    var isMarked: Bool = false {
        didSet {
            if isMarked {
                checkmarkView.frame = CGRectMake(-7,0,35,25) //チェックマークの設定
                self.contentView.addSubview(self.checkmarkView!)
            } else {
                self.checkmarkView?.removeFromSuperview()
            }
        }
    }
    func clearCheckmark() -> Void {
        self.isMarked = false
    }
    
    override init(frame: CGRect) {
        super.init(frame: frame)
        self.checkmarkView = UIImageView(image: self.checkmarkImage)
    }
    
    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
}
  • let checkmarkImage: UIImage = UIImage(named: "check")!の""内はXcodeに取り込んだ画像の名前です
  • チェックマークの設定とコメントしている行でチェックマークを表示させる位置と大きさを設定します
    • CGRectMake(x座標, y座標, 横幅, 縦幅)だったはず

3. ViewControllerのファイル(collectionViewの宣言をしているファイル)にプログラムを書く

① クラスがUICollectionViewDelegateも継承するようにする

class MemoCollectionViewController: UIViewController, UICollectionViewDataSource, UICollectionViewDelegate {

みたいな感じ

override func viewDidLoad(){}の{}の中に下4行のプログラムを書く

collectionView.register(CustomCell.self, forCellWithReuseIdentifier: "Cell")
collectionView.delegate = self
self.view.addSubview(collectionView)
self.collectionView.allowsMultipleSelection = true

override func viewDidLoad(){}の後ろに以下のプログラムを書く

// Cell がタップで選択されたときに呼ばれる
    func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
        guard let cell: CustomCell = collectionView.cellForItem(at: indexPath) as? CustomCell else { return }
        if self.collectionView.allowsMultipleSelection {
            cell.isMarked = true
        }
    }
        
    // Cell がタップで選択解除されたときに呼ばれる
    func collectionView(_ collectionView: UICollectionView, didDeselectItemAt indexPath: IndexPath) {
        guard let cell: CustomCell = collectionView.cellForItem(at: indexPath) as? CustomCell else { return }
        if self.collectionView.allowsMultipleSelection {
            cell.isMarked = false
        }
    }
おしまい!

完成イメージ

スクリーンショット 2023-02-05 22.45.09.png

参考にしたサイト

おわりに

次はcollectionViewCellをスワイプすることでそのCell自体を削除する機能を作ろうと思ってます
最後まで読んでいただきありがとうございました!

0
0
0

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
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?