質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Q&A

1回答

1434閲覧

iOSでGoogleカレンダーのようなセクションを実装する方法について

退会済みユーザー

退会済みユーザー

総合スコア0

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

0グッド

0クリップ

投稿2017/06/28 04:26

iOSアプリでイベントの日程表の開発をしてします。

その際添付した画像のように、左側に日付を、右側にセルのコンテンツを表示したいと考えています。

イメージ説明

日付はセクションとして、スクロールに追随して先頭に表示されることになります。

このようなUIを搭載しているアプリとしてはGooleカレンダーや、このスクリーンショットのSHOWROOMがあります。

今回質問したいことは、どうすればこのようなセクションを実装できるのかということです。

まず思いついたのが、「左側にテキストを寄せてある普通のセクションを実装すること」ですが、そうするとセクションの高さの分だけセルが下に落ちてしまうので格好がつきません。

次にセクションの高さを0にしたらどうだろうかと思ったのですが、そうすると単にセクションがなかったかのように表示されるだけになってしまいます。

一体どうすればGoogleカレンダーアプリのようなセクションを実装できるのでしょうか。

ご回答のほど何卒よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

セクション自体は表示せず、各セクションの先頭セル(row=0)だけに日付を表示すればいいのではないでしょうか?

やり直し

セクション自体の高さは0(には出来ないので1とか)にして、そこからはみ出すように表示したいViewをぶら下げます。

すごく雑ですが、こんな感じ。

swift

1func tableView(_ tableView: UITableView, viewForHeaderInSection section: Int) -> UIView? { 2 let view = UIView() 3 view.backgroundColor = .orange 4 let label = UILabel() 5 label.font = UIFont.systemFont(ofSize: 50) 6 label.text = String(section) 7 label.sizeToFit() 8 view.addSubview(label) 9 return view 10} 11 12func tableView(_ tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat { 13 return 1 14}

分かりやすいように、セクションの高さを1にしてオレンジのラインにしています。
全く表示させたくないなら.clearにすればいいでしょう。(高さ0だとセクションが表示されません)

細かいところを気にしだすとダメかも知れませんが。

投稿2017/06/28 04:35

編集2017/06/28 05:30
fuzzball

総合スコア16731

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/06/28 04:37

回答ありがとうございます。 そうするとスクロールに合わせて日付が追随しないので、日付のセルが画面外に消えたら、それ以降のセルが何日のものか分からなくなってしまうのが懸念点です。
fuzzball

2017/06/28 04:44

なるほど。セクションの「あの」動きをしないとダメなんですね。
fuzzball

2017/06/28 05:30

やり直しました。
退会済みユーザー

退会済みユーザー

2017/06/28 07:18 編集

ありがとうございます。早速試してみました。 ただ高さを1にするとセクション同士が重なってしまって、Googleカレンダーのように下のセクションが上のセクションを押し出すような本来の挙動になりませんでした。 また説明が難しいのですが、例えば下にスクロールした時には下のセクションが上のセクションに被さるものの、反対に上にスクロールすると上のセクションが下のセクションに被さることになり、スクロール方向によって階層が変わってしまうのも違和感があるところです。 おそらくGoogleやSHOWROOMの場合は、本来の高さをそのまま設定しているように感じられますが、そうするとセルの位置が下に下がってしまうので、どうして良いのやらと。
fuzzball

2017/06/28 08:22

セルを上方にずらす方法を試していたのですが色々弊害が出るので断念。 もう自作するしかないですねw
退会済みユーザー

退会済みユーザー

2017/06/28 12:33

実際に試していただいたとのことで、お手数をおかけして申し訳ございません。 承知しました。デフォルトの挙動だと難しいということですね。 回答ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問