micomia株式会社の井上です。今回はDesign Systemについて解説していきます。
初心者にも分かりやすく解説していくのでぜひご一読ください。
1. Design Systemとは
Design Systemとは、簡単にまとめるとアプリのUIを統一されたデザインで作るためのパーツやスタイルの集合になっています。
Design Systemを使用することで画面ごとの色、文字、ボタンが統一されたり、複数人で開発してもUIが崩れにくいなどのメリットがあります。
2. Design Systemの詳細
Design SystemはTheme Settingsにあります。

まず1つ目のBreakpointsはどこからどこまでの画面幅がモバイル扱いで、どこからどこまでの画面幅がタブレット扱いなのかを決められますが、この部分は基本的に変更する必要は無いと考えています。

次にLoading Indicatorです。ロード中のアイコン(Previewに表示されているもの)に関する設定をすることができます。

デフォルトはよくあるCircularですが、たくさんの種類の中から選んでカラーやサイズも変更することができます。


次に、Scrollbar Themeです。これはスクロール時に端に表示されるバーに関する設定をすることができます。

例えば、カラーを赤に設定してみるとこのように色が変わります。

その下にあるThicknessはバーの太さを、Border Radiusは角の丸みを、Main Thumb Lengthはつまみの長さを、Main Axis Marginは上下(横向きなら左右)の余白を、Cross Axis Marginはコンテンツとバーとの間隔を設定できます。

Thumb Always VisibleはONにするとスクロールバーが縦でも横でも常に表示されるようになります。

Horizontal Scrollbar Always Visibleは横のスクロールバーだけ常に表示されるようになります。
その下のInteractiveはONにするとスクロールバーのつまみをドラッグして動かせるようになります。
次に、Pull to Refresh Styleは引っ張った時に更新する表示に関する設定できます。

例えば、このようにColor, Background Color, Border Widthを変えることができます。

一番下にあるMaterial ThemeはFlutterで用意されているMaterial 3を使用するかどうかに関する設定ですが、Material 3にするとかなりUIが変わるので基本的にOFFのままで良いと考えています。

3. さいごに
今回はDesign Themeについて解説していきました。機能実装ではないものの、実装の基盤となる重要な部分なのでぜひ本記事を参考にして設定してみてください。
本記事の内容を動画で見たい方は以下もご覧ください。


.webp%3Falt%3Dmedia%26token%3Da7c14698-1b08-4fea-89c6-f77a9121f4c5&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D899eeefd-f4c9-44a6-9ec2-3ced0b223ffd&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3Dca25fa6b-e233-43f7-90c3-e68e4c5b0bc5&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D7f18e5f1-cfda-4148-ab86-b3d2e6547262&w=3840&q=75)




.webp%3Falt%3Dmedia%26token%3D6ca2c2ef-9413-4453-b992-55b66b11ed54&w=3840&q=75)



.webp%3Falt%3Dmedia%26token%3D900f385d-12a2-449b-8d1e-83a57cef0088&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D0e802fb0-2dda-44a7-bf80-5d39019635ba&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D3fb3dc66-ecca-402e-8fb8-fbec9407f7f5&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3Ddb21d760-e1ed-4ec2-af28-3462041e31b5&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3Dcce7bd72-f11e-4292-86bf-e6ccf3e7bf32&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D457ff920-e0df-4ff5-95eb-e29f74b73823&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3Dc21fcc77-7404-458d-9eb5-85b8d84ae1bc&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D92052f12-5280-49df-877a-b514582e95db&w=3840&q=75)