LoginSignup
5
0

[Flutter]Flutterを用いたクソアプリの作り方の一例

Last updated at Posted at 2023-12-05

スクリーンショット 2023-11-13 14.51.52(2).png

こんにちは。いせりゅーです。
この記事は、「クソアプリ Advent Calendar 2023」のアドベントカレンダーになっております。

今回は、Flutterを用いたクソアプリの作り方を簡単に紹介します。Flutterを用いた理由は、僕がFlutterエンジニアだったからです。

自己紹介

スクリーンショット 2023-06-13 7.33.21(2).png

クソアプリの作り方

その1 サンプルアプリを作ろう

今回は、クソアプリを作るのにフォーカスを当てるために、flutter create <アプリ名>で作られるカウントアプリを魔改造しようと思います。

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

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

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
        useMaterial3: true,
      ),
      home: const MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  const MyHomePage({super.key, required this.title});

  final String title;

  @override
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  int _counter = 0;

  void _incrementCounter() {
    setState(() {
      _counter++;
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        backgroundColor: Theme.of(context).colorScheme.inversePrimary,
        title: Text(widget.title),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Text(
              'You have pushed the button this many times:$_counter',
            ),
          ],
        ),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: _incrementCounter,
        tooltip: 'Increment',
        child: const Icon(Icons.add),
      ),
    );
  }
}

その2 どうしたらクソアプリになるか考えてみる

個人的なクソアプリの概念ですが、理不尽であることや「なんで?」と思われることがとても大切だと思いました。
そのため、今回は以下のような対応を行いました。

  • ちゃんとカウントできないようにする
    • カウントアップするたびに素数をランダムで表示する
    • いっそのこと、数字ではなく適当な文字を表示する
  • リセットする方法を隠しボタンにする
  • どうでもいい広告を入れてみる
  • 変なタップ音をつける

実装するよぉぉぉぉ

1.ちゃんとカウントできないようにする。

この実装については、インクリメントを削除するだけでできそうですね。

void _incrementCounter() {
-  setState(() {
-   _counter++;
- });
}

↓実際に動かしてみました。

Simulator Screen Recording - iPhone 15 Pro - 2023-11-17 at 14.04.02.gif

「You have pushed the button this many times」と書いてあるくせに、ボタンを押しても増えないのは既におかしいですね。

2.カウントアップするたびに素数のみを表示する

_incrementCounter()の記載が何もないのでせっかくだから変な要素を加えてみたいですね。

今回は、ボタンを押すと+1をするのではなく、数字の結果を素数のみにします。

考え方としては、
1、現在の数値を保持するための変数を定義します。(int _counter = 0;
2、次の素数を見つける関数を実装します。この関数は現在の数値より大きい最小の素数を返すように実装します。

main.dart
int _counter = 0;

 void _incrementCounter() {
    int nextNumber = _counter + 1;
    while (!isPrime(nextNumber)) {
      nextNumber++;
    }
    setState(() {
      _counter = nextNumber;
    });
  }

  // 2、素数を見つける関数
  bool isPrime(int number) {
    for (int i = 2; i <= number ~/ 2; i++) {
      if (number % i == 0) {
        return false;
      }
    }
    return true;
  }

↓実際に動かしてみました。

Simulator Screen Recording - iPhone 15 Pro - 2023-11-17 at 13.58.23.gif

これはこれで良さそう・・・???
別のアプリで使えそうですね😆

3.いっそのこと、数字ではなく適当な文字を表示する

2番目の実装で素数のみの表示になりましたが、数字ではなく、適当な文字を表示してもいいなと思いました。
実装としては、ランダムな日本語の5文字を並べることにしました。

今回は大幅にコードの内容が変わったので、全体のコードを載せます。

main.dart
main.dart
import 'dart:math';

import 'package:flutter/material.dart';

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

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
        useMaterial3: true,
      ),
      home: const MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  const MyHomePage({super.key, required this.title});

  final String title;

  @override
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  String _randomString = 'Hello World';

  void _generateRandomString() {
    _randomString = generateRandomString(5);
    setState(() {});
  }

  String generateRandomString(int length) {
    const characters = 'あいうえおかきくけこさしすせそたちつてとなにぬねのはひふへほまみむめもやゆよらりるれろわをん';
    final random = Random();

    // 文字コードを受け取り、それを文字列に変換します
    return String.fromCharCodes(
      // 指定された長さのリストを作成
      Iterable.generate(
        length,
        // リストの各要素(この場合は文字コード)をどのように生成するかを定義
        (_) => characters.codeUnitAt(
          random.nextInt(characters.length),
        ),
      ),
    );
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        backgroundColor: Theme.of(context).colorScheme.inversePrimary,
        title: Text(widget.title),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            const Text(
              'You have pushed the button this many times:',
            ),
            Text(
              _randomString,
              style: Theme.of(context).textTheme.headlineMedium,
            ),
          ],
        ),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: _generateRandomString,
        tooltip: 'Increment',
        child: const Icon(Icons.add),
      ),
    );
  }
}

↓実際に動かしてみました。

Simulator Screen Recording - iPhone 15 Pro - 2023-11-17 at 14.24.57.gif

どんどん謎なアプリになりましたね。

今回はここまで。

感想

この後ももっとクソアプリ化してもいいかなと思いましたが、長くなりそうなので今回はここまでです。
もし、好評でしたら作成します😆(いいねやコメント待っています!!)

リポジトリはこちらです。

最後に

少し宣伝をさせてください!!

株式会社ゆめみの23卒のメンバーでアドベントカレンダーを作成しています。
新卒のフレッシュな記事がたくさん投稿予定なので、少しでも興味があれば購読いただけると幸いです!!

5
0
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
5
0