メインコンテンツへスキップ
  1. Posts/

【flutter】Lottieアニメーションライブラリの使い方をわかりやすく解説

loading · loading ·

flutterでアニメーションの作り方を探している方向け。

コピペで簡単にアニメーションが実装できるLottieライブラリの使い方をデモコード付きでわかりやすく解説します。

この記事は以下のような方を対象者としています。

  • flutter初学者の方
  • flutterでアニメーションのやり方を探している方
  • flutter+Lottieライブラリの組み込み方を探している方

今回作るflutter+lottieアニメーション
#

Alt text

今回の記事ではこちらのLottieアニメーションをflutterで実装していきたいと思います。

前置き:Lottieアニメーションライブラリとは?
#

LottieアニメーションライブラリはAirbnb(民泊アプリ)が開発したアニメーションの作成・配布ができるサービスです。

jsonの形式で作成されたデータをWebアプリやモバイルアプリに簡単に組み込むことができます。

このLottieライブラリの特徴はアニメーション制御のコーディングなしで簡単にアニメーションを表示できることです。

また、商用利用も可能のためアプリやWebサービスに組み込むことも柔軟にできます。

それでは早速flutterでLottieアニメーションの組み込み方を説明します。


flutter+lottieでアニメーション実装その1 : アニメーションファイルのダウンロード
#

まずはLottieの公式サイトにアクセスしてください。

(アカウント未作成の方は無料で作れますので作成してください。)

すると下記画像のようなアニメーション一覧画面が表示されます。

Alt text

今回は一番右に表示されているアニメーションをflutterアプリに組み込みます。

組み込みたいアニメーションをクリックし、画面上部のダウンロード→Lottie Jsonをクリックしてください。

Alt text

これでLottie jsonデータをダウンロードできます。

flutter+lottieでアニメーション実装その2 : プロジェクトファイルを作成
#

まずはflutterのプロジェクトを自分のローカル上に作成しましょう。

まずはターミナルを開き下記コマンドを実行してください。

<!-- デスクトップ上にliquid-animationというflutterプロジェクトフォルダを作成 -->
$ flutter create ~/Desktop/lottie-animation

flutter+lottieでアニメーション実装その3 : lottieアニメーションファイルを配置
#

先ほど作ったプロジェクトファイルを開き、libフォルダと同じ階層にassetsフォルダを作成します。

Alt text

そしてその中に先ほどダウンロードしたLottie Jsonファイルを格納します。

flutter+lottieでアニメーション実装その4 : pubspec.yamlファイルの修正
#

続いてコードから先ほど配置したLottieデータにアクセスするために、pubspec.yamlファイルを修正します。

pubspec.yamlとはパッケージ管理ファイルです。

pubspec.yamlはプロジェクトフォルダ直下に存在します。

50行目あたりにassetsとコメントアウトで書いてある箇所があると思います。

そちらを下記の通り修正してください。

<!-- To add assets to your application, add an assets section, like this: -->
  assets:
    - assets/

上記ファイル保存後にターミナル上で下記コマンドを実行します。

flutter pub get

これでコード上からassetsフォルダ内のlottieデータにアクセスできるようになりました。

flutter+lottieでアニメーション実装その5 : dartコードの実装
#

続いてdartのコードを修正していきます。

プロジェクトフォルダ直下のlib/main.dartファイルを開き、下記コピペをしてください。

デフォルトの不要なコメントアウトやコードは全て削除しています。

import 'package:flutter/material.dart';
<!-- 下記を追加 -->
import 'package:lottie/lottie.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key key, this.title}) : super(key: key);

  final String title;

  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  @override
  Widget build(BuildContext context) {
    <!-- 下記を追加 -->
    return Scaffold(
        body: Center(
        child: Lottie.asset('assets/lottiefile.json'),
    ));
  }
}

あとはコードを保存して実際にビルドし実行してみましょう。

すると冒頭で添付したYoutube動画のようなアニメーションが画面中央に表示されていると思います。

※もし表示されなければ本記事にコメントください。

また、Lottieはアプリ内に組み込む他CDN等にJSONデータを配置しアクセスする方法でもアニメーションが表示できます。

さいごに
#

ここまでお読みいただきありがとうございました。
私のブログ記事を読んでいる方の中には海外転職・海外移住への興味がある方もいらっしゃるかと思います。

私自身ダナンで働き始めて7年目になりますが、海外就職を実現するために大事なのは英語力と開発現場で働いた経験だと感じました。

もし今後海外移住・海外就職を本気で実現させたい方はぜひこれらのサービスを活用してみてください。

レアジョブ - 実務で使える英語力を身につけよう
#

レアジョブ英会話は英会話力の向上に特化したサービスです。 私の友人もレアジョブを通じて0から学習を続け、現在はベトナム人のエンジニアとも英語でコミュニケーションが取れるレベルまで英会話力を伸ばすことができました。

レアジョブが選ばれる理由は多岐にわたりますが、主な理由としては下記3点が考えられます。

  • 優秀な講師陣:公用語が英語であるフィリピン人の方が講師となり、生きた英語を身につけることができる
  • 豊富な教材: 5,000以上の教材を提供しており、学習者のレベルや目的に応じて最適な教材を選べます。
  • 安心のサポート体制:初心者でも安心して始められるように、日本人カウンセラーが学習のサポートをしてくれます。

海外移住計画の第一歩として、スピーキング力を身につけたいと考えている方は、ぜひこちらの無料体験を試してみてはいかがでしょうか。

Related

【flutter】Tinderのようなスワイプ型カードのやり方をわかりやすく【アプリ開発】
loading · loading
【M1チップ】flutter開発にてエミュレータが起動しない時の解決法【Visual Studio/Android Studio】
loading · loading
【flutter】コピペOK!おしゃれなアニメーションのやり方!【Liquid Swipe Animation】
loading · loading