カレンダー表示のように、垂直方向と水平方向でスクロールする Viewを実現する方法で比較的簡単なものが UITableViewと CollectionViewの組み合わせで実現する方法だと思う。簡単なカレンダー表示を実装したサンプルコード。参考程度にどうぞ。
プロジェクトコード一式 → Github.
CollectionView
extension ViewController: UICollectionViewDataSource, UICollectionViewDelegate { func numberOfSections(in collectionView: UICollectionView) -> Int { return 1 } func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int { return self.numberOfDays[collectionView.tag] } func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell{ let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "Cell", for: indexPath) let dayLabel = cell.contentView.viewWithTag(1) as! UILabel let weekLabel = cell.contentView.viewWithTag(2) as! UILabel let formatter = self.getFormatter() let year = formatter.string(for: Date())! formatter.dateFormat = "YYYY/MM/dd" let targetDay = String(format: "%@/%02d/%02d", year, collectionView.tag + 1, indexPath.row + 1) let target = formatter.date(from: targetDay) var calendar = Calendar(identifier: .gregorian) calendar.timeZone = TimeZone(identifier: "Asia/Tokyo")! let weekday = calendar.component(.weekday,from: target!) dayLabel.text = "\(indexPath.row + 1)" weekLabel.text = self.weekLabel[weekday - 1] if weekday == 1 { dayLabel.backgroundColor = UIColor.red dayLabel.textColor = UIColor.white dayLabel.layer.borderColor = UIColor.white.cgColor weekLabel.textColor = UIColor.red } else { dayLabel.backgroundColor = UIColor.white dayLabel.textColor = UIColor.black dayLabel.layer.borderColor = UIColor.black.cgColor weekLabel.textColor = UIColor.black } return cell } func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) { let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "Cell", for: indexPath) let dayLabel = cell.contentView.viewWithTag(1) as! UILabel print(dayLabel.text!) } }
UITableView
extension ViewController: UITableViewDelegate, UITableViewDataSource { func numberOfSections(in tableView: UITableView) -> Int { return 1 } func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return 12 } func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as! CalendarTableViewCell cell.monthLabel.text = "\(indexPath.row + 1)" cell.daysCollectionView.delegate = self cell.daysCollectionView.tag = indexPath.row return cell } func tableView(_ tableView: UITableView,didSelectRowAt indexPath: IndexPath) { self.tableView.deselectRow(at: indexPath, animated: true) } }
- 投稿タグ
- Swift