Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yumnumm/eqmonitor
An earthquake monitoring Application
https://github.com/yumnumm/eqmonitor
android earthquake flutter
Last synced: about 1 month ago
JSON representation
An earthquake monitoring Application
- Host: GitHub
- URL: https://github.com/yumnumm/eqmonitor
- Owner: YumNumm
- License: mit
- Created: 2022-02-27T17:14:37.000Z (over 2 years ago)
- Default Branch: develop
- Last Pushed: 2024-10-01T16:39:00.000Z (about 1 month ago)
- Last Synced: 2024-10-01T18:46:48.371Z (about 1 month ago)
- Topics: android, earthquake, flutter
- Language: Dart
- Homepage: https://eqmonitor.app/
- Size: 82.4 MB
- Stars: 183
- Watchers: 8
- Forks: 11
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# EQMonitor - 地震速報・監視アプリケーション
[![Github All Releases](https://img.shields.io/github/downloads/EQMonitor/EQMonitor/total.svg)](https://github.com/EQMonitor/EQMonitor/tags)
[![GitHub release (latest by date including pre-releases)](https://img.shields.io/github/v/release/EQMonitor/EQMonitor?color=blue&include_prereleases&label=Release)](https://github.com/EQMonitor/EQMonitor/releases/latest)| Android | iOS |
| :----------------------------------------------------------------------------------------------------------------------------------------------------------------------------: | :-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------: |
| [](https://play.google.com/store/apps/details?id=net.yumnumm.eqmonitor) | [](https://apps.apple.com/ja/app/eqmonitor-%E5%9C%B0%E9%9C%87%E9%80%9F%E5%A0%B1/id6447546703) |> [!WARNING] > [利用規約 - Term of Service](https://github.com/EQMonitor/EQMonitor/blob/main/assets/docs/term_of_service.md)を必ずご確認の上ご利用ください。
![iPad1](https://github.com/YumNumm/EQMonitor/assets/73390859/4196623d-222e-4eac-991a-fee5a976be76)
## 概要
EQMonitorは、日本全国の地震情報をいち早く受信できるアプリケーションです。
**_機能_**
- **地震情報・緊急地震速報の通知**
気象庁により発表された地震情報や、緊急地震速報を受信し、通知します。
- **過去の地震履歴の閲覧**
過去に発表された地震情報を遡って確認できます。
- **緊急地震速報のリアルタイム表示**
緊急地震速報が発表された際に、P波・S波の予想到達範囲、予想最大震度、震央地を表示します。
緊急地震速報は、リアルタイムに更新され、インターネットに接続されていれば、どこからでも確認できます。- **強震モニタの表示**
防災科学技術研究所の提供するWebサービス 強震モニタ を表示します。
(※ 強震モニタは、揺れの様子を直感的に捉えることを目的としています。また、リアルタイムで観測値を処理しているため、ノイズ等により観測値が変動します。
そのため、本アプリケーションで表示される観測値は、あくまで参考値としてご利用ください。)## 環境構築
下記のコマンドをターミナルから実行してください。
1. `git clone https://github.com/YumNumm/EQMonitor` でリポジトリをクローンします。
1. `cd EQMonitor` でカレントディレクトリを移動します。
1. Dartプロジェクトを管理するためのツールである[melos](https://melos.invertase.dev/)をインストールします。
- `dart pub global activate melos` を実行してください。
- 詳細は、[Get Started](https://melos.invertase.dev/~melos-latest/getting-started)を参照してください。1. `melos bootstrap` を実行してください。
- これにより、各パッケージの依存関係が解決されます。
1. `mv app/.env.example app/.env` を実行してください。
- HTTP APIのみ Staging APIへ接続できます。(事前設定済み)
- 常に最新の地震情報が提供されることを保証しません。
- 事前の予告なしに、APIの仕様が変更される可能性があります。
- アプリストアで公開しているAPIとは異なり、APIの実行環境やWAFの設定が異なります。
- その他の値は、そのままでも問題ありません。
- WebSocket APIは公開していないため、リアルタイムでの緊急地震速報の受信などはできません。1. `fvm flutter run` でアプリケーションを起動します。
## アーキテクチャ
- アプリケーション
- 状態管理: Riverpod, Flutter Hooks
- データ取得: Dio, retrofit, eqapi_client(自作)
- JSONシリアライズ/デシリアライズ: freezed, json_serializable
- マップ: maplibre_gl- エッジサーバサイド(API)
- 実行環境: Cloudflare Workers
- データベース: Cloudflare D1 + Supabase
- キャッシュ: Cloudflare KV
- WebSocket(Fallback): Cloudflare Durable Objects- バックエンド(通知配信, DB追加, データ加工, WebSocket, 揺れ検知)
- 実行環境: Oracle Cloud Infrastructure Compute Instance, Docker Compose(12個のコンテナを管理)
- データベース(キャッシュ用): PostgreSQL
- 言語: Node.js(TS), Bun(TS), Golang, C#