data:image/s3,"s3://crabby-images/1fe21/1fe21d9d936a4d2a65f350f8387dc831c3b3246f" alt=""
flutter_neumorphic ? どんなパッケージなんだろう?
data:image/s3,"s3://crabby-images/46e90/46e90cbf7b68ef62b290e99bd7f6f808acadc4ea" alt=""
おしゃれなUIを作ってみたいわ!
本記事ではそんな疑問、要望にお答えします。
立体的で質感のあるデザインスタイル、ニューモーフィズムで
UIを構築するのに有用なパッケージ、flutter_neumorphic の使い方を解説します。
以下のようなUI を実装することが簡単に可能です。
data:image/s3,"s3://crabby-images/6ddf9/6ddf9a5bf59bfd428518ec492c3f32e1577967d5" alt=""
ぜひ本記事を読んで実装してみて下さい!
基本的な使い方
data:image/s3,"s3://crabby-images/264e6/264e610e45487819ebe97049ff1b6c9dc838ae85" alt=""
パッケージのインストール
CLI(macならターミナル)で、自分のプロジェクトのルートにて
以下のコマンドを実行しパッケージをインストールします。
flutter pub add flutter_neumorphic
パッケージのインポート
UIを構築するDartファイルの上部に以下のインポート文を追加し、
パッケージをインポートします。
import 'package:flutter_neumorphic/flutter_neumorphic.dart';
Widget の設定
flutter_neumorphicには様々なボタンやTextField
など、さまざまなWidget
が用意されています。
どんなWidgetが用意されているかについては、
以下のパッケージ紹介ページをご確認ください。
data:image/s3,"s3://crabby-images/6e29f/6e29f56e4514bc48b64941e41d3a91e80a974cd7" alt=""
本記事ではflutter_neumorphicの基本Widget 、Neumorphic Widget
について紹介します。
使い方は簡単で、ニューモーフィズムを実装したいContainer
やSizedBox
をNewmorpic
Widget
で囲うだけです。
import 'package:flutter_neumorphic/flutter_neumorphic.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return const MaterialApp(
home: MyWidget(),
);
}
}
class MyWidget extends StatelessWidget {
const MyWidget({super.key});
@override
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: Colors.black12,
body: Center(
child: Neumorphic(
child: const SizedBox(
height: 100,
width: 100,
child: Center(
child: Text('Hello World'),
),
),
),
),
);
}
}
data:image/s3,"s3://crabby-images/6ddf9/6ddf9a5bf59bfd428518ec492c3f32e1577967d5" alt=""
色や深さ、光の当たり方向はstyle
にNeumorphicStyle
を
設定することによって調整することが可能です。
色
色の調製例のコードです。NeumorphicStyle
Neumorphic(
style: NeumorphicStyle(
color: Colors.green[100],
),
child: const SizedBox(
height: 100,
width: 100,
child: Center(
child: Text('Hello World'),
),
),
),
data:image/s3,"s3://crabby-images/a515a/a515a78293dea208df0d443e4641498fcf46de91" alt=""
深さ
depth プロパティに-20 ~ 20の値を設定することで、
でっぱり具合(へこみ具合)を調整することができます。
以下は-20を設定した場合の例です。
Neumorphic(
style: const NeumorphicStyle(
depth: -20,
),
child: const SizedBox(
height: 100,
width: 100,
child: Center(
child: Text('Hello World'),
),
),
),
),
data:image/s3,"s3://crabby-images/a37f4/a37f4149443be696ecc4ed2e4718e5337f287cee" alt=""
光の方向
デフォルトは左上から光が当たっている形となっていますが、
この光の方向をlightSource
プロパティにLigthtSource
を設定することで
変更することが可能です。
以下の例では右上からに変更を行っています。
Neumorphic(
style: const NeumorphicStyle(
lightSource: LightSource.topRight,
),
child: const SizedBox(
height: 100,
width: 100,
child: Center(
child: Text('Hello World'),
),
),
),
data:image/s3,"s3://crabby-images/8bd4d/8bd4d2fd745cb1a76067b7b4ba4c61c4ec0c8b2a" alt=""
おまけ ニューモーフィズムなWidgetの作り方
data:image/s3,"s3://crabby-images/e6c5f/e6c5f4106bf1ba81c3a5356f8c7eaa22c01b49d9" alt=""
data:image/s3,"s3://crabby-images/e5a59/e5a5982cf1c71fe2e4387ca64f15f842ff253b7c" alt=""
ニューモーフィズムなWidget
をパッケージに依存せずに作りたい!
そんな人向けに、ニューモーフィズムなWidgetの作り方を紹介します。
ポイントは影の付け方です。
光源が左上にあるとして、左上側は明るく、右下側は暗く影をつけると、
ニューモーフィズムに見えるWidgetとなります。
実装例は以下となります。
Container(
height: 100,
width: 100,
decoration: BoxDecoration(
color: Colors.grey[300],
borderRadius: BorderRadius.circular(20),
boxShadow: [
//1
BoxShadow(
color: Colors.grey[500]!,
blurRadius: 15,
offset: const Offset(5, 5),
),
//2
const BoxShadow(
color: Colors.white,
blurRadius: 15,
offset: Offset(-5, -5),
),
],
),
child: const Center(
child: Text('Hello World'),
),
),
//1
右下に影をつけている部分です。offset
で右下にずらしています。
//2
左上に光が当たっている表現として明るい色を設定している部分です。
offsetで左上にずらし、whiteを設定しています。
このコードで以下のような見た目となります。
data:image/s3,"s3://crabby-images/590d4/590d4448c17c73a207c96581e0dc80e088cf606b" alt=""
以上が、パッケージに依存すること無くニューモーフィズムを実装する方法でした!
まとめ
data:image/s3,"s3://crabby-images/f55ee/f55ee8d294001be1042e76e9d5d4d9934c2739fe" alt=""
本記事では、ニューモーフィズムで
UIを構築するのに有用なパッケージ、flutter_neumorphic の使い方を解説しました。
いかがだったでしょうか?
ニューモーフィズムでUIを構築してみたくなりましたか?
本記事で紹介したように、簡単におしゃれなデザインを実装できるようになるため、
ぜひ使用を検討してみて下さい!
参考
編集後記(2022/7/1)
Flutterでニューモーフィズムを実装する方法についての記事でした。
そもそも、ニューモーフィズムとは?となる方がいらっしゃるかもしれません。
ニューモーフィズムは「new」と、同じく立体的な表現の「スキューモーフィズム」の合体による造語で、「スキューモーフィズム」をより現代的にしたもの、ということです。
参考:
data:image/s3,"s3://crabby-images/add8f/add8f34cc55b7b3604628cd8f6f29132494fa225" alt=""
このようなデザイン手法について学んでみるのも面白いかもしれませんね。
週刊Flutter大学では、Flutterに関する技術記事、Flutter大学についての紹介記事を投稿していきます。
記事の更新情報はFlutter大学Twitterにて告知します。
ぜひぜひフォローをお願いいたします。