iOS/UIKit
[UIKit] : CollectionView 생성, Cell 등록하기
SeorinY
2022. 9. 2. 16:26
정말 많이 사용되는 CollectionView 를 띄워보자.
Collection View 를 생성하기 전에 먼저 CollectionView 에서 사용될 Cell 을 만들어보자
UICollectionViewCell를 상속받는 Cell을 생성해주자.
그리고 알 수 있게 배경화면을 파란색으로 설정해주자
class CollectionViewCell: UICollectionViewCell {
static let identifier = "CollectionViewCell"
override init(frame: CGRect) {
super.init(frame: frame)
//Cell에서는 View대신 ContentView를 사용한다
contentView.backgroundColor = .blue
}
required init?(coder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
}
이제 CollectionView를 사용할 ViewController에서 CollectionView를 생성하고, Layout 설정해주자.
class ViewController: UIViewController{
//collectionView를 생성해주자
private var collectionView : UICollectionView?
override func viewDidLoad() {
super.viewDidLoad()
configureCollectionView()
}
private func configureCollectionView(){
let layout = UICollectionViewFlowLayout()
layout.scrollDirection = .vertical
layout.itemSize = CGSize(width: 50 , height:50)
layout.sectionInset = UIEdgeInsets(top: 10, left: 10, bottom: 10, right: 10)
//위 layout들로 UICollectionView를 생성해주자
collectionView = UICollectionView(frame: .zero, collectionViewLayout: layout)
collectionView?.backgroundColor = .systemBackground
//collectionView에서 사용하고 싶은 cell을 identifier를 사용하여 등록해주자!!
collectionView?.register(CollectionViewCell.self, forCellWithReuseIdentifier: CollectionViewCell.identifier)
collectionView?.delegate = self
collectionView?.dataSource = self
guard let collectionView = collectionView else {
return
}
view.addSubview(collectionView)
}
override func viewDidLayoutSubviews() {
super.viewDidLayoutSubviews()
collectionView?.frame = view.bounds
}
}
이제 ViewController 에 나타낼 CollectionView의 cell 과 section, item 수를 정해주자!
collectionViewDelegate 를 사용해서 나타내자
extension ViewController : UICollectionViewDelegate, UICollectionViewDataSource{
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
5
}
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
guard let cell = collectionView.dequeueReusableCell(withReuseIdentifier: CollectionViewCell.identifier, for: indexPath) as? CollectionViewCell else { return UICollectionViewCell() }
return cell
}
func numberOfSections(in collectionView: UICollectionView) -> Int {
return 3
}
}
그림처럼 3개의 섹션 안에 5개의 아이템을 넣어줬다.
이제 실행하면 위의 결과처럼 잘 나올 것이다!
전체코드
import UIKit
class ViewController: UIViewController{
//collectionView를 생성해주자
private var collectionView : UICollectionView?
override func viewDidLoad() {
super.viewDidLoad()
configureCollectionView()
}
private func configureCollectionView(){
let layout = UICollectionViewFlowLayout()
layout.scrollDirection = .vertical
layout.itemSize = CGSize(width: 50 , height:50)
layout.sectionInset = UIEdgeInsets(top: 10, left: 10, bottom: 10, right: 10)
//위 layout들로 UICollectionView를 생성해주자
collectionView = UICollectionView(frame: .zero, collectionViewLayout: layout)
//알 수 있게 배경색을 노란색으로 정해주자
collectionView?.backgroundColor = .systemBackground
//collectionView에서 사용하고 싶은 cell을 identifier를 사용하여 등록해주자!!
collectionView?.register(CollectionViewCell.self, forCellWithReuseIdentifier: CollectionViewCell.identifier)
collectionView?.delegate = self
collectionView?.dataSource = self
guard let collectionView = collectionView else {
return
}
view.addSubview(collectionView)
}
override func viewDidLayoutSubviews() {
super.viewDidLayoutSubviews()
collectionView?.frame = view.bounds
}
}
extension ViewController : UICollectionViewDelegate, UICollectionViewDataSource{
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
5
}
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
guard let cell = collectionView.dequeueReusableCell(withReuseIdentifier: CollectionViewCell.identifier, for: indexPath) as? CollectionViewCell else { return UICollectionViewCell() }
return cell
}
func numberOfSections(in collectionView: UICollectionView) -> Int {
return 3
}
}
class CollectionViewCell: UICollectionViewCell {
static let identifier = "CollectionViewCell"
override init(frame: CGRect) {
super.init(frame: frame)
//Cell에서는 View대신 ContentView를 사용한다
contentView.backgroundColor = .blue
}
required init?(coder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
}