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

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

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

Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。

Q&A

解決済

1回答

2938閲覧

TableViewCellをカスタムしAutoLayoutでViewオブジェクトを整えた際に上部番号の位置が不安定になる

kaji

総合スコア648

Swift 2

Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。

0グッド

0クリップ

投稿2016/07/04 14:39

編集2016/07/05 01:18

storyboard内のAutolayoutはこのように5つ設定してます。
それぞれのオブジェクトの高さ間隔のみAutolayoutで追加してます。
イメージ説明

番号の高さが不揃いになってます。
本来であれば番号ラベルは緑ラベルと同じY位置になるはずなのですが・・
68,73,79,80が上ずってます。他は正常な位置です。
イメージ説明

TableViewメソッド内でcellのラベルにデータを入れてます。
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCellWithIdentifier("TestTableViewCellId") as! TestTableViewCell
cell.titleLabel.text = "ラベル1"
cell.textbodyLabel.text = _data["text"]
cell.numLabel.text = _data["num"]
cell.textbodyLabel.numberOfLines = 0; // 複数行
cell.textbodyLabel.sizeToFit()
return cell
}

何が悪いのでしょうか?

追加20160705 0:19
イメージ説明

追加20160705 10:19
番号ラベルの上部にもAutolayoutを設置してます。
イメージ説明

番号ラベルのY座標にばらつきがあります。
イメージ説明

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

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

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

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

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

guest

回答1

0

ベストアンサー

数字ラベルグリーンのラベルを同時に選択して、それぞれの上揃え(Top Edges)、or 中央揃え(Vertical Center)の制約を付け加えると揃うと思います。

例は2つのラベルの中央揃え(Vertical Center)
image

プロジェクト

以下にサンプルプロジェクトを置きました、ダウンロードして確認してみてください。
teratail_40075

i

投稿2016/07/04 15:12

編集2016/07/05 12:50
_Kentarou

総合スコア8490

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

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

kaji

2016/07/04 15:27 編集

中央揃え(Vertical Center)の制約を付けましたところ、ラベル同士が揃いました。 ただ、番号ラベルと緑のラベルも一緒に高さが不安定になってます。 (TableViewCellの上辺と番号ラベルの間が各Cellで広かったり狭かったり) これを直す方法ありませんでしょうか? 上に画像を追加しました。
_Kentarou

2016/07/04 21:38

番号ラベルの上の制約が固定で入っているのなら、上からの距離は一定になり不安定になることは無いと思います。 そもそもですがセルにImageViewがのっていると思いますが、こちらは表示されなくてよいのでしょうか? ※縦の制約だけで無く全ての部品の各方向の制約をいれた方が良いと思います。
kaji

2016/07/05 01:23 編集

番号ラベルの上の制約は追加した画像にある通り入ってます。(これは投稿初回から入れてます。) ImageViewを3つ消すと番号ラベルのAutoLayoutはうまくいきました。 しかし、 やりたいこととして投稿にImageデータがある場合は3つまで表示するというような 処理をしたいのでImageViewを3つ設置してます。 全Cellにダミーで画像を入れた状態で 確認しましたがやはり番号のLabelのy座標にブレがありました。 追加で、番号ラベルと、緑ラベル、本文ラベルの左右に制約を入れました。 画像の左右に制約を入れたところ画像が上下にひしゃげてしまったので制約を入れてません。 また、3番目の画像の下側の制約入れてません。
_Kentarou

2016/07/05 12:52

サンプルプロジェクトを作成しまいした(回答に記述)、おおよそのやりたいことは出来ていると思います。 確認してみてください。
kaji

2016/07/24 01:24

サンプルまで作っていただきありがとうございます。 DLしてみたところうまく動きました。 サンプルと比較しながら修正していきたいと思います。 _Kentarouさんありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問