入力フォームの作り方を毎度忘れてしまうので、思いつく限りのデザイン集を作って、コピペで楽しようよという記事です。師走なので。
デフォルト
data:image/s3,"s3://crabby-images/b76a8/b76a81243f3abdd51a8fb309f083d7df77232827" alt=""
TextFormField(
decoration: const InputDecoration(hintText: 'デフォルト'),
)
背景色あり、フレームあり
data:image/s3,"s3://crabby-images/f7cc3/f7cc352011a8bad70cd96bf29d4d069b74af59ab" alt=""
TextFormField(
decoration: InputDecoration(
hintText: '背景色あり, フレームあり',
hintStyle: const TextStyle(fontSize: 12, color: Colors.green),
fillColor: Colors.green[100],
filled: true,
focusedBorder: OutlineInputBorder(
borderRadius: BorderRadius.circular(16),
borderSide: const BorderSide(
color: Colors.green,
width: 2.0,
),
),
enabledBorder: OutlineInputBorder(
borderRadius: BorderRadius.circular(16),
borderSide: BorderSide(
color: Colors.green[100]!,
width: 1.0,
),
),
),
),
フレームあり、ラベルあり
data:image/s3,"s3://crabby-images/2b363/2b363b5e304d7ecd0ff8d38eb94d5768d17fcbf1" alt=""
TextFormField(
decoration: InputDecoration(
focusedBorder: OutlineInputBorder(
borderRadius: BorderRadius.circular(16),
borderSide: const BorderSide(
color: Colors.green,
width: 2.0,
),
),
labelStyle: TextStyle(
fontSize: 12,
color: Colors.green[300],
),
labelText: 'フレームあり、ラベルあり',
floatingLabelStyle: const TextStyle(fontSize: 12),
enabledBorder: OutlineInputBorder(
borderRadius: BorderRadius.circular(16),
borderSide: BorderSide(
color: Colors.green[100]!,
width: 1.0,
),
),
),
),
アイコンあり、フレームあり
data:image/s3,"s3://crabby-images/b2392/b239262430770b38f7fed6ffd5c494e95bcd9f96" alt=""
TextFormField(
decoration: const InputDecoration(
hintText: 'アイコンあり、フレームあり',
prefixIcon: Icon(
Icons.search,
),
border: OutlineInputBorder(),
),
),
アイコンあり、フレームなし
data:image/s3,"s3://crabby-images/30aa0/30aa04a61070af2d04223238397d5eefcf9b4f90" alt=""
TextFormField(
decoration: InputDecoration(
hintText: 'アイコンあり、フレームなし',
fillColor: Colors.green[100],
filled: true,
isDense: true,
prefixIcon: const Icon(Icons.search),
border: OutlineInputBorder(
borderRadius: BorderRadius.circular(32),
borderSide: BorderSide.none,
),
),
),
フレームなし、パディングなし
data:image/s3,"s3://crabby-images/695b8/695b8b7f6458fe75c76d8bee0db44ee3b8108b18" alt=""
TextFormField(
decoration: InputDecoration.collapsed(
hintText: 'フレームなし、パディングなし',
fillColor: Colors.green[100],
filled: true,
),
),
複数行入力、フレームなし、パディングなし
data:image/s3,"s3://crabby-images/bd6c7/bd6c74b05b7a5fc1eef6ab9b6e09b55f0a51e1aa" alt=""
TextFormField(
maxLines: 6,
minLines: 6,
keyboardType: TextInputType.multiline,
decoration: InputDecoration.collapsed(
hintText: '複数行入力\n1\n2\n3\n4\n5',
fillColor: Colors.green[100],
filled: true,
),
),
複数行入力、角フレームあり、ラベルあり
data:image/s3,"s3://crabby-images/8400d/8400dc00faa475640aed4e3aa2ea46f6a1aaf0c9" alt=""
TextFormField(
maxLines: 6,
minLines: 6,
keyboardType: TextInputType.multiline,
decoration: InputDecoration(
labelText: '複数行、角フレームあり、ラベルあり',
enabledBorder: OutlineInputBorder(
borderRadius: BorderRadius.circular(0),
borderSide: const BorderSide(
width: 2,
color: Colors.green,
),
),
focusedBorder: OutlineInputBorder(
borderRadius: BorderRadius.circular(0),
borderSide: const BorderSide(
width: 2,
color: Colors.green,
),
),
),
),
パラメータ解説
coming soon...