はじめに
2024/6/13~2024/6/14にお台場で開催された「FlutterNinjas Tokyo 2024」に参加してきました。英語で実施されるFlutterイベントは日本初とのことで、かなり豪華なメンバーでした!
Flutterアプリ開発には欠かせない「Riverpod」、「Provider」などのライブラリの作者である「Remi Rousselet」さんも登壇されていました。
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F600358%2F833b2e1c-5b4e-037d-e749-04f091b823d2.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=bdf66973df6af014f45c7982f877d049)
セッションの感想
どのセッションも素晴らしかったですが、とても語りきれないので特に印象に残ったセッションについて感想を書きます!
拙い英語力で理解した内容なので間違っていたらすみません!
Riverpod 3.0, the preview
スピーカー: Remi Rousselet
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F600358%2Ff9c8fc75-5dac-cde1-4192-ac76513527b8.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=dd7318bf4f5fdb122164c48b2f991290)
今後公開予定のRriverpod 3.0について紹介でした。主に以下のような内容が紹介されていましたが、特に気になったのはGeneric Providers、リトライ機能、オフライン機能でした。
- 様々なバグ修正
- パフォーマンスの改善
- AutoDisposeやRefの型を整理
- StateNotifier/StateProviderがDeprecatedに
-
<T>
で動的に型を指定できるGeneric Providers - 自動リトライ機能
- オフライン時に処理を切り替える機能
v2でも多機能で複雑なので使いこなせるかわからないのですが、リリースを楽しみにしています!生のRemiさんをみれてよかった!
Flutter Add-to-App: The Good, the Bad and the Ugly
スピーカー: Marcin Chudy
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F600358%2F33ec17d1-46af-75c6-b946-fed028df38fa.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=a095f847fcdcbbadbc44be7236a7e935)
既にあるアプリを段階的にFlutterに移行する方法について紹介されていました。画像のようにFlutterとNativeコードが混在するので、見るだけでとても大変そうでした...。
FlutterとNativeの通信や移行後のテストが大変ということで、pigeonやpatrolなどのパッケージの活用についても紹介されていました。
小規模なアプリであれば書き直してしまうのがよさそうです。
Building SimCity 2000: Unleashing the Power of Flame Engine and Flutter
スピーカー: Abdelrahman Eba
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F600358%2F4424bcda-efc6-57e4-f0ef-432191ffb8dc.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=6eb7d2a167afaf18ff0bd39d282d4f2a)
FlutterでSimCityのようなゲームを作る方法についての紹介でした。
flameパッケージを使ってその場でコーディングしながら3次元的なゲームを作るセッションでした。
コードに間違いがあった時には会場の有識者からアドバイスがあり、会場全体でモブプロしている感じでとても面白かったです!
Flutterで作ったゲームを競いあうGlobal Gamers Challengeで入賞したMGame - A waste management gameはスピーカーの方が作成されたということでした。
こんなゲームも作れるFlutterの凄さを改めて実感しました。
flameは本来2次元のゲームを作るパッケージなので、3次元への座標変換に数学の知識が必要とのことです。実際に作るのは中々ハードルが高そう...。
Workshop: Flutter for Android TV and Apple TV
スピーカー: Sasha Denisov
Android TVとApple TVでFlutterアプリを動かす方法についてのセッションでした。
Flutter公式ではTV系の対応をしていないので、FlutterのEngineをカスタマイズして実行できるようにしたとのことでした。
Flutter自体をカスタマイズして実行するという熱意がすごいと思いました。興味ある方は以下のリポジトリにサンプルがあるので、実行してみてください!
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F600358%2Fb0634ef8-830b-91fe-2211-9d975a3fea16.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=18e9e70e4a9f5668c5a757e39e038c3e)
Monitoring user experience of flutter apps with SLI/SLO
スピーカー: Takuma Osada
サイバーエージェントのエンジニアさんがWINTICKTでユーザー体験を向上させるために計測している SLI/SLO についての紹介でした。アプリのログイン成功率や離脱率などを詳細に計測・可視化している試みを自分が開発しているアプリでも参考にしたいと思いました。
ありがたいことに発表資料を日本語で公開していただいているので、詳細はそちらを見ていただくのが良いと思います!
Implementing a RAG (Retrieval-Augmented Generation) System in Dart
スピーカー: Park JaiChang
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F600358%2Ff5439375-ad7a-c8ac-c8b5-6c26d80c13a9.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=45b11a5a18d61b9122bf40c062f31275)
流行りの生成AIとRAGを組み合わせたシステムをDartを作成する方法についてのセッションでした。PythonやJavascriptでの実装が一般的ですが、langchainを扱うためのDartパッケージも非公式ながら公開されているのでDart Onlyにしたい時などに選択肢に入ると思いました。
スピーカーが韓国の方で、NewJeansやaespaなどのK-POPアイドルを知らないChatGPTにRAGを使って教えるという内容がとても面白かったです笑。
終わりに
どれも素晴らしいセッションで、普段では触れない内容について知ることができてとても有意義な時間でした!紹介されていた技術やパッケージなどを今後触っていきたいなと思います。
ぬいぐるみとTシャツもゲットして大満足です!グッズの抽選はルーレット形式もあって大盛り上がりでした!
運営の方々、スピーカーの皆様、素晴らしいイベントを本当にありがとうございました!
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F600358%2F592a524c-cead-414f-9310-a1be6b3e362f.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=3997f0f3ea9428377a42e7dd71bdbd4f)
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F600358%2F4faebbad-848b-c43b-7b27-c50981a0cf7a.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=82cbc2ee9c2a9b2ce318ab46a0dfc2ea)