この記事は、Android #2 Advent Calender 2020 16日目の記事です。
また、同日にこちらのイベントで、この記事をLTサイズにまとめたスライドを使用した発表を行います。
そうだ、アプリを作ろう ※未経験
ある秋の夜、ふと思い立ちました。
よーし!今から1日でダイエット用のスマホアプリを作るぞぉ!!
— 白栁隆司@エンジニアカウンセラー (@ShirayanagiRyuj) September 11, 2020
この時、これからダイエットに励むことは確定事項でした。
その為、そのダイエットで出てくる色々な情報を管理できるアプリを作ってみよう、そう思い立ったのです。
※ダイエット関連のまとめはエンジニアライフ(別サイト)のコラム『コレざま』に掲載中
この記事では、その時にやったアレコレを、Twitterに投稿した内容に情報を補足する形で追っていきます。
ベストプラクティスだったり、入門だったりの役に立つものでは有りません。
ただの失敗の記録です。
アプリ?そんなのヨユーっしょ!!
白栁は思い立った。
必ず、かのダイエットアプリを制作せねばならぬと決意した。
白栁にはスマホアプリ開発がわからぬ。
白栁はは、SESの底辺エンジニアである。
Windowsを使い、VisualStudioで開発して来た。
けれども技術に対しては、人一倍に敏感であった。
きょう深夜白栁はAndroidStudioをインストールし、Googleを問い詰め、未経験のはAndroid開発の入り口にやって来た。
ということで開発をスタートしたわけです。
太宰治の名作「走れメロス」の冒頭調に紹介しましたが、普段はVisualStudioでWindows向けの業務システムを作ってます。※GUIはWinFormです。
スマホアプリは全く分かりません。
ただそれでも、Androidスタジオのインストールだけなら、数年ぶりn度目です!(キリッ
そして、業務システムとはいえ、幾つかのシステムをゼロから作った経験もある。
もう負ける姿は見えないねっ!!(フラグ
初めに計画をしよう
仕事でもプライベートでも、まずやることは一緒です。
「何を作るかを明確にすること」です。
必要機能の書き出しも充分!
— 白栁隆司@エンジニアカウンセラー (@ShirayanagiRyuj) September 11, 2020
これでもう何も怖くないッ!!
既に二次開発の予定まで入ってしまっているとは… pic.twitter.com/4moPp7nh1a
ということで、30分程で作成した資料は、以下にアップされています。
この時点で、必要そうな技術的な情報の下調べまでを終わらせています。
※参考資料のページは消しました。
この計画を指標に、以後の開発を進めていくことにしました。
開発環境を作ろう
実際に開発を行うにしても、環境がない状況では何も始まりません。
Android Studioのインストールと日本語化(3.0日本語化手順追記) - FIDS CREATE
上記のページを参考にして、インストールと日本語化を進めました。
若干手間取りましたが、情報通りに進めることで無事にインストールを完了しました。
ただ、Cドライブに余り情報を入れたくない性分なので、以下の設定でちょっとミスをしたな、と感じています。
今回は「だからこうすればいい」という解決策もありません。
しっかり日本語化もしよう!
— 白栁隆司@エンジニアカウンセラー (@ShirayanagiRyuj) September 11, 2020
インストール時にconfig関係のフォルダ設定を間違ってしまった気がしてる… pic.twitter.com/Tli554uCkO
AndroidStudioを触ってみる&仮想デバイスの作成
しっかり日本語されている事を確認しながら、適当にプロジェクトを作成します。
初めてのAndroidプロジェクト…
— 白栁隆司@エンジニアカウンセラー (@ShirayanagiRyuj) September 11, 2020
ドキドキである
しかし、アレだな
アクティビティの種類が豊富過ぎて、これだけで何でも作れそうな気になってくる
(まずは参考資料通りに…) pic.twitter.com/lnscFUoCcf
適当なアクティビティを作成して、エミューレータの作成に入ります。
ここで設定が間違っていたら、最初からプロジェクトを作り直せばいいんだ、そう考えて進んでいます。
Android StudioでAndroidアプリのエミュレータを使う方法【初心者向け】 - TECH ACADEMY マガジン
Kotlinで始めるAndroidアプリ入門(前編) - @k-ysd - Qiita
これらのページを参考にしながら、設定を進めます。
Androidはバージョンや画面サイズの種類も多く、どの環境を選んで作成すればいいのか、ベストプラクティスがわかりません。
とりあえず、自分が使っている環境を…と思ったのですが、プリセットには入っていませんでした。
OSバージョンの設定も、使う予定の最新スマホではなく、今は使ってない古いスマホに合わせています。
とりあえず、なんとか仮想デバイス作成にたどり着けたぞ!
— 白栁隆司@エンジニアカウンセラー (@ShirayanagiRyuj) September 11, 2020
イメージの一覧にOPPOA3がなかったので、FullHDサイズ縦のPixel2を選んでみた
AndroidOSのバージョンは…適当に10でいいだろ?
だって、自分が使えればいいんだもの!
(といいつつ、手持ちの最古OSである7.1.1に合わせるチキンプレイ) pic.twitter.com/GAAYMnAnTX
エミュレータ、永遠に遊べる
エミューレータの中にはしっかりとAndroidが入ってます。
なので、環境設定したり色々してると、これだけでマジで遊べすぎます。
程々(1時間)で見切りをつけて、初めてのアプリ制作へ突入。
トラブルに悩まされつつ、Git入れたりしつつ(省略)2時間ぐらいかけてようやく動くものができる。
参考にしたのは設定でもお世話になった記事の中編と後編。
Kotlinで始めるAndroidアプリ入門(中編) - @k-ysd - Qiita
Kotlinで始めるAndroidアプリ入門(後編) - @k-ysd - Qiita
基本はこれに沿って色々配置しただけ。
初めてのスマホアプリができたよ!
— 白栁隆司@エンジニアカウンセラー (@ShirayanagiRyuj) September 11, 2020
ボタンの位置が変なのはご愛嬌ということで…(遠い目 pic.twitter.com/WGXByDs9tP
流石にここら辺で活動限界を迎えた為(午前3時半)一旦睡眠を取る。
流石に眠くて頭回らなくなったらダメですからね。
メニューGUIを作る
7時間程寝てスッキリ!
具体的な画面づくりを始めるに当たり、まずはメニュー作成から。
たまにお世話になっているフリー素材サイトからそれっぽいアイコンをダウンロード。
ただ、これをプロジェクトに取り込もうとすると、うまく出来ない。
おはようございます🌅
— 白栁隆司@エンジニアカウンセラー (@ShirayanagiRyuj) September 12, 2020
作業を再開します
メニュー用のフリー素材アイコンを画像として使うのにドハマリした
分かったこと:日本語名の画像は使えない pic.twitter.com/dG8Av71LXA
ドハマリすること30分以上。
日本語名ファイルだとリソースとして取り込めないっぽい。
ナンジャソレ!
そこから4時間ぐらい掛けて、なんとかメニューのレイアウトが形になる。
コントロールの相対位置の設定で、どうにも思い通りに設定ができなかったのだ。
レイアウトに四苦八苦して、進捗報告止まってた
— 白栁隆司@エンジニアカウンセラー (@ShirayanagiRyuj) September 12, 2020
大分できてきた感あるよね? pic.twitter.com/mxnPT7VB3y
この時点で開始から14時間。
でもまだ、ちょっと登録画面作るぐらいなら今日中にイケるって!
遷移先の画面を追加しよう
登録画面は、いちばん重要な「食事登録」の画面から作る。
なるほど。2つ目の定義(ハイライト部分)があるのが原因だったか!
— 白栁隆司@エンジニアカウンセラー (@ShirayanagiRyuj) September 12, 2020
よしよし、これで食事登録が進められるぞ pic.twitter.com/70IddF6Uks
だが、プロジェクトに新しい画面を追加した所、今まで表示されていた画面が表示されなくなってしまった。
ローカルなGitで、メニュー作成完了時点でコミットしていた為、差分を見ながら原因となりそうな箇所を特定していく。
正確な意味は調べていないが、恐らく「起動時に使用する画面」という設定が2箇所(L13~17、L25~29)あるのが問題なのだろう。
後書き優先ということか。
方針転換:体重登録が先!
もう少し簡単に、HTMLや、VisualStudioのWPFの様にGUI画面が作れると予想していた。
だがしかし、初めて体当たりで扱うには、AndroidStudioのGUI画面作成のハードルは高かった。
食事登録画面でやろうとしたことは2つ
- 日時と食事内容のフリー入力
- 写真も登録出来るようにする
- 一覧表示と登録の画面遷移
残念ながら、これらを実現する為の良い資料が見つからなかった。
そもそも、一覧の作り方判らねぇっ!!
ということで、画面難易度が低い体重登録画面を先に作ることにした。
運良く、画面イメージのレイアウトを解説しているページを見つけることができた。
ScrollViewでAndroidアプリの画面スクロールを実現させる - RAKUSU Developer Blog
この通りに実装して、画面っぽいガワはできた。
ただ、どうしても日付の自動入力や数値項目の書式設定がうまく出来ない。
仕方がない、使うのはどうせ自分だけ。
「その辺りの面倒は運用でカバー!」と割り切って進めることにする。
そして最大の問題に直面する。
DBの選定に大失敗する!
ファイル書込みでもローカルDBでも良いのだが。
ここまで来て、データを保存する仕組み、というのが全く実装できていなかった。
後々、表にしたりする事を考えれば、ローカルDBが好ましいだろう。
適当なフリーのDBが、DAO通して簡単に使えるだろう、その程度に考えていた。
今考えれば、MariaDBを利用するのが、一番手っ取り早かったかもしれない。
PHPで使っていた経験もあるからだ。
だが、このときはその頭がなかった。
色々なサイトを当たってみて「AndroidのローカルDBにはRealmが流行ってるらしい」という情報を掴んだ為、Realm以外の選択肢が無くなっていた。
Javaの資料も公式から豊富に出ているっぽいし、とりあえず大丈夫だろう。
そう考えての見切り発車だったが、その後激しく後悔することになる。
このRealm、公式サイトのKotlinの最新ドキュメントが存在しないっぽい。
Javaは最新版の10.0.0に対応している(当時)のだが、
Kotlinは7.0.0-bataだからだ。
それは、今もって変わっていない。
DBのインストールはできたが、どうやってデータを格納する入れ物を作るのか。
それはテーブル定義が必要なのか?
何らかのデータを流し込めばいいだけなのか?
全くわからないまま、ここで時間切れを迎えた。
まとめ:失敗の原因
こうしてチャレンジは失敗に終わった。
失敗も失敗。大失敗である。
最後に、その失敗の要因を、幾つか分析してみよう。
1. 体系立てた情報を使わなかった
最初にアプリを作るなら、体系立てて手順が書かれている、最新のバージョンに対応した入門書に沿った方が良かったのだろう。
残念ながら、思い立ったのが深夜で本もなにもない。
「ある程度の開発経験があるから、ネット上の断片的な情報でも組み合わせて、うまく乗り越えられ楼だろう」
この考えが甘かったと思い知らされる。
2. 写経で作るファーストアプリを軽んじた
入門書であれば、最初に簡単な要素を適度に詰め込まれたアプリを写経する。
こういうのを無視して、いきなり自分のやりたいアプリを組み立てた事は、悪いプラクティスだ。
その開発環境に対するノウハウがないのだから、失敗しながら覚えていくしかない。
ただ、正解も判らず無闇に失敗するのは、徒労でしか無い。
また、最初に写経したアプリは、色々と設定を弄ることにより、仕組みの理解にも役立つ。
しっかりと学ぶのであれば、これを軽んじてはいけない。
とりあえず、まずは写経なのだ。
3. 入力系の設定が判らなかった
これは、上記の写経を怠ったことに付随するものだ。
世の中、入力エリアはフリーテキストばかりではない。
情報を入力する為のルールというのは、必ず設定できる。
うまく調べることが出来なかった、というのも大きな敗因だ。
しかし、これは僕の能力不足なだけでもある。
4. Kotlin使ってない
いや、実際使ってない。
記事のタグに入ってるけど、本文で1行も触れてない!
タグ詐欺と言われても仕方がないレベル。
5. DBわからん
Androidのアプリ上で、ローカルな情報管理をする場合に、どう保持するのがベストなのか、結局全くわからなかった。
後々で考えれば、MariaDBを利用するという手段もあっただろう。
幸い、MariaDBであれば、以前触った経験もある。
もう少し楽に導入できたかもしれない。
ただ、Realmを知って、冒険してみたかっただけなんだろう。
6. 豊富なActivity設定を活かせない
これは完全な知識不足だ。
何処を見れば、これらの効果的な使い方がわかるのか?すら調べていないのだが。
だが、これらのActivityを活かすことで、見た目の良い機能的なスマホアプリを簡単お手軽に実装できるようになるのだろう。
とりあえず、食事内容と体重を管理することがメインのアプリには必要なさそうだけれど。
最後に
チャレンジから3ヶ月が経った。
だがこれ以後、1行たりともコードに触れていない。
開発環境の起動すら、この記事を書くまでしていない。※書いていてもしてない
では、もうスマホアプリ開発はしないのか?
いや。スマホアプリ開発は、いつかリベンジもあるかもしれない。
その時は、家計簿アプリに挑戦するだろう。
画面からWebAPIを呼んでデータを登録するような…(無茶振りは続く)