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

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

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

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

Q&A

解決済

1回答

512閲覧

UIToolbarのスムーズな消し方について

thirdesr34

総合スコア36

Swift

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

0グッド

0クリップ

投稿2018/12/22 23:39

前提

Swift 4.2でiOSアプリを作成しています。
StoryboardでUIViewの中にUIToolbarを置き、Auto Layoutで下部に張り付くようにしました。

イメージ説明
イメージ説明

実現したいこと

UINavigationbarの場合、setNavigationBarHiddenでスムーズに非表示・再表示を切り替えることができますが、それと同様にUIToolbarの表示を切り替えたいと思いました。

UIToolbar.isHiddenでは瞬時に表示・非表示が切り替えられてしまうので、UIView.animateメソッドでアニメーションすればよいかと思いますが、Auto Layoutを利用しているため、UIToolbarを画面外へスライドして非表示・表示を切り替えるには、コード上どのようにレイアウトの制約を変更すればよいか教えてください。

宜しくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

BottomのConstraintに名前を付けてやって、隠すときはConstant値をtoolBar.frame.size.height + view.safeAreaInsets.height にすればいいです。
Constraintのconstantを設定した後、UIView.animateの中でlayoutIfNeededを呼んで強制的に再レイアウトすることでアニメーションします。こちらが参考になるかと。
回転をサポートする場合はiPhoneXとかだとSafeInsetの値が変わるので、アニメーションが終わったら非表示にするか、フェードとと組み合わせてごまかしたりする必要があると思います。

投稿2018/12/23 10:09

toki_td

総合スコア2850

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

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

thirdesr34

2018/12/24 09:52 編集

有難うございました。大変助かりました。 下記のようなコードでアニメーションできました。 self.view.layoutIfNeeded() if(self.isToolbarsHidden) { //Unhide Bars self.bottomBarConstraintNormal.constant = 0; } else { //Hide Bars self.bottomBarConstraintNormal.constant = 44; } UIView.animate(withDuration: 0.5, animations: { self.view.layoutIfNeeded() }); self.isToolbarsHidden = !self.isToolbarsHidden; (尚、他のビューの制約をUIToolbarのAnchorに固定しているとそのビューの変更がアニメーションされないため、改めて別の質問を立てたいと思います。)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問