7
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

【SwiftUI】カスタムダイアログの表示と管理

Last updated at Posted at 2021-06-18

【SwiftUI】 Manage Custom Dialogs

Goal

  • カスタムViewを作成しそれをダイアログとして表示する
  • 複数のダイアログを表示できるようにする

Background

SwiftUIではAlertを利用することで標準のアラートを表示することができます。
しかし、UIKitを用いて開発していたときのように独自のViewをダイアログとして表示したいことがあります。
また、1つの画面で複数パターンのダイアログを表示することもあるでしょう。
そのような要件を満たすものを紹介します。

Demo

今回作成するものは次のようになります。
全体のコードは最後にありますので参考にして下さい。

Simulator Screen Recording - iPhone 12 - 2021-05-25 at 17.32.12.gif

Content Pattern

まず、カスタムダイアログViewを作成します。
(後でダイアログの背景を透過する処理を共通で入れるので、その部分は不要です)

Viewを継承したパーツです。

carbon.png

そしてこれらをまとめたEnumを作成します。
こうすることでアプリ内でカスタムダイアログを利用するケースを一覧で見られるようになり、また特定のケースでViewを差し替えることも容易です。

carbon2.png

caseの命名がcontentDetail01のようになっていますが、実際にはより詳細な命名が良いと思います。簡単化のためにそうしています。)

Manage Dialog Presentation

次にダイアログの表示を制御するクラスを作成します。

  • 表示フラグの更新
  • 表示するコンテンツの設定

を担います。

carbon3.png

ダイアログを表示するViewからはshowメソッドを利用して任意のコンテンツを表示します。

Custom Dialog Modifier

カスタムダイアログをViewModifierを経由して表示します。
これはこちらの記事: Custom View Dialog in SwiftUI | Swift UI recipesを参考にしています。

  • ViewModifiewで元のコンテンツの上にカスタムダイアログを表示する
  • 画面全体を覆う、黒の透過色を配置することでダイアログ風のUIにする

というのが主な点です。

carbon4.png

Set Up

以上で要素が揃いました。
Viewでダイアログを表示してみましょう。

carbon5.png

ViewではDialogPresentationを保持します。

 dialogPresentataion.show(
                    content: .contentDetail01(isPresented: $dialogPresentataion.isPresented))

のようにしてダイアログを表示します。
ダイアログ側で閉じるボタンを押した時にフラグを更新するので、isPresentedを渡しています。

Summary

ダイアログ表示の責務を持つ管理クラスを作成することで、ダイアログを表示する際の処理を隠蔽し、また複数の表示パターンに対応することができました。

より良い方法、問題点等ありましたら気軽にコメント頂けると幸いです。

コード全体はこちら

References

7
5
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
7
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?