13
11

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

AndroidTV:ListRow, ListRowPresenter

Posted at

Introduction

Android leanback support libraryにはコンテンツ表示用のAPIがいくつか備わっている.
ここではコンテンツを水平方向に並べるAPIについて記載する.

Blog: Yukiの枝折

Overview

AndroidTVのデザインガイドラインには, 画面上下はカテゴリ等のセクション領域として確保する方針が書かれている.
そのためコンテンツのリストは垂直展開するListViewより水平展開するGridViewが好まれる.

enter image description here
[カテゴリ毎のメディアコンテンツリスト]

###Horizontal list
Android leanback support libraryではコンテンツをリスト管理するためのクラスを提供する.

  • ListRow
  • ListRowPresenter

下記はこれらを使用したサンプルコード.

private ArrayObjectAdapter mRowsAdapter;
private static final int NUM_ROWS = 4;

private void buildRowsAdapter() {
    mRowsAdapter = new ArrayObjectAdapter(new ListRowPresenter());

    for (int i = 0; i < NUM_ROWS; ++i) {
        ArrayObjectAdapter listRowAdapter = new ArrayObjectAdapter(
                new StringPresenter());
        listRowAdapter.add("Media Item 1");
        listRowAdapter.add("Media Item 2");
        listRowAdapter.add("Media Item 3");
        HeaderItem header = new HeaderItem(i, "Category " + i, null);
        mRowsAdapter.add(new ListRow(header, listRowAdapter));
    }

    mBrowseFragment.setAdapter(mRowsAdapter);
}

ListRowはRowのサブクラスであるため, HeaderItemを持つ.
更にHeaderItemに紐づくコンテンツを子要素として管理するよう拡張されている.

下図はListRowの構造.

ListRow Structure
[ListRow]

ListRowは子要素をObjectArrayで保持する.
上記サンプルコードではStringStringPresenterのセット(listRowAdapter)になる.
※StringPresenterは別途用意したString専用のPresenter

下図は子要素の構造.

Child Elements
[Child Elements]

これら行リストは水平方向へ展開するためにしばしばHorizontalGridViewにバインドされる.

###Vertical list
ListRowは行のリスト表現である.
ここにヘッダ(カテゴリ等)を追加し, 列リストを形成するためにListRowをArrayObjectAdapterで管理する.
これにより複数行リスト(列×行)を作成し, ListRowを列リストとして表現する.

ListRowがModelで, ListRowPresenterがPresenterとして作用する.
最終的なデータ構造は次の通り.

List Structure
[ListRows]

これら列リストは垂直方向へ展開するためにしばしばVertialGridViewにバインドされる.

APIs

###ListRow
android.support.v17.leanback.widget.Row
 ┗android.support.v17.leanback.widget.ListRow

####Class Overview

A row composed of a optional HeaderItem, and an ObjectAdapter describing children.

HeaderItem(任意)と, 子要素が定義されたObjectAdapterから構成される.

####Summary
ListRow(HeaderItem header, ObjectAdapter adapter)
: > (no discription)
: ListRowを初期化する. 行のメタ情報となるHeaderItemと, コンテンツをリスト表示するObjectAdapterを引数に取る

getAdapter()
: > Get the ObjectAdapter that represents a list of objects.
: コンテンツをリスト表示するObjectAdapterを返却する


###ListRowPresenter
android.support.v17.leanback.widget.Presenter
 ┗android.support.v17.leanback.widget.RowPresenter
   ┗android.support.v17.leanback.widget.ListRowPresenter

####Class Overview

ListRowPresenter renders ListRow using a HorizontalGridView hosted in a ListRowView.

ListRowPresenterはListRowをレンダリングする. ListRowはHorizontalGridViewを持つListRowViewにバインドされる.

#####Hover card

Optionally, setHoverCardPresenterSelector(PresenterSelector) can be used to display a view for the currently focused list item below the rendered list. This view is known as a hover card.

任意で, フォーカスされたアイテムのPresenterSelectorを指定するsetHoverCardPresenterSelector(PresenterSelector)が利用できる.
例えばフォーカスしたアイテムをHover cardのように見せることができる.

#####Selection animation

ListRowPresenter disables RowPresenter's default dimming effect and draw a dim overlay on top of each individual child items. Subclass may override and disable isUsingDefaultListSelectEffect() and write its own dim effect in onSelectLevelChanged(RowPresenter.ViewHolder).

ListRowPresenterはRowPresenterの標準エフェクトを無効化し, フォーカスされていない各行のコンテンツリストにオーバレイの効果を描画する.
サブクラスはisUsingDefaultListSelectEffect()をoverrideしてこれを無効化し, onSelectLevelChanged(RowPresenter.ViewHolder)でエフェクトを再定義できる.

#####Shadow

ListRowPresenter applies a default shadow to child of each view. Call setShadowEnabled(boolean) to disable shadow. Subclass may override and return false in isUsingDefaultShadow() and replace with its own shadow implementation.

ListRowPresenterは標準でViewに影の効果を与える. setShadowEnabled(boolean)でこれを無効化できる.
サブクラスはisUsingDefaultShadow()でfalseを返し,独自の影の効果を実装できる.

####Summary
下記は主なAPI.

ListRowPresenter (int zoomFactor)
: > Constructs a ListRowPresenter with the given parameters.
zoomFactor: Controls the zoom factor used when an item view is focused. One of ZOOM_FACTOR_NONE, ZOOM_FACTOR_SMALL, ZOOM_FACTOR_MEDIUM, ZOOM_FACTOR_LARGE
: ListRowPresenterを初期化する.
引数zoomFactorにはViewがフォーカスされた際のズーム係数を指定する. 係数は次の中から選択する(ZOOM_FACTOR_NONE, ZOOM_FACTOR_SMALL, ZOOM_FACTOR_MEDIUM, ZOOM_FACTOR_LARGE)

setHoverCardPresenterSelector(PresenterSelector selector)
: > Set PresenterSelector used for showing a select object in a hover card.
: 選択されたアイテムをHover cardとして表示するためのPresenterSelectorを設定する

getHoverCardPresenterSelector()
: > Get PresenterSelector used for showing a select object in a hover card.
: 選択されたアイテムをHolver cardとして表示するためのPresenterSelectorを取得する

getShadowEnabled()
: > Returns true if child shadow is enabled.
: 子要素の影効果が有効になっている場合はtrueを返却する

setShadowEnabled(boolean enabled)
: > Enable or disable child shadow.
: 子要素の影効果を有効/無効で設定する

isUsingDefaultShadow()
: > Returns true if SDK >= 18, where default shadow is applied to each individual child of HorizontalGridView.
: SDKバージョンが18以上の場合にtrueを返却する. 標準の影効果はHorizontalGridViewの子要素として個別に充てられる.


License:
Portions of this page are modifications based on work created and shared by the Android Open Source Project
and used according to terms described in the Creative Commons 2.5 Attribution License.

13
11
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
13
11

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?