はじめに
- 今回も始めていきます.
前回の記事はこちらから
前回発覚した課題点に関して
- #1のおわりにで端末ごとに見え方が変わってしまう現象を調査しないと…という記載をしていた件に関して、Android 10 (API レベル 29)以降で端末側にダークテーマという設定が実装されたようです.これは端末側で一部アプリなどの見え方を暗くすることで、節電などの効果をもたらす機能のようですが、#0時点でアプリが初期設定であったため、バックグラウンドカラーを明示的に指定していなかったたことで、端末側でダークモード時のカラーが適応されたと思われます.
原因が特定できたのとレイアウトが崩れるわけではなさそうなので今回はいったん対応せずに進めます.
登録画面の機能をつめていく
-
前回は登録画面のレイアウト配置をざっくり行いました.
ボタンが左寄りにずれてたり、配置がそろってなかったりしたので前回の最後から以下のように修正してます. -
前回の最後
- 修正後
- 今回の作業の話に移りますが、前回作ったのはGUIだけなので、裏ではいろいろエラーが出ている状態です.なのでそれを片付けていきます.
-
赤で囲った部分に赤や黄色のアイコンがついているのがわかります.いうまでもなくすべてエラーやそれに類しているので直していきます.
アイコンを押すと画面下のほうに画像のようなタブが出てくるのでエラー文に沿って直していくか、fixボタンもあるのでそこを押して簡単に治せるものは直していきます.
-
また、warningで「Hardcoded text」と出ているので、表示テキストをres/values/string.xmlにまとめてそこから呼び出すようにします.
例えば一番上の「タスク/スケジュールを入力…」はこんな感じで記載します.
-
配置した要素のidが初期設定のままだったので、このタイミングでidも変えていきます.
idの変更は右のタブの項目「id」から変更できます.
-
エラー内容が、「target size too small」(テキストエリアの高さが足りない)と上記の「hardcoded text」だったのでこれでエラーはほぼ解消できました.
一覧画面を仮置きする
- File/New/Activity/Empty Activityから新しい画面を作っていきます.今回は一覧画面を作りたいのでListActivityとします.ほかの項目は「Generate a layout file」にチェックが入っていれば自動補完されるのでそのままfinishを押下します.
※デフォルトはkotlinファイルが生成されるので、javaにしたい場合は適宜変更してください
- activity_list.xmlを開いてButtons/FloatingActionButtonを追加しました.設置した瞬間にボタンのデザインを聞かれるのでしっくりくるものを選択します.このボタンから先ほどの登録ボタンへ遷移する想定です.
※上記のボタン設定だと以下のようなwarningが出るようです.「その色設定だと見えにくくない?」みたいな注意のようですが、後々のデザインで色は変える可能性が高いことと、正常に見えている(と思っている)のでこのまま進めます.
The image's contrast ratio is 1.77. This ratio is based on an estimated foreground color of #FFFFFF and an estimated background color of #03DAC5. Consider increasing this ratio to 3.00 or greater.
起動時の画面を変更する
-
一覧画面(仮)ができましたが、このままだと実機で起動したときにどこにもつながっていないため画面を表示させることができません.
-
また、起動後の動作としては、
一覧画面 → +ボタン押下 → 登録画面
を想定しているため、起動時の画面を変更していきます.
app/manifests/AndroidManifest.xmlに下記の記述があります.
<activity
android:name=".ListActivity"
android:exported="false" />
<activity
android:name=".MainActivity"
android:exported="true" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
intent-filterのタグが.MainActivity下にあるため、.ListActivity下に移動させます.
<activity
android:name=".MainActivity"
android:exported="false" />
<activity
android:name=".ListActivity"
android:exported="true" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
この状態でビルドしなおして実機で起動してみます.
現時点でボタンに機能を付けていないため登録画面へ遷移はしないですが、無事起動画面が変わりました.
おわりに
- 長くなってきたのでここまでにします.
今回はエラーの解消と一覧画面の仮置きを行いました.
次回は画面遷移をメインに行っていく予定です.余力があればDBの準備ぐらいまで行いたい.
参考資料まとめ
- ダークテーマに関する挙動
- コントラストの注意事項
- 起動時の画面変更