![[Android]ActionBarにボタン(メニュー)を設置する](https://www.yukiiworks.com/wp-content/uploads/2019/04/android.jpg)
はじめに
AndroidでActionBarにボタンを設置する方法をメモしておきます。
ActionBarに設置したボタンをタップするとメニューが下に出てくるものは調べるとたくさんあったのですがボタンを設置してタップした時に何かしらの処理をするようなコードがなかなか出てこなかったので。
イメージ

このようなボタンを追加していきます。
今回、ボタンイメージはAndroid内蔵の画像イメージを使用します。
リソースファイルの作成
画像の手順に従って新しいメニューのリソースファイルの作成をします。 (AndroidStudio2を使用しています。)
作成する場所はresディレクトリ配下、menuディレクトリの直下に作成します。
ここではmenu_main.xmlのファイル名で作成しました。

作成したリソースファイルに以下のタグを記述します。 ボタンが2つ以上欲しい場合Itemタグを適宜増やしてそれぞれ設定してください。
1 2 3 4 5 6 7 8 | <!--?xml version="1.0" encoding="utf-8"?--> <menu xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto"> <item android:id="@+id/addButton" android:icon="@android:drawable/ic_input_add" android:title="Add" app:showasaction="always"> </item> </menu> |
ソースコード
1 2 3 4 5 | @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.menu_main, menu); return true; } |
設置するアクティビティでonCreateOptionsMenuメソッドをオーバーライドします。 オーバーライドしたらgetMenuInflaterのinflateメソッドに先ほど作成したメニューのリソース(menu_main)を設定します。
アクティビティにボタンが設置できたら次はそのボタンに処理を追加します。
設置したボタンをタップした際の処理はonOptionsItemSelectedメソッドをオーバーライドして以下のように記述できます。
1 2 3 4 5 6 7 8 9 | @Override public boolean onOptionsItemSelected(MenuItem item) { switch (item.getItemId()) { case R.id.addButton: // ボタンをタップした際の処理を記述 break; } return true; } |
Switch文で引数のMenuItemのgetItemIdメソッド調べることでボタンを識別できます。 idはメニューのリソースを作成した時につけたidです。
ボタンを増やしたらcase文を追加していくだけで処理を分岐できます。

![[Swift3]画面の幅、高さを取得する(画面サイズ)](https://www.yukiiworks.com/wp-content/uploads/2019/04/swift-300x300.png)
![[Flutter]debugとreleaseビルドをコードから判別する方法](https://www.yukiiworks.com/wp-content/uploads/2020/08/flutter-150x150.png)
![[DB2]ペンディング状態の解除](https://www.yukiiworks.com/wp-content/uploads/2019/03/code1211IMGL1494_TP_V4-150x150.jpg)
![[iOS13][Process] kill() returned unexpected error 1エラーについて](https://www.yukiiworks.com/wp-content/uploads/2019/09/Xcode-150x150.png)
![[AWS]Node.jsでSSMパラメータストアの値を取得する](https://www.yukiiworks.com/wp-content/uploads/2020/03/aws-eyecatch-960x504-1-150x150.png)
![[Docker]起動済みのMySQLデータを永続化させる](https://www.yukiiworks.com/wp-content/uploads/2019/08/docker-logo-2-150x150.png)
![[frappe-gantt]スクロールバーがかなり下に出るバグの対応方法](https://www.yukiiworks.com/wp-content/uploads/2019/05/javascript-150x150.png)
![[PHP]local.ERROR: compact(): Undefined variable:エラーについて](https://www.yukiiworks.com/wp-content/uploads/2019/06/php-150x150.jpg)
![[Swift4]コードから親View一杯にフィットさせる方法](https://www.yukiiworks.com/wp-content/uploads/2019/04/swift-150x150.png)
