LoginSignup
40
19

More than 3 years have passed since last update.

自分の結婚式に写真共有アプリを作った

Last updated at Posted at 2019-12-12

本記事は 個人開発 Advent Calendar 2019 13日目の記事です。

経緯

2年前くらいに Motoki Narita さんの「 結婚式を支えた技術 Firebaseを活用したサーバレスiOSアプリケーション開発 」の発表を拝見しました(たしか potatotips だったような :thinking:
もうこのとき感動しまくりで、いつか自分もこれやりたい!って思ってから、ようやくそれが叶ったって感じです。
みんな目線の写真というのが本当にいいなと思いました :relaxed:

アプリ仕様

当初は結婚式アプリとして、席次表の閲覧とかPUSH通知でお知らせとかやりたかったのですが、工数の関係上、写真共有アプリに機能を絞ることにしました。

参列頂いた多くの方に使ってもらいたい

その想いから Android/iOS の対応はマストにしました。
「一番多くの いいね がついた写真を投稿してくれた人には豪華景品!」というゲームをするために簡易ログイン、いいね機能もつけました 🥕

対応OS

  • Android
  • iOS

機能

  • 写真の投稿
  • いいね
  • 簡易ログイン(ゲームで活用するため)

↓ 実際の画面 ↓

ログイン画面 メイン画面 拡大表示画面
login main detail

エスコートカードの裏面に専用の番号を書いて、それでログインしてもらう感じです

detail

仕組み

仕組みはこんな感じで考えました
Firebase さんに非常にお世話になりました :pray:

使った Firebase の機能

Cloud Firestore firestore NoSQL データベース
投稿された画像の情報( URL や いいね数 など)をここに保存する
クライアントはここから画像情報のリストを取得して一覧表示する
Cloud Storage storage ストレージ
投稿された画像の保存場所
Cloud Functions functions Node.js で書いた関数をいろいろなトリガーで実行してくれる
今回は画像の投稿(Cloud Storage へのファイル追加)をトリガーにサムネイル画像を作成
Hosting hosting HtmlをホスティングしてWebページが作れる
今回はWebアプリにして、各スマホのブラウザからアクセスしてもらう形を採用

写真共有のざっくり構成

system

① Cloud Firestore にドキュメントを作成
② 写真をアップロード
③ Cloud Storage に写真が追加されたのをトリガーに Cloud Function でサムネイルを作成
④ サムネイルを Cloud Storage に保存
⑤ オリジナル、サムネイルの画像を Cloud Firestore のドキュメントに追記
⑥ Cloud Storage の変更がクライアントに通知される(写真が追加される)

結果

多くの方に投稿いただくことができました

枚数にしてなんと 319 枚!!

やらかしてなければもっと投稿いただけたはずなのに(後述) :innocent:

ちなみに一番いいねが多かったのは新婦の甥っ子姪っ子ちゃんでした :baby:10イイネ

system

失敗

はいこのアプリやらかしたんです。。

スクリーンショット 2019-12-12 21.28.02.png

はじめログイン画面の「GOボタンを」非表示にして、番号を入力したらボタンを表示するという仕様にしていたのですが、このボタンが表示されないという方向がちらほら。。
(開発中は良かれと思って入れた機能ですが、今となってはマジでやんなきゃ良かったと悔やみきれません)

スクリーンショット logindialog.png

iPhone ユーザーに起こってたようで、 IME 依存で jQuery の keypress イベントが発火しなかった模様。。。

この被害に遭われた方々は結局式の間アプリを使うことができませんでした(本当にごめんなさい :bow:

参列頂いた多くの方に使ってもらいたい

はい :innocent:

自分の iPhone でも、iPhone ユーザーの友人にもテストはしてもらってたんですが、まさか IME 依存という落とし穴

これはホントにホントに悔しいです。。

式終わって機能追加した

実は画像のダウンロード機能も実装しようと思っていたのですが、当日までに間に合いませんでした(手が回らなかった)
当日のウェルカムスピーチの際に皆さんと「いつか実装します!」と約束してしまったので、頑張ることにしました。

こんな感じでいけないかな? と構想

スクリーンショット logindialog.png

① 選択された画像IDを Cloud Function の HTTPトリガー の関数に投げる
② ID の画像を Cloud Storage から( Function 上で)ダウンロード
③ ダウンロードした画像を zip にする
④ zip を Cloud Storage にアップロード
⑤ Cloud Storage 上の zip の Download URL をクライアントに返す
(⑥ クライアント側でダウンロードを行う)

実際実装してみると、なんか動いてそうに見えたんですが、写真の枚数が多くなると Function でクラッシュします :thinking:

純粋にメモリが足りてないのかとか思ったんですが、Function のログ見るとなんか違いそうだがよくわからん。。(Cloud Function のベストプラクティスな開発手法知りたい)
この辺はもう少し調査が必要そうなので、今は五月雨式に選択した画像が降ってくる鬼機能にしています :sunglasses:

できなかったこと

最低限の機能実装って感じになってしまい、お世辞にも使いやすいUIとは言えないものでした :frowning2:
僕だけかもしれませんが、個人開発はどうしても UI が疎かになりがち。。
もう少しカッチョよくて使いやすいUIにしたかったです。

まとめ

個人開発は楽しいはもちろん、めちゃめちゃ勉強になりますね。
今回も、普段業務で使わない node.js やら何やらは環境構築から躓いたり、Hosting で独自ドメイン使うのに DNSレコードってどんなんだっけ?って調べたり、とにかく自分の 知らない とたくさん出会いました!
また、その 知らない を学ぶのに好きに時間を割いて良いのも個人開発ならではだと思います!
(もともと Android/iOS でそれぞれネイティブアプリ作るつもりだったのですが、好きに時間割きすぎて、「時間ないっ!」てなってほぼ完成品の Android アプリ捨てて Webに切り替えたとかいう裏話があります。)

結婚式は信頼の置けるクローズドな環境で多くの方にアプリを触ってもらえる最高の場でした :tada:
この記事を見て「自分もなんかやろーっ」て感じてくれる方がいたら幸いです!!

40
19
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
40
19