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

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

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

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

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

解決済

2回答

2572閲覧

【Swift,Xcode】Labelを動的に可変させながら、ImageViewを表示させたい

nekokichi

総合スコア54

Xcode

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

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

1クリップ

投稿2018/10/29 15:03

編集2018/10/30 05:01

LINEのようなチャットアプリを制作するために、

・Labelを動的に可変させる
・ImageViewをそのままのサイズで表示させる

を同時に実現したいです。

既に別の質問でLabelを動的に可変させることができています。

次は、ImageViewをLabelの横に配置し、ImageViewに様々な制約を付けて、シミュレータで実行したら、

・Labelは動的に変化するが、ImageViewが動的に可変しない
・ImageViewは表示されるが、Labelが動的に可変しない

などの問題が発生しました。

制約なし

イメージ説明

左右上下

イメージ説明

左右上下幅高さ

イメージ説明

上下幅高さ

![イメージ説明

上記のように、制約を変えても、LabelかImageViewのどちらかに問題が生じてしまいます。

どこが原因がご指摘願います!!

※追記
Lableの制約です。
(上下左右幅の5つ)
イメージ説明

※追記2

上左幅高さ

イメージ説明

import

1 2class SecondViewController: UIViewController,UITableViewDelegate,UITableViewDataSource,UITextFieldDelegate { 3 4 @IBOutlet weak var tableView: UITableView! 5 @IBOutlet weak var textField: UITextField! 6 @IBOutlet weak var send: UIButton! 7 8 //メッセを格納する配列 9 var array = [String]() 10 11 override func viewDidLoad() { 12 super.viewDidLoad() 13 14 textField.delegate = self 15 16 tableView.estimatedRowHeight = 68 17 tableView.rowHeight = UITableView.automaticDimension 18 19 } 20 21 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 22 23 return array.count 24 25 } 26 27 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 28 29 let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) 30 31 let label = cell.viewWithTag(1) as! UILabel 32 label.font = UIFont(name: "HiraKakuProN-W3", size: 18) 33 label.numberOfLines = 0 34 label.lineBreakMode = .byCharWrapping 35 label.text = array[indexPath.row] 36 label.layer.cornerRadius = 10 37 38 return cell 39 40 } 41 42 43 //TextFieldでEnterが押された時、 44 func textFieldShouldReturn(_ textField: UITextField) -> Bool { 45 46 //もし入力値があるなら、代入 47 if let _ = textField.text { 48 array.append(textField.text!) 49 } 50 51 //リロード 52 tableView.reloadData() 53 54 //セルが追加される度に自動スクロール 55 DispatchQueue.main.asyncAfter(deadline: .now() + 0.1) { 56 self.tableView.scrollToRow(at: IndexPath(row: self.array.count - 1, section: 0), at: UITableView.ScrollPosition.bottom, animated: true) 57 } 58 59 return true 60 61 } 62 63}

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

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

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

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

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

fuzzball

2018/10/30 00:04

「ImageViewをそのままのサイズで表示させる」の「そのまま」とは具体的にどういうことでしょうか?UIImageのサイズそのままということですか?
fuzzball

2018/10/30 00:07

画像に関しては「左右上下幅高さ」が正解でしょうか?ラベルに関しては「制約なし」と「上下幅高さ」が正解でしょうか?
fuzzball

2018/10/30 00:07

制約を具体的に書いて下さい。
nekokichi

2018/10/30 04:12

Labelに関しては無視してください。この質問においての制約は全てImageViewに対してのものだと思ってください。ImageViewは左右上下幅高さの制約を付けた時、Labelは制約なしの時に表示されている状態を実現したいのです。
fuzzball

2018/10/30 04:27

なぜLabelがImageViewの制約の影響を受けるのでしょうか?影響を受けるということは、Labelの制約にImageViewが関係していると思うのですが。そうであればLabelの制約の情報が必要になりますので書いて下さい。
fuzzball

2018/10/30 04:38 編集

追記された状態の制約に、「ImageViewは左右上下幅高さの制約」を付けてもLabelには影響しないと思うのですが。「制約を具体的に書いて下さい」と質問したのですから、具体的に書いてもらえませんかね?なぜ情報を出し渋るのでしょうか。
nekokichi

2018/10/30 04:46

いえ、Labelに変更を加えず、ImageViewに左右上下幅高さの制約を課しましたが、Labelが可変しません。質問文の中にある状態と変わりません。
guest

回答2

0

過去に似た質問がありました、これ参考になりませんかね?
https://teratail.com/questions/31558

投稿2018/10/30 03:26

harumi

総合スコア407

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

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

nekokichi

2018/10/30 04:54

cellForRowAtに let img = cell.viewWithTag(2) as! UIImageView img.frame = CGRect(x: 0, y: 0, width: 70, height: 66) 1番下に extension UIImage { func resize(size: CGSize) -> UIImage { let widthRatio = size.width / self.size.width let heightRatio = size.height / self.size.height let ratio = (widthRatio < heightRatio) ? widthRatio : heightRatio let resizedSize = CGSize(width: (self.size.width * ratio), height: (self.size.height * ratio)) // 画質を落とさないように以下を修正 UIGraphicsBeginImageContextWithOptions(resizedSize, false, 0.0) draw(in: CGRect(x: 0, y: 0, width: resizedSize.width, height: resizedSize.height)) let resizedImage = UIGraphicsGetImageFromCurrentImageContext() as! UIImage UIGraphicsEndImageContext() return resizedImage } } と入力しましたが、変化なしです。
guest

0

ベストアンサー

ImageViewに左・上・下・幅・高さの制約を付けて(右は付けても付けなくてもいいです)、
ImageViewとLabelの下の制約はEqualではなくGreater Than or Equalにして下さい。
(Priorityは全て1000でいいです)

投稿2018/10/30 04:55

編集2018/10/30 05:36
fuzzball

総合スコア16731

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

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

nekokichi

2018/10/30 05:08

カスタムクラスで実装できないか試してみます。
fuzzball

2018/10/30 05:09

下の制約を追加して、優先(priority)を750にして下さい。
nekokichi

2018/10/30 05:19

変化なしです。 思いついたのですが、 ・Labelの行数がLabelのサイズ以下の場合、ImageViewを優先 ・Labelの行数がLabelのサイズ以上の場合、Labelを優先 という方法は効果ありませんか?
fuzzball

2018/10/30 05:50

回答修正してます。 実際に試したので大丈夫だと思います。
nekokichi

2018/10/30 05:53

ありがとうございます!! 解決しました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問