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

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

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

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

Q&A

解決済

1回答

920閲覧

(Swift)UITextViewのテキスト表示位置や入力開始位置をテキスト内容の最後の文字にする方法

niship

総合スコア37

Swift

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

0グッド

0クリップ

投稿2017/12/07 09:30

いつもお世話になっております。

UITextViewをテキスト内容に応じて高さが可変になるように実装しています。
入力終了後、キーボードを閉じると、テキスト内容が入っていても、入っていなくても、
UITexiViewの高さを元の高さに戻すようにしています。
テキスト内容が入ったままで元の高さに戻すと表示されるテキスト内容が一番最初の行になります。
元の高さに戻した時にテキスト内容の一番最後の行が表示されるようにしたいのですが、方法がわかりません。
また、テキスト内容が入ったまま、キーボードを閉じて、もう一度、UITextViewを選択した際に、入力開始位置(カーソルの位置)を一番最後の文字に合わせたいです。

以下に関連するソースコードを記載いたします。
ご教示頂けますと幸いです。

//messageTextViewのテキスト内容に変化がある度に呼ばれる func textViewDidChange(_ textView: UITextView) { // 入力フィールドの最大サイズ let maxHeight: CGFloat = 100.0 //テキスト内容に応じたぴったしサイズを計算 let size:CGSize = messageTextView.sizeThatFits(messageTextView.frame.size) //最大サイズ以下なら if(size.height <= maxHeight) { //ぴったしサイズをAutoLayoutに代入 _constraintTextViewHeight.constant = size.height } }
// キーボードが現れた時に、画面全体をずらす。 @objc func keyboardWillShow(notification: Notification?) { /* 省略 */ // 入力フィールドの最大サイズ let maxHeight: CGFloat = 100.0 //テキスト内容に応じたぴったしサイズを計算 let size:CGSize = messageTextView.sizeThatFits(messageTextView.frame.size) if(size.height <= maxHeight) { //ぴったしサイズをAutoLayoutに代入 _constraintTextViewHeight.constant = size.height } else {          //最大サイズを超えていれば、100.0を代入 _constraintTextViewHeight.constant = 100.0 } } }
// キーボードが消えたときに、画面を戻す @objc func keyboardWillHide(notification: Notification?) { /* 省略 */ //AutoLayoutを元の高さに戻す self._constraintTextViewHeight.constant = 33 } }

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

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

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

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

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

guest

回答1

0

ベストアンサー

swift

1textView.selectedRange.location = textView.text.utf16.count

これでカーソルを文末まで持っていけます。

投稿2017/12/07 12:41

編集2017/12/12 10:30
xAxis

総合スコア1349

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

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

niship

2017/12/12 06:11

xAxis様 いつもご回答有難うございます。 お礼が遅れまして失礼いたしました。
xAxis

2017/12/12 10:29

いえいえ解決したなら何よりです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問