1page.title=TV アプリのビルドを開始する
2page.tags=tv, leanback, recyclerview
3
4trainingnavtop=true
5startpage=true
6
7@jd:body
8
9<div id="tb-wrapper">
10<div id="tb">
11  <h2>学習の目的</h2>
12  <ol>
13    <li><a href="#dev-project">TV プロジェクトをセットアップする</a></li>
14    <li><a href="#tv-libraries">TV サポート ライブラリを追加する</a></li>
15    <li><a href="#build-it">TV アプリをビルドする</a></li>
16    <li><a href="#run">TV アプリを実行する</a></li>
17  </ol>
18  <h2>関連コンテンツ</h2>
19  <ol>
20    <li><a href="{@docRoot}design/tv/index.html">TV 向けデザイン</a></li>
21    <li><a href="{@docRoot}training/tv/start/layouts.html">TV 用のレイアウトをビルドする</a></li>
22  </ol>
23</div>
24</div>
25
26<p>
27  TV アプリでは、携帯電話やタブレット向けのものと同じ構造を使用します。つまり、Android アプリのビルドに関する既知の技術を使用して新たな TV アプリを作成したり、既存のアプリを TV 端末でも使用できるように編集したりできます。
28</p>
29
30<p class="note">
31  <strong>重要:</strong>Google Play で Android TV アプリを提供するには、特定の要件を満たす必要があります。詳細については、<a href="{@docRoot}distribute/essentials/quality/tv.html">TV アプリの品質</a>に記載されている要件を参照してください。
32</p>
33
34<p>
35  このレッスンでは、TV アプリのビルドの際の開発環境の準備方法と、TV 端末上でアプリを使用できるようにするために最低限必要な変更について説明します。
36</p>
37
38
39<h2 id="dev-project">TV プロジェクトをセットアップする</h2>
40
41<p>
42  このセクションでは、TV 端末向けに既存のアプリを変更したり、新しく作成する方法について説明します。TV 端末向けアプリを作成する際に使用する必要がある主なコンポーネントは次のとおりです。
43</p>
44
45<ul>
46  <li><strong>TV 用のアクティビティ</strong>(必須) - アプリのマニフェストで、TV 端末上で動作させるアクティビティを宣言します。</li>
47  <li><strong>TV サポート ライブラリ</strong>(任意) - ユーザー インターフェースのビルド用にウィジェットを提供する、TV 端末向けの<a href="#tv-libraries">サポート ライブラリ</a>をいくつか利用できます。</li>
48</ul>
49
50
51<h3 id="prerequisites">前提条件</h3>
52
53<p>TV 向けアプリのビルドを開始するには:</p>
54
55<ul>
56  <li><strong><a href="{@docRoot}sdk/installing/adding-packages.html#GetTools">SDK ツールをバージョン 24.0.0 以降にアップデートする</a></strong>
57    <br/> SDK ツールをアップデートすると、TV 向けアプリのビルドとテストができるようになります。
58  </li>
59  <li><strong><a href="{@docRoot}sdk/installing/adding-packages.html#GetTools">SDK ツールを Android 5.0(API レベル 21)以降を使用してアップデートする</a></strong>
60    <br/> アップデート後のプラットフォームのバージョンでは、TV アプリ向けの新しい API を提供しています。
61  </li>
62  <li><strong><a href="{@docRoot}sdk/installing/create-project.html">アプリのプロジェクトを作成またはアップデートする</a></strong>
63    <br/> TV 端末用の新しい API にアクセスするには、プロジェクトを作成するか、Android 5.0(API レベル 21)以降をターゲットとする既存のプロジェクトを変更する必要があります。
64  </li>
65</ul>
66
67
68<h3 id="tv-activity">TV アクティビティを宣言する</h3>
69
70<p>TV 端末向けアプリでは、{@link android.content.Intent#CATEGORY_LEANBACK_LAUNCHER} のインテント フィルタを使用して、アプリのマニフェストで TV 用ランチャーのアクティビティを宣言する必要があります。このフィルタは、アプリが TV 向けになっていることを判別しますので、Google Play 内で TV アプリと認識される上で必要です。この宣言は、ユーザーが TV のホーム スクリーンでアプリのアイコンを選択したときに、アプリ内のどのアクティビティが起動するかについても判別します。</p>
71
72<p>次のコード スニペットでは、マニフェストにインテント フィルタを含める方法を示します。</p>
73
74<pre>
75&lt;application
76  android:banner="&#64;drawable/banner" &gt;
77  ...
78  &lt;activity
79    android:name="com.example.android.MainActivity"
80    android:label="@string/app_name" &gt;
81
82    &lt;intent-filter&gt;
83      &lt;action android:name="android.intent.action.MAIN" /&gt;
84      &lt;category android:name="android.intent.category.LAUNCHER" /&gt;
85    &lt;/intent-filter&gt;
86  &lt;/activity&gt;
87
88  &lt;activity
89    android:name="com.example.android.<strong>TvActivity</strong>"
90    android:label="&#64;string/app_name"
91    android:theme="&#64;style/Theme.Leanback"&gt;
92
93    &lt;intent-filter&gt;
94      &lt;action android:name="android.intent.action.MAIN" /&gt;
95      &lt;category android:name="<strong>android.intent.category.LEANBACK_LAUNCHER</strong>" /&gt;
96    &lt;/intent-filter&gt;
97
98  &lt;/activity&gt;
99&lt;/application&gt;
100</pre>
101
102<p>
103  この例では、2 番目のアクティビティのマニフェスト エントリが、TV 端末で起動するアクティビティを指定しています。
104</p>
105
106<p class="caution">
107  <strong>警告:</strong>アプリに {@link android.content.Intent#CATEGORY_LEANBACK_LAUNCHER} インテント フィルタを含めない場合、TV 端末で Google Play ストアを開いているユーザーにアプリが表示されません。開発者ツールを使用して TV 端末にロードする際にこのフィルタがない場合も、TV のユーザー にはアプリインターフェースが表示されません。
108</p>
109
110<p>
111  TV 向け用途で既存のアプリを変更する場合は、携帯電話やタブレットと同じアクティビティのレイアウトを使用しないでください。TV アプリや既存のアプリの TV 向け部分については、ソファでくつろぎながら TV リモコンを使用して、簡単にナビゲートできるシンプルなユーザー インターフェースを提供する必要があります。TV 向けアプリをデザインする際のガイドラインについては、<a href="{@docRoot}design/tv/index.html">TV 向けデザイン</a>ガイドを参照してください。TV のインターフェースのレイアウトに関する最低限の実装要件については<a href="{@docRoot}training/tv/start/layouts.html">TV 用のレイアウトをビルドする</a>を参照してください。
112</p>
113
114
115<h3 id="no-touchscreen">タッチスクリーンの不要を宣言する</h3>
116
117<p>
118  TV 端末向けアプリでは、入力はタッチスクリーンに依存しません 。これを明確にするために、TV アプリのマニフェストで {@code android.hardware.touchscreen} 機能が不要であることを宣言する必要があります。この設定により、アプリが TV 端末向けであると判別しますので、Google Play 内で TV アプリと認識される上で必要です。次のコード例では、マニフェストに宣言を含める方法を示します。
119</p>
120
121<pre>
122&lt;manifest&gt;
123    <strong>&lt;uses-feature android:name="android.hardware.touchscreen"
124              android:required="false" /&gt;</strong>
125    ...
126&lt;/manifest&gt;
127</pre>
128
129<p class="caution">
130  <strong>警告:</strong>このコード例のようにアプリのマニフェストでタッチスクリーンが不要であると宣言しないと、アプリが TV 端末の Google Play ストアに表示されません。
131</p>
132
133<h3 id="banner">ホーム スクリーンにバナーを配置する</h3>
134
135<p>
136  アプリに Leanback ランチャーのインテント フィルタが含まれている場合は、ホーム スクリーンにバナーを配置する必要があります。バナーは、アプリやゲームの行のホーム スクリーン上に表示されるアプリの起動ポイントです。次のようにマニフェストにバナーを記述します。
137</p>
138
139<pre>
140&lt;application
141    ...
142    android:banner="&#64;drawable/banner" &gt;
143
144    ...
145&lt;/application&gt;
146</pre>
147
148<p>
149  <a href="{@docRoot}guide/topics/manifest/application-element.html#banner">{@code android:banner}</a> 属性を使用して、<a href="{@docRoot}guide/topics/manifest/application.html"><code>&lt;application&gt;</code></a> タグとともにアプリのすべてのアクティビティにデフォルトのバナーを配置するか、<a href="{@docRoot}guide/topics/manifest/activity-element.html"><code>&lt;activity&gt;</code></a> タグとともに特定のアクティビティにバナーを配置します。
150</p>
151
152<p>
153  TV 向けデザインの UI パターンガイドの<a href="{@docRoot}design/tv/patterns.html#banner">バナー</a>を参照してください。
154</p>
155
156<h2 id="tv-libraries">TV サポート ライブラリを追加する</h3>
157
158<p>
159  Android SDK には、TV アプリ向けのサポート ライブラリが用意されています。これらのライブラリでは、TV 端末向けに使用できる API とユーザー インターフェース ウィジェットを提供しています。同ライブラリは {@code &lt;sdk&gt;/extras/android/support/} ディレクトリにあります。ライブラリとその全般的な用途の一覧を次に示します。
160</p>
161
162<ul>
163  <li><a href="{@docRoot}tools/support-library/features.html#v17-leanback"> <strong>v17 leanback ライブラリ</strong></a> - 特にメディア再生用のアプリ向けに、TV アプリのユーザー インターフェース ウィジェットを提供します。
164  </li>
165  <li><a href="{@docRoot}tools/support-library/features.html#v7-recyclerview"> <strong>v7 recyclerview ライブラリ</strong></a> - メモリ効率に配慮した方法で、項目の多いリストの表示を管理するためのクラスを提供します。 v17 leanback ライブラリ内のクラスの一部は、このライブラリ内のクラスに依存します。
166  </li>
167  <li><a href="{@docRoot}tools/support-library/features.html#v7-cardview"> <strong>v7 cardview ライブラリ</strong></a> - メディア アイテムの画像や説明などの情報カードを表示するためのユーザー インターフェース ウィジェットを提供します。
168  </li>
169</ul>
170
171<p class="note">
172  <strong>注意:</strong>これらのサポート ライブラリは TV アプリに必須ではありませんが、特にメディア カタログのブラウジング インターフェースを提供するアプリについては使用することを強くお勧めします。
173</p>
174
175<p>
176  v17 leanback ライブラリを使用する場合、<a href="{@docRoot}tools/support-library/features.html#v4">v4 サポート ライブラリ</a> に依存していることに注意してください。つまり、leanback ライブラリを使用するアプリには、次のサポート ライブラリをすべて含める必要があります。
177</p>
178
179<ul>
180  <li>v4 サポート ライブラリ</li>
181  <li>v7 recyclerview サポート ライブラリ</li>
182  <li>v17 leanback サポート ライブラリ</li>
183</ul>
184
185<p>
186  v17 leanback ライブラリには、アプリのプロジェクトに含める際に、特定の手順を踏む必要があるリソースが含まれています。リソースを使用してサポート ライブラリをインポートする手順については、<a href="{@docRoot}tools/support-library/setup.html#libs-with-res">サポート ライブラリのセットアップ</a>を参照してください。
187</p>
188
189
190<h2 id="build-it">TV アプリをビルドする</h2>
191
192<p>上記の手順を完了したら、TV 向けアプリのビルドに取りかかりましょう。TV アプリのビルドに役立つ次の補足的なトピックに目を通してください。 <ul>
193  <li>
194    <a href="{@docRoot}training/tv/playback/index.html">TV 再生アプリのビルド</a> - TV は娯楽用途に特化されていますので、Android では、ユーザーがビデオや音楽を再生したり、必要なコンテンツをブラウズできたりする TV アプリのビルド向けに、ユーザー インターフェース ツールとウィジェット一式を提供しています。
195  </li>
196  <li>
197    <a href="{@docRoot}training/tv/search/index.html">TV でのコンテンツの露出</a> - ユーザーがすべてのコンテンツを見ながら、お目当てのコンテンツを探し出せるようにすることは、コンテンツ自体の提供と同程度に重要です。このトレーニングでは、TV 端末上にコンテンツを露出させる方法について説明します。
198  </li>
199  <li>
200    <a href="{@docRoot}training/tv/games/index.html">TV 向けゲーム</a> - TV 端末は、ゲームに非常に適したプラットフォームです。TV 向けの優れたゲーム エクスペリエンスのビルド方法については、このトピックを参照してください。
201  </li>
202</ul>
203
204
205<h2 id="run">TV アプリを実行する</h2>
206
207<p>
208  アプリの実行は、開発プロセスの重要な一部です。Android SDK の AVD Manager では端末定義を提供しており、アプリの実行やテスト用の仮想 TV 端末を作成することができます。
209</p>
210
211<p>仮想 TV 端末を作成するには:</p>
212
213<ol>
214  <li>AVD Manager を起動します。詳細については、<a href="{@docRoot}tools/help/avd-manager.html">AVD Manager</a> のヘルプを参照してください。</li>
215  <li>[AVD Manager] ダイアログで [<strong>端末定義</strong>] タブをクリックします。</li>
216  <li>Android の TV 端末定義を選択し、[<strong>AVD の作成</strong>] をクリックします。</li>
217  <li>エミュレータのオプションを選択して、[<strong>OK</strong>] をクリックして AVD を作成します。 <p class="note">
218      <strong>注意:</strong>TV 用のエミュレータ端末で最高のパフォーマンスを得るには、[<strong>ホスト GPU を使用</strong>] オプションを有効にし、サポートされている場合には、仮想端末のアクセラレーションを使用します。エミュレータのハードウェア アクセラレーションについては、<a href="{@docRoot}tools/devices/emulator.html#acceleration">エミュレータを使用する</a>を参照してください。
219    </p>
220  </li>
221</ol>
222
223<p>仮想 TV 端末上でアプリをテストするには:</p>
224
225<ol>
226  <li>自分の開発環境に TV アプリをコンパイルします。</li>
227  <li>自分の開発環境からアプリを実行し、ターゲットの TV 仮想端末を選択します。</li>
228</ol>
229
230<p>
231  エミュレータの使用方法については、<a href="{@docRoot}tools/devices/emulator.html">エミュレータを使用する</a>を参照してください。Android Studio から仮想端末へのアプリのデプロイについては、<a href="{@docRoot}sdk/installing/studio-debug.html">Android Studio を使用してデバッグする</a>を参照してください。ADT を使用した Eclipse からエミュレータへのアプリのデプロイについては、<a href="{@docRoot}tools/building/building-eclipse.html">Eclipse から ADT を使用してビルド、実行する</a>を参照してください。
232</p>
233