このページの本文へ

これで作れる! Androidのアプリケーション 第6回

Androidアプリ内で表示されるメニューを作成する

2010年08月05日 12時00分更新

文● 塩田紳二

  • この記事をはてなブックマークに追加
  • 本文印刷

アプリケーション内にメニューを作る

 Androidのアプリケーションではメニューキーを押すことで、アプリケーション独自のメニューを表示させられます。このメニューは普段は隠れていますが、メニューキーを押したときに画面の下部に表示されます。基本的にはアイコンとテキストから構成されていて、タップすると機能が実行されます。

 メニューは、xmlで記述して作ることもできますし、コードからメニューを生成することもできます。今回のサンプルでは、メインアクティビティとアイテム編集アクティビティの2ヵ所でメニューを利用しています。

世界時計ではメニューを2ヵ所で利用している。1つは左画面のメインアクティビティで、もう1つは右画面のアイテムの編集画面

 前者は設定やアイテム追加、アプリケーションの終了などがあり、後者では、設定を保存することなく終了させる取り消し機能とアイテム自体の削除の2つの項目があります。アイテムの削除を編集画面に持ってきたのにはいくつか理由があります。1つは、メイン画面ではアイテムを選択した状態を表すことができないため、どれを削除するのかを指定するのが面倒であること(利用者、コード書く自分両方とも)、簡単に削除できるのもユーザーインターフェースとしてはいいものとは言いがたいので、個々のアイテムの編集画面に移行したのちに削除する仕組みにしました。

 メイン画面のメニュー表示は、初期に書いたものであるため、コードで項目を生成させています。これに対して、アイテム編集画面のメニューは、xmlを使って記述してあります。本来なら両方ともxmlにすべきでしょうが、サンプルという性格上、コードによる記述を残してあります。

メニューで発生するタイミング

 アプリケーション内で、ユーザーがメニューキーを押したとき、以下のようなイベントが発生します。

onCreateOptionMenu
onPrepareOptionMenu
onOptionMenuItemSelected

 最初の「onCreateOptionMenu」は、初めてメニューキーが押されたときのみに呼び出されるもので、通常はここでメニューを生成させます。次の「onPrepareOptionMenu」は、メニューが表示される直前に毎回呼び出されます。ここでは、状態に合わせてメニュー項目の有効、無効などを設定します。最後の「onOptionMenuItemSelected」は、ユーザーがメニュー項目のどれか1つをタップしたあとに呼び出されるものです。

 メニューは、基本的にはユーザーの操作により呼び出されます。このため、あらかじめタイミングを想定することはできません。必要なデータなどがあるなら、onCreateOptionMenuの中で生成するか、あるいはメニューを表示させるアクティビティのonCreateなどで準備しておく必要があります。

コードによるメニューの生成

 まずは、コードを使ってメニューを作る場合を見てみることにしましょう。WorldClock.javaの233行目からが対応するコードになります。

@Override
public boolean onCreateOptionsMenu( Menu menu ) {
  MenuItem itemAdd = menu.add( 0, MENU_ITEM_ADD, 0, R.string.menu_item_add );
  MenuItem itemSet = menu.add( 0, MENU_ITEM_SET, 0, R.string.menu_item_set );
  MenuItem itemDtSet = menu.add( 0, MENU_ITEM_DTSET, 0, R.string.menu_item_dt );
  MenuItem itemEnd = menu.add( 0, MENU_ITEM_END, 0, R.string.menu_item_end );
  itemAdd.setIcon( android.R.drawable.ic_menu_add );
  itemSet.setIcon( android.R.drawable.ic_menu_preferences );
  itemDtSet.setIcon( android.R.drawable.ic_menu_more );
  itemEnd.setIcon( android.R.drawable.ic_menu_close_clear_cancel );
  return true;
}

 onCreateOptionsMenuは、Menuオブジェクトを引数として受け取り、これに対してメニューを追加していきます。あとから参照できるようにMenuItemクラスの変数で追加したメニュー項目を記憶します。これはあとからアイコンをセットするために必要になるからです。やり方としては、後述するメニューのIDを使って、menuオブジェクトからメニュー項目のオブジェクト(MeunItem)を見つける方法もあるのですが、それも記述が少し面倒になるため、ここでは、ローカル変数を作っています。

 ここで、「MENU_ITEM_」で始まる定数は、以下のようにWorldClock.javaの55行目あたりで別途、定義してあります。

private static final int     MENU_ITEM_ADD = 0;
private static final int     MENU_ITEM_SET = 1;
private static final int     MENU_ITEM_DTSET = 2;
private static final int     MENU_ITEM_END = 99;

 コードで記述するやり方はそれほど難しくないため、項目数がそんなにないのならコードで定義してもいいのですが、このように別途IDを定義しなければなりません。このIDは、あとでどのメニュー項目が押されたのかを検出するために使います。こういうIDを定数として管理するのは結構面倒で、まちがって重複した値を定義してしまうこともあります。間違いをなくすには、今回のようにダイレクトに定義するのではなくて、ひとつ前の値に「+1」をするようなコードを使うという方法もあります。ですがxmlを使えば、何も定義する必要はなく、管理がより簡単になります。

 onCreateOptionsMenuでは、メニュー生成が成功したことを通知するためにtrueを返す必要があります。

メニューのアイコンはデフォルトのリソースを使用

 前述の画面を見ると、メニューの4エリアそれぞれにアイコンが表示されています。しかしリソースの「res/drawable-*」を見てもファイルとしては「ic_btn_search.png」しかありません。

 ここで参照されているアイコンは、すべてAndroid自身が持っているリソースを参照しているのです。これは、Android SDKのインストールフォルダにある「platforms」以下にあるフォルダに実際のデータが置かれており、これらに関しては、コード中で名前を指定するだけ(android.R.drawable.XXXX)で利用できます。

システム側で定義されているアイコンは、Android SDKの下のplatformsフォルダの下にある

 アプリケーションを実行するプラットフォームで図柄が違っています。たとえばAndroid 1.6の場合には「ic_menu_add」(android.R.drawable.ic_menu_add)は「platforms\android-4\data\res\drawable」にあります。ところがAndroid 2.1では「platforms\android-4\data\res」には「drawable-hdpi」「drawable-mdpi」「drawable-land-ldpi」の3つにic_menu_addが配置されています。これは解像度や画面の向きに応じて画像を自動的に切り替えることができるようにするためです。前記の名前で指定しておけば、実際の画面の表示密度に合わせて適当なものを選択してくれます。

 なお、こうしたシステム側のリソースを使うには、SDKのインストールフォルダで、APIレベルごとになっているdata/resフォルダを調べてファイル名を得たら、“android.R.”を付けてリソース参照を行ないます。Android自身が表示に使っている画像のすべてをアプリケーションから利用できるわけでなく、このresフォルダ以下にあるもののみです。

カテゴリートップへ

本記事はアフィリエイトプログラムによる収益を得ている場合があります

この連載の記事
1
【Amazon.co.jp限定】Lenovo Chromebook クロームブック Duet 11 10.95インチ MediaTek Kompanio 838 プロセッサー​搭載 メモリ8GB eMMC 128GB 重量1.0kg 83HH000TJP パソコン
【Amazon.co.jp限定】Lenovo Chromebook クロームブック Duet 11 10.95インチ MediaTek Kompanio 838 プロセッサー​搭載 メモリ8GB eMMC 128GB 重量1.0kg 83HH000TJP パソコン
¥61,800
2
HP ノートパソコン 15-fd 15.6インチ インテル Core Ultra 5 125H メモリ16GB SSD512GB Windows 11 Microsoft Office 2024搭載 WPS Office搭載 カメラシャッター 指紋認証 薄型 Copilotキー搭載 ナチュラルシルバー (BJ0M7PA-AAAF)
HP ノートパソコン 15-fd 15.6インチ インテル Core Ultra 5 125H メモリ16GB SSD512GB Windows 11 Microsoft Office 2024搭載 WPS Office搭載 カメラシャッター 指紋認証 薄型 Copilotキー搭載 ナチュラルシルバー (BJ0M7PA-AAAF)
¥130,000
3
Apple 2026 MacBook Air M5チップ搭載13インチノートブック:AIとApple Intelligence、13.6インチLiquid Retinaディスプレイ、16GBユニファイドメモリ、512GB SSDストレージ、12MPセンターフレームカメラ、Touch ID - シルバー
Apple 2026 MacBook Air M5チップ搭載13インチノートブック:AIとApple Intelligence、13.6インチLiquid Retinaディスプレイ、16GBユニファイドメモリ、512GB SSDストレージ、12MPセンターフレームカメラ、Touch ID - シルバー
¥177,333
4
Lenovo ノートパソコン パソコン IdeaPad Slim 3 14.0インチ AMD Ryzen™ 5 8640HS メモリ16GB SSD512GB MS Office搭載 Windows11 バッテリー駆動12.6時間 重量1.39kg ルナグレー 83K90027JP ノートPC
Lenovo ノートパソコン パソコン IdeaPad Slim 3 14.0インチ AMD Ryzen™ 5 8640HS メモリ16GB SSD512GB MS Office搭載 Windows11 バッテリー駆動12.6時間 重量1.39kg ルナグレー 83K90027JP ノートPC
¥108,800
5
【整備済み品】富士通 ノートパソコン LIFEBOOK U9310 13.3型FHD(1920x1080) 超軽薄 ノートPC/第10世代 Core i5-10310U@1.7GHz/ 8GB メモリ/高速ストレージ SSD/Webカメラ/WIFI/Type-C/HDMI/win11&MS Office 2019 搭載 ビジネス 在宅勤務向け パソコン (メモリ:8GB/SSD:256GB)
【整備済み品】富士通 ノートパソコン LIFEBOOK U9310 13.3型FHD(1920x1080) 超軽薄 ノートPC/第10世代 Core i5-10310U@1.7GHz/ 8GB メモリ/高速ストレージ SSD/Webカメラ/WIFI/Type-C/HDMI/win11&MS Office 2019 搭載 ビジネス 在宅勤務向け パソコン (メモリ:8GB/SSD:256GB)
¥35,130

Amazonのアソシエイトとして、ASCII.jpは適格販売により収入を得ています。

ASCII倶楽部

注目ニュース

  • 角川アスキー総合研究所

プレミアム実機レビュー

ピックアップ
1
Anker PowerLine III Flow USB-C & USB-C ケーブル Anker絡まないケーブル 240W 結束バンド付き USB PD対応 シリコン素材採用 iPhone 17 / 16 / 15 / Galaxy iPad Pro MacBook Pro/Air 各種対応 (1.8m ミッドナイトブラック)
Anker PowerLine III Flow USB-C & USB-C ケーブル Anker絡まないケーブル 240W 結束バンド付き USB PD対応 シリコン素材採用 iPhone 17 / 16 / 15 / Galaxy iPad Pro MacBook Pro/Air 各種対応 (1.8m ミッドナイトブラック)
¥1,390
2
KIOXIA(キオクシア) 旧東芝メモリ microSD 128GB UHS-I Class10 (最大読出速度100MB/s) Nintendo Switch動作確認済 国内サポート正規品 メーカー保証5年 KLMEA128G
KIOXIA(キオクシア) 旧東芝メモリ microSD 128GB UHS-I Class10 (最大読出速度100MB/s) Nintendo Switch動作確認済 国内サポート正規品 メーカー保証5年 KLMEA128G
¥2,374
3
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
¥1,025
4
エレコム 電源タップ 6個口 3m 雷ガード 個別スイッチ ほこりシャッター付 耐熱 PSE技術基準適合 ブラック T-K6A-2630BK
エレコム 電源タップ 6個口 3m 雷ガード 個別スイッチ ほこりシャッター付 耐熱 PSE技術基準適合 ブラック T-K6A-2630BK
¥1,590
5
Anker iPhone充電ケーブル PowerLine II ライトニングケーブル MFi認証 超高耐久 iPhone 14 / 14 Pro Max / 14 Plus / 13 / 13 Pro / 12 / 11 / X/XS/XR / 8 Plus 各種対応 (0.9m ホワイト)
Anker iPhone充電ケーブル PowerLine II ライトニングケーブル MFi認証 超高耐久 iPhone 14 / 14 Pro Max / 14 Plus / 13 / 13 Pro / 12 / 11 / X/XS/XR / 8 Plus 各種対応 (0.9m ホワイト)
¥990
6
Anker USB Type C ケーブル PowerLine USB-C & USB-A 3.0 ケーブル iPhone 17 / 16 / 15 /Xperia/Galaxy/LG/iPad Pro/MacBook その他 Android 等 USB-C機器対応 テレワーク リモート 在宅勤務 0.9m ホワイト
Anker USB Type C ケーブル PowerLine USB-C & USB-A 3.0 ケーブル iPhone 17 / 16 / 15 /Xperia/Galaxy/LG/iPad Pro/MacBook その他 Android 等 USB-C機器対応 テレワーク リモート 在宅勤務 0.9m ホワイト
¥660
7
KIOXIA(キオクシア)【日本製】SDカード 64GB SDXC UHS-I Class10 読出速度100MB/s 国内正規品 メーカー保証5年 KLNEA064G
KIOXIA(キオクシア)【日本製】SDカード 64GB SDXC UHS-I Class10 読出速度100MB/s 国内正規品 メーカー保証5年 KLNEA064G
¥1,616
8
NIMASO ガラスフィルム iPad 第11世代(A16) 2025用/iPad 10.9インチ 第10世代 2022用 衝撃吸収 強化 ガラス 保護フィルム 指紋防止 ガイド枠付き NTB22I574
NIMASO ガラスフィルム iPad 第11世代(A16) 2025用/iPad 10.9インチ 第10世代 2022用 衝撃吸収 強化 ガラス 保護フィルム 指紋防止 ガイド枠付き NTB22I574
¥1,359
9
【Amazon.co.jp限定】 ロジクール 静音 ワイヤレス トラックボール マウス M575SPd Bluetooth Logibolt 無線 windows mac iPad OS Chrome トラックボールマウス ブラック M575 M575SP 国内正規品 ※Amazon.co.jp限定 壁紙ダウンロード付き
【Amazon.co.jp限定】 ロジクール 静音 ワイヤレス トラックボール マウス M575SPd Bluetooth Logibolt 無線 windows mac iPad OS Chrome トラックボールマウス ブラック M575 M575SP 国内正規品 ※Amazon.co.jp限定 壁紙ダウンロード付き
¥5,680
10
【Amazon.co.jp限定】 ロジクール ワイヤレスマウス 無線 マウス M185CG 小型 電池寿命最大12ケ月 M185 グレー 国内正規品
【Amazon.co.jp限定】 ロジクール ワイヤレスマウス 無線 マウス M185CG 小型 電池寿命最大12ケ月 M185 グレー 国内正規品
¥999

Amazonのアソシエイトとして、ASCII.jpは適格販売により収入を得ています。

デジタル用語辞典

ASCII.jpメール デジタルMac/iPodマガジン