20
10

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

KBOYのFlutter大学Advent Calendar 2020

Day 21

Flutterでシェイク機能を実装する(Provider + ChangeNotifier)

Last updated at Posted at 2020-12-19

#はじめに
この記事では、Flutterでシェイク機能を実装するための手順を解説します。
シェイク機能のみの簡単なアプリを作りながら、実装をしていきます。
※ Android端末での動作確認のみとなります。

###筆者のレベル
・Flutterを始めて、約2ヶ月
・普段は、Javaのエンジニア(実務経験1年ほど)
・「ー」←このキーのブラインドタッチができない。。

#前提条件
・Flutterの環境構築が完了していること
参考記事 → Flutterの環境構築(Mac編)

・Providerのパッケージ導入が完了していること
参考記事 → provider | Flutter Package - Pub.Dev

#shakeパッケージの導入

参考記事 → shake | Flutter Package - Pub.Dev

pubspec.yaml
dependencies:
  shake:


flutter pub get

#完成コード

main.dart
import 'package:flutter/material.dart';

import 'home_page.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'シェイクアプリ',
      home: HomePage(),
    );
  }
}
home_page.dart
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';

import 'home_model.dart';

class HomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return ChangeNotifierProvider<HomeModel>(
      create: (_) => HomeModel()..shakeGesture(context),
      child: Consumer<HomeModel>(builder: (context, model, child) {
        return Scaffold(
          appBar: AppBar(
            title: Text('シェイクアプリ'),
          ),
          body: Center(
            child: Column(
              mainAxisAlignment: MainAxisAlignment.center,
              children: [
                Text('端末を振ってください'),
              ],
            ),
          ),
        );
      }),
    );
  }
}

home_model.dart
import 'package:flutter/material.dart';
import 'package:shake/shake.dart';

class HomeModel extends ChangeNotifier {
  shakeGesture(BuildContext context) {
    ShakeDetector.autoStart(onPhoneShake: () {
      showDialog(
          context: context,
          builder: (_) {
            return AlertDialog(
              title: Text('正常にシェイクを検知しました。'),
              actions: [
                FlatButton(
                  child: Text('OK'),
                  onPressed: () => Navigator.pop(context),
                ),
              ],
            );
          });
    });
  }
}

#画面作成
Screenshot_1608358582.png

home_page.dart
class HomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('シェイクアプリ'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: [
            Text('端末を振ってください'),
          ],
        ),
      ),
    );
  }
}

#モデル作成

###メソッド作成

class HomeModel extends ChangeNotifier {
  shakeGesture(BuildContext context) {
    // シェイク処理実装
  }
}

###シェイク処理実装

class HomeModel extends ChangeNotifier {
  shakeGesture(BuildContext context) {
    // 端末のシェイクを検知
    ShakeDetector.autoStart(onPhoneShake: () {
      // 端末がシェイクされた時の処理
      showDialog(
          context: context,
          builder: (_) {
            return AlertDialog(
              title: Text('正常にシェイクを検知しました。'),
              actions: [
                FlatButton(
                  child: Text('OK'),
                  onPressed: () => Navigator.pop(context),
                ),
              ],
            );
          });
    });
  }
}

#home_page.dartの編集

home_page.dart
class HomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    // ChangeNotifierProviderを追加
    return ChangeNotifierProvider<HomeModel>(
      // ここでHomeModelのシェイク機能メソッドを呼び出す。
      create: (_) => HomeModel()..shakeGesture(context),
      child: Consumer<HomeModel>(builder: (context, model, child) {
        return Scaffold(
          appBar: AppBar(
            title: Text('シェイクアプリ'),
          ),
          body: Center(
            child: Column(
              mainAxisAlignment: MainAxisAlignment.center,
              children: [
                Text('端末を振ってください'),
              ],
            ),
          ),
        );
      }),
    );
  }
}

#実機でテストする

Androidの実機でテストする方法は、下記の記事を参考にしていただければと思います。

参考記事 → [Flutter]実機でデバッグしてみる(Android編)

Screenshot_20201219_154311_com.rrraibuuu.shake_gesture_app.jpg

#終わりに
僕自身、Flutterでシェイク機能を実装する際に躓いたので、メモ感覚で書いてみました。
参考になれば幸いです。

20
10
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
20
10

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?