このページの本文へ

車とスマホがつながるSDLの世界 第7回

メニュー画面を表示してみよう

SDL対応アプリ開発環境の構築その3~Android版のSDLのAPIを使いこなす

2019年01月12日 11時00分更新

文● 柴田文彦 編集●アスキー編集部

提供: トヨタ自動車株式会社

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

ソフトボタンの操作に応答してアラートを表示する

 以上のプログラムによって配置した2つのソフトボタンのうち、1つめはクリック(タップ)するたびにステートが切り替わるので、アプリの動作モードをすばやく切り替えるためのボタンなどとして利用できるだろう。

 それに対して、もう1つのボタンのイベントリスナーはnullのままで、まだ何も動作を割り当てていなかった。ここでは、そのボタンをクリックすることでアラートを表示するプログラムを追加することにしよう。その場合のアラートは、もちろんスマホ側ではなく、車載機側の画面に表示される。

 アラートを表示するためのAPIは、これまで示したものに比べてもかなりシンプルで、簡単に利用できる。基本的には、まずAlertクラスのオブジェクトを作成し、そのオブジェクトに表示するテキスト、アラートを閉じる条件、ボタンなどをプロパティとして付加する。その後SdlManagerを使って、RPC経由でアラートオブジェクトを車載機に転送するだけでいい。

 アラートには最大3行のテキストを表示できるが、ここでは2行のテキストを設定し、5秒(5000ミリ秒)後に自動的に閉じるようにする。以下にこのアラートを表示するためのコードを示す。

Alert alert = new Alert();
alert.setAlertText1("Softbutton Pressed!");
alert.setAlertText2("Wait for 5 seconds to dismiss.");
alert.setDuration(5000);
sdlManager.sendRPC(alert);

 SDLの車載機のアラートは、運転中に注視したり、ボタンを探して操作したりする必要がないよう、このように時間が経ったら自動的に閉じるような設定も有効だろう。

 このコードは、上で作った2番めのソフトボタンオブジェクトのイベントリスナーの中に書く。ソフトボタンオブジェクトを作成している部分を含めて、イベントリスナーのコードを以下に示す。

SoftButtonObject button2 = new SoftButtonObject("button2", button2States, button2S1.getName(), null);
button2.setOnEventListener(new SoftButtonObject.OnEventListener() {
    @Override
    public void onPress(SoftButtonObject softButtonObject, OnButtonPress onButtonPress) {
        Alert alert = new Alert();
        alert.setAlertText1("Softbutton Pressed!");
        alert.setAlertText2("Wait for 5 seconds to dismiss.");
        alert.setDuration(5000);
        sdlManager.sendRPC(alert);
    }
 
    @Override
    public void onEvent(SoftButtonObject softButtonObject, OnButtonEvent onButtonEvent) {}
});

 この例でも、動作としては不要なonEvent()メソッドを記述しているが、上で述べたように中身が空でも、このメソッドを記述しておく必要がある。

 以上のコードを加えたアプリを実行して、車載機エミュレーター画面の「Button 2」というラベルのボタンをクリックしてみよう。すると、「Softbutton Pressed!」というメッセージを表示するアラートが表示される(図10)。

図10:アラートを表示するためのコードをイベントリスナー内に加えたことで下の「Button 2」をクリックすると、このようなアラートを表示するようになった

 そしてこのアラートは、「Wait for 5 seconds to dismiss.」と表示されている通り、何もしなくても5秒後には自動的に閉じられる。


メニュー画面にメニューコマンドを追加する

 今回ベースとして利用しているサンプルプロジェクトには、車載機画面右上の「≡」マークのメニューボタン(いわゆるハンバーガーメニュー)を操作すると表示されるメニュー画面のコマンドも1つだけ含まれている。もちろんこのメニュー画面には複数のメニューコマンドを表示し、ユーザーに選択してもらうことができる。

 ここでは、最初からある「Test Command」に加えて、サブメニューを持たない単独のメニューコマンドと、サブメニューを持ったメニュー項目をそれぞれ1つずつ、さらにそのサブメニューとして表示する2つのメニューコマンドを追加する例を示す。

 まずは、サブメニューを持たない単純なメニューコマンド1つを追加してみよう。車載機上のメニューを作成するには、まずメニューコマンドの名前やIDを含むメニュー項目をMenuParamsクラスのオブジェクトとして作成する。必要なプロパティを設定したら、そのオブジェクトを、こんどはAddCommandクラスのオブジェクトにセットする。その後、SdlManagerを使って、そのAddCommandクラスのオブジェクトRPCで送信すればいい。

 このような手順によって、「Menu Item without Submenu」という名前のコマンドをメニュー画面に追加するコードは以下のようになる。

MenuParams menu1 = new MenuParams();
menu1.setParentID(0);
menu1.setPosition(1);
menu1.setMenuName("Menu Item without Submenu");
 
AddCommand addCmd = new AddCommand();
addCmd.setCmdID(11);
addCmd.setMenuParams(menu1);
 
sdlManager.sendRPC(addCmd);

 ここでは、setParentID()メソッドによって親のIDとして0を指定している。これは他のメニューのサブメニューとしてではなく、ルートのメニュー画面に直接表示するものであることを示している。このコードは、上で記述したソフトボタンを追加するためのコードの後ろに続けて書けばいい。念のために、その位置をスクリーンショットで確認しておこう(図11)。

図11:メニューを設定するためのコードは、上でソフトボタンを設定したコードに続けて、やはりperformWelcomeShow()メソッドの中に書く

 このプログラムを動かして結果を確認してみよう。アプリ画面が表示されたら、右上の「≡」のようなボタンをクリックすると、2つのメニューコマンドを持ったメニュー画面が表示される(図12)。

図12:アプリ画面右上のコーナーにある「≡」ボタンをクリックすると、アプリ画面全体がメニュー画面に切り替わる

 元からあった「Test Command」の下に、「Menu Item without Submenu」というメニューコマンドが追加された。このメニュー画面の表示は、右端に「>」のようなマークが表示されていて、サブメニューがありそうにも見える紛らわしい表示となっているが、これは単にメニューコマンドを表しているマークだと考えられる。

カテゴリートップへ

この連載の記事
1
【整備済み品】富士通 ノートパソコン 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)
¥39,800
2
【整備済み品】中古 ノートパソコン NEC VersaPro VKT16/15.6型・第8世代Core i5-8250U(最大動作3.4GHz)/快適メモリ8GB/ 高速SSD 256GB/Win11 Pro/MS Office 2019付属/テンキー付, Webカメラ, USB3.0, HDMI, VGA, 有線LAN, WIFI内蔵, Bluetooth/ACアダプター付属/180日間保証
【整備済み品】中古 ノートパソコン NEC VersaPro VKT16/15.6型・第8世代Core i5-8250U(最大動作3.4GHz)/快適メモリ8GB/ 高速SSD 256GB/Win11 Pro/MS Office 2019付属/テンキー付, Webカメラ, USB3.0, HDMI, VGA, 有線LAN, WIFI内蔵, Bluetooth/ACアダプター付属/180日間保証
¥26,880
3
【整備済み品】富士 通 2in1ノートパソコン V727【本体のみ】/第7世代Core M3/12.3型タッチパネル1920×1080/メモリ 8GB/SSD 128GB/Win 11/MS Office 2019/USB 3.1/Type-C/無線WIFI/オーディオ内蔵/WEBカメラ/初期設定済
【整備済み品】富士 通 2in1ノートパソコン V727【本体のみ】/第7世代Core M3/12.3型タッチパネル1920×1080/メモリ 8GB/SSD 128GB/Win 11/MS Office 2019/USB 3.1/Type-C/無線WIFI/オーディオ内蔵/WEBカメラ/初期設定済
¥9,600
4
Lenovo Chromebook クロームブック IdeaPad Flex 3i Gen8 12.2インチ インテル® プロセッサー N100搭載 メモリ4GB eMMC 64GB バッテリー駆動12.0時間 重量1.25kg アビスブルー 82XH001KJP
Lenovo Chromebook クロームブック IdeaPad Flex 3i Gen8 12.2インチ インテル® プロセッサー N100搭載 メモリ4GB eMMC 64GB バッテリー駆動12.0時間 重量1.25kg アビスブルー 82XH001KJP
¥29,800
5
【Amazon.co.jp限定】 ASUS ノートパソコン Vivobook 15 X1502VA 15.6インチ インテル Core i7 13620H メモリ16GB SSD 1TB Windows 11 バッテリー駆動 8.9時間 重量1.7kg PC Game Pass 3ヶ月利用権付き クワイエットブルー X1502VA-I7H161W
【Amazon.co.jp限定】 ASUS ノートパソコン Vivobook 15 X1502VA 15.6インチ インテル Core i7 13620H メモリ16GB SSD 1TB Windows 11 バッテリー駆動 8.9時間 重量1.7kg PC Game Pass 3ヶ月利用権付き クワイエットブルー X1502VA-I7H161W
¥104,800

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

ASCII倶楽部

注目ニュース

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

プレミアム実機レビュー

ピックアップ
1
KIOXIA(キオクシア) 旧東芝メモリ microSD 128GB UHS-I Class10 (最大読出速度100MB/s) Nintendo Switch動作確認済 国内サポート正規品 メーカー保証5年 KLMEA128G
KIOXIA(キオクシア) 旧東芝メモリ microSD 128GB UHS-I Class10 (最大読出速度100MB/s) Nintendo Switch動作確認済 国内サポート正規品 メーカー保証5年 KLMEA128G
¥1,880
2
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
3
【Amazon.co.jp限定】バッファロー microSD 32GB 100MB/s UHS-1 U1 microSDHC【 Nintendo Switch 対応 】V10 A1 IPX7 Full HD RMSD-032U11HA/N
【Amazon.co.jp限定】バッファロー microSD 32GB 100MB/s UHS-1 U1 microSDHC【 Nintendo Switch 対応 】V10 A1 IPX7 Full HD RMSD-032U11HA/N
¥1,880
4
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
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
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
¥980
7
【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,280
8
バッファロー SDカード 128GB 100MB/s UHS-1 スピードクラス1 VideoSpeedClass10 IPX7 Full HD データ復旧サービス対応 RSDC-128U11HA/N
バッファロー SDカード 128GB 100MB/s UHS-1 スピードクラス1 VideoSpeedClass10 IPX7 Full HD データ復旧サービス対応 RSDC-128U11HA/N
¥2,000
9
キヤノン Canon 純正 インクカートリッジ BCI-381(BK/C/M/Y)+380 5色マルチパック BCI-381+380/5MP 長さ:5.3cm 幅:13.9cm 高さ:10.75cm
キヤノン Canon 純正 インクカートリッジ BCI-381(BK/C/M/Y)+380 5色マルチパック BCI-381+380/5MP 長さ:5.3cm 幅:13.9cm 高さ:10.75cm
¥5,545
10
Amazonベーシック USB-A -ライトニングケーブル ナイロン iPhone充電 Apple MFi認証 iPhone 14/14 Pro/13/13 Pro/12/SE(第2世代)/iPad 各種対応(シルバー 0.9m)
Amazonベーシック USB-A -ライトニングケーブル ナイロン iPhone充電 Apple MFi認証 iPhone 14/14 Pro/13/13 Pro/12/SE(第2世代)/iPad 各種対応(シルバー 0.9m)
¥980

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

デジタル用語辞典

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