Flutter でテキストにアニメーションを付けて表示する方法について紹介します!
今回は、animated_text_kit パッケージを使っていきます。
パッケージのインストール
パッケージのインストール方法は、以下の記事で紹介しています。
インストール方法がわからないという方は、ご参照ください。
基本の実装
AnimatedTextKit は、基本は以下のように実装します。
animatedTexts の中に、次の章で紹介する各 AnimatedText を入れて使用します。
AnimatedTextKit(
animatedTexts: [
// 任意のAnimatedText
],
),
以下の例では、1文字ずつ表示する TyperAnimatedText を実装しています。
AnimatedTextKit(
animatedTexts: [
TyperAnimatedText('Hello World!'),
],
),
アニメーションの種類と実装例
animated_text_kit を使用することで、様々なアニメーション付きテキストを表示できます。
どのようなアニメーションがあるか紹介していきます。
Rotate
RotateAnimatedText は、上から下に回転させながらテキストを表示できます。
AnimatedTextKit(
animatedTexts: [
RotateAnimatedText('おはようございます。'),
RotateAnimatedText('こんにちは。'),
RotateAnimatedText('こんばんは。'),
],
),
data:image/s3,"s3://crabby-images/f2f41/f2f41e933c888318ebd77adccc177efaaa13ae6c" alt="RotateAnimatedTextの例"
Fade
FadeAnimatedText は、フェードインとフェードアウトでテキストを表示できます。
AnimatedTextKit(
animatedTexts: [
FadeAnimatedText('おはようございます。'),
FadeAnimatedText('こんにちは。'),
FadeAnimatedText('こんばんは。'),
],
),
data:image/s3,"s3://crabby-images/b5533/b55332b9b990b22775c2b57e23f753f9b7c58f6d" alt="FadeAnimatedTextの例"
Typer
TyperAnimatedText は、テキストを1文字ずつ表示できます。
speed の指定は必須ではありませんが、指定しないと速すぎたため 100ms を指定しています。
AnimatedTextKit(
animatedTexts: [
TyperAnimatedText(
'Hello World!',
speed: const Duration(milliseconds: 100),
),
],
),
data:image/s3,"s3://crabby-images/1297e/1297ef2b9adc43c8cf5c5d78222585bb1f83d8b8" alt="TyperAnimatedTextの例"
Typewriter
TypewriterAnimatedText は、タイプライターで入力したようにテキストを1文字ずつ表示できます。
こちらも speed の指定は必須ではありませんが、指定しないと速すぎたため 100ms を指定しています。
AnimatedTextKit(
animatedTexts: [
TypewriterAnimatedText(
'Hello World!',
speed: const Duration(milliseconds: 100),
),
],
),
data:image/s3,"s3://crabby-images/4d8fd/4d8fdfc0fd4509374c381bcd0f1fd28532f4d810" alt="TypewriterAnimatedTextの例"
Scale
ScaleAnimatedText は、スケールアップおよびスケールダウンさせてテキストを表示できます。
AnimatedTextKit(
animatedTexts: [
ScaleAnimatedText('おはようございます。'),
ScaleAnimatedText('こんにちは。'),
ScaleAnimatedText('こんばんは。'),
],
),
data:image/s3,"s3://crabby-images/3a854/3a854fde6ee9486834dff3927caa18fbcbe3969b" alt="ScaleAnimatedTextの例"
Colorize
ColorizeAnimatedText は、色を変化させながらテキストを表示できます。
AnimatedTextKit(
animatedTexts: [
ColorizeAnimatedText('Hello World!',
textStyle: const TextStyle(fontSize: 20.0, fontWeight: FontWeight.bold),
colors: [
Colors.purple,
Colors.blue,
Colors.yellow,
Colors.red,
],
),
],
),
data:image/s3,"s3://crabby-images/3eee5/3eee5cd0c99e9202213c0193678758e2dd593016" alt="ColorizeAnimatedTextの例"
TextLiquidFill
TextLiquidFill は、テキストが液体で満たされるように表示できます。
他のアニメーションと違い、AnimatedTextKit の Widget を使用しません。
TextLiquidFill(
text: 'おはようございます。',
textStyle: const TextStyle(
fontSize: 20,
fontWeight: FontWeight.bold,
),
),
data:image/s3,"s3://crabby-images/ffe34/ffe342d1eeb45f5085ef9851652c78488e80168d" alt="TextLiquidFillの例"
Wavy
WavyAnimatedText は、波打たせながらテキストを表示できます。
AnimatedTextKit(
animatedTexts: [
WavyAnimatedText('おはようございます。'),
WavyAnimatedText('こんにちは。'),
WavyAnimatedText('こんばんは。'),
],
),
data:image/s3,"s3://crabby-images/8561d/8561dcf52381b4028bafeb4cdc76bc19b8fd3ab1" alt="WavyAnimatedTextの例"
Flicker
FlickerAnimatedText は、点滅させながらテキストを表示できます。
AnimatedTextKit(
animatedTexts: [
FlickerAnimatedText('おはようございます。'),
FlickerAnimatedText('こんにちは。'),
FlickerAnimatedText('こんばんは。'),
],
),
data:image/s3,"s3://crabby-images/c051b/c051bb4969d664bec447ff6bb05065183cfb9e48" alt="FlickerAnimatedTextの例"
各 AnimatedText の設定
各 AnimatedText のプロパティで、設定をカスタマイズすることができます。
例えば、TyperAnimatedText では、テキストのスタイルやアニメーションのスピードなどを変更できます。
詳しくは、以下のページから、各 AnimatedText のクラスについて書かれたページをご参照ください。
まとめ
Flutter で、アニメーション付テキストを表示する方法について紹介しました!
- animated_text_kit パッケージを使用すると、アニメーション付きテキストを表示可能
- animated_text_kit には、様々なアニメーションがある
- テキストのスタイルやアニメーションの設定が変更可能
以上で、【Flutter】テキストにアニメーションを付ける方法 は終わりです。
コメント