このページの本文へ

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

SDLのライブラリを組み込み、車載機のユーザーインターフェースを実現してみよう!

SDL対応アプリ開発環境の構築その4~白紙のiOSプロジェクトから作るSDLアプリ

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

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

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

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

最小限の動作を確認する

 ここまでできたら、白紙のプロジェクトから作ったiOSアプリも、最小限のSDLアプリとして機能するようになっているはずだ。車載機エミュレーター環境を準備してから、アプリを起動してみよう。

 アプリを起動すると、これまでの操作に誤りがなければ、車載機タのアプリ一覧画面には、SDLのアイコンとともに「MyFirstSDLApp」というアプリ名が表示されるはずだ(図10)。

図10:Linux上の車載機エミュレーター環境を準備してからアプリを起動すると、最初のアプリ一覧画面に「MyFirstSDLApp」のタイトルとアイコンが表示される

 もちろん、そのアプリアイコンをクリックすると、アプリ固有の画面に切り替わる(図11)。

図11:前の画面のアプリアイコンをクリック(タップ)すると、「MyFirstSDLApp」固有のアプリ画面に移行する。アプリ名だけを表示するブランクの状態だ

 ただし、まだ何も中身のユーザーインターフェースを設定していないので、アプリ名と、アプリ一覧画面に戻るボタン「APPS」、それとメニュー画面を呼び出す「≡」ボタンが表示されるだけとなっている。

アプリ画面に任意の文字を表示する

 ここから車載機に表示するユーザーインターフェースを少しずつカスタマイズしていく。まずは最もシンプルなテキストの表示機能を試そう。これはAndroidの例でも示したものだが、iOSのSwiftでは、よりコンパクトな書き方が可能となっている。

 まず、このテキスト表示を始めとするカスタマイズのコードを書く場所だが、上で述べたように、デリゲートメソッドのhmiLevel()を利用して、タイミングを計ることにする。それによって知ることのできる車載機の動作レベルが「フル稼働状態」になってから設定するのが妥当だ。そこで、このメソッドに渡されてくる引数のnewLevelを調べ、それが.fullになったときに車載機画面に表示するテキストを設定することにしよう。

 テキストの設定に限らず、車載機のユーザーインターフェースをアプリから更新する前と後には、必ず実行しなければならないメソッドがある。

 更新前に実行するのは、SdlManagerオブジェクトのプロパティに含まれるスクリーンマネージャ(screenManager)が持つbeginUpdates()というメソッドだ。これを実行してから、UIをアップデートするためのコードを実行し、最後にやはりスクリーンマネージャのendUpdatesを非同期的に実行する。これは応答を返すので、エラーがないかどうかチェックする必要がある。

 iOSの場合は、特にRPCによってアプリと車載機が通信することを意識することなく、UPのアップデートは、ほとんどスクリーンマネージャに任せることができる。

 アプリ画面にテキスト表示するコードも、実はスクリーンマネージャのプロパティに表示したいテキストを設定しているだけだ。

sdlManager.screenManager.textField1 = "Text Field Line 1"
sdlManager.screenManager.textField2 = "Text Field Line 2"
sdlManager.screenManager.textField3 = "Text Field Line 3"
sdlManager.screenManager.textField4 = "Text Field Line 4"

 この例では、4行のテキストを設定しているが、やはり車載機側のテンプレートによって、実際に表示可能なテキストの行数や、それぞれの表示のされ方(フォント、サイズ)は異なる。このプログラムは、番号付きのテキストを4行表示させようとすることで、このテンプレートの場合、何行までの文字列が、それぞれどのように表示されるかをテストするものだ。

 この最初のテキスト表示のコードは、hmiLevel()メソッドの中で、車載機の可動レベルのチェックとともに、以下のように書くことで、実際にUIのアップデートが可能となる。

if newLevel == .full {
    sdlManager.screenManager.beginUpdates()
 
    sdlManager.screenManager.textField1 = "Text Field Line 1"
    sdlManager.screenManager.textField2 = "Text Field Line 2"
    sdlManager.screenManager.textField3 = "Text Field Line 3"
    sdlManager.screenManager.textField4 = "Text Field Line 4"
 
    sdlManager.screenManager.endUpdates { (error) in
        if error != nil {
            print("UI Updated Successfully!");
        } else {
            print("UI Update Failed with Error: \(String(describing:  error))");
        }
    }
}

 上のコードをProxyManager.swiftの中に記述する位置も含めて、念のためにスクリーンショットで確認しておこう。PloxyManagerクラスに追加した2つのデリゲートメソッドのうち、2番めのhmiLevel()内で、コンソールへのログ出力の後に付け加えた(図12)。

図12:上のコードをPloxyManagerクラスに追加したデリゲートメソッドhmiLevel()の中に実装する

 テキスト表示のためのコードを追加したアプリを動かして結果を確認しておこう。アプリ固有の画面を見ると、このアプリ画面を表示しているデフォルトの(MEDIA)テンプレートでは、3行までの文字列までが表示できていることがわかる(図13)。

図13:4行のテキストフィールドを表示させるようにプログラムしたが、デフォルトのテンプレートでは、そのうち3行までを表示できる。その3つのテキストの位置や色、サイズもあらかじめ決められている

カテゴリートップへ

この連載の記事

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,890
2
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 ホワイト
¥740
3
CIO フラットスパイラルケーブル CtoC 1m (Type-C/USB-C) PD 急速充電 平型 磁石 マグネット吸着 まとまる 充電ケーブル PD 240W データ転送 480Mbps (ライトブラック, 1m)
CIO フラットスパイラルケーブル CtoC 1m (Type-C/USB-C) PD 急速充電 平型 磁石 マグネット吸着 まとまる 充電ケーブル PD 240W データ転送 480Mbps (ライトブラック, 1m)
¥1,980
4
エレコム 電源タップ 6個口 3m 雷ガード 個別スイッチ ほこりシャッター付 耐熱 PSE技術基準適合 ブラック T-K6A-2630BK
エレコム 電源タップ 6個口 3m 雷ガード 個別スイッチ ほこりシャッター付 耐熱 PSE技術基準適合 ブラック T-K6A-2630BK
¥2,111
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
【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限定 壁紙ダウンロード付き
¥7,040
7
Verbatim バーベイタム 1回録画用 ブルーレイディスク BD-R 25GB 50枚+3枚増量パック インクジェットプリンタ対応 ホワイト 片面1層 1-6倍速
Verbatim バーベイタム 1回録画用 ブルーレイディスク BD-R 25GB 50枚+3枚増量パック インクジェットプリンタ対応 ホワイト 片面1層 1-6倍速
¥2,480
8
UGREEN USB Type Cケーブル PD対応 100W/5A 超急速充電 USB C ナイロン編み 断線防止 iphone17/16/15シリーズ/iPad/MacBook Pro/Galaxy S24/Matebook/iPad/Xperia等USB-C各種対応(1m, ブラック)
UGREEN USB Type Cケーブル PD対応 100W/5A 超急速充電 USB C ナイロン編み 断線防止 iphone17/16/15シリーズ/iPad/MacBook Pro/Galaxy S24/Matebook/iPad/Xperia等USB-C各種対応(1m, ブラック)
¥1,299
9
Amazon Kindle - 目に優しい、かさばらない、大きな画面で読みやすい、6週間持続バッテリー、6インチディスプレイ電子書籍リーダー、ブラック、16GB、広告なし
Amazon Kindle - 目に優しい、かさばらない、大きな画面で読みやすい、6週間持続バッテリー、6インチディスプレイ電子書籍リーダー、ブラック、16GB、広告なし
¥19,980
10
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
¥980

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

デジタル用語辞典

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