編寫:huanglizhuo - 原文:http://developer.android.com/training/tv/playback/card.html
在前面的課程中,我們創(chuàng)建一個目錄瀏覽器,實現(xiàn)了瀏覽 fragment,顯示了媒體項目的列表。在本課程中,我們將創(chuàng)建該卡視圖的媒體項目,并在瀏覽fragment中呈現(xiàn)出來。
BaseCardView類以及子類顯示與媒體項目相關(guān)聯(lián)的元數(shù)據(jù)。在本節(jié)課程中使用的ImageCardView類顯示隨著媒體項目的標(biāo)題內(nèi)容的圖像。
這節(jié)課介紹了GitHub上 Android Leanback sample app的示例應(yīng)用程序代碼。使用該示例代碼,開始我們自己的應(yīng)用程序。
http://wiki.jikexueyuan.com/project/android-training-geek/images/app-browse.png" alt="app-browse" />
Presenter生成視圖并把類和它們綁定起來。在我們的瀏覽 fragment 中將內(nèi)容呈現(xiàn)給用戶,我們?yōu)閮?nèi)容卡片創(chuàng)建Presenter并把它傳給適配器然后將內(nèi)容呈現(xiàn)在屏幕上。在下面的代碼中,CardPresenter在 LoaderManager的[onLoadFinished](http://developer.android.com/reference/android/support/v4/app/LoaderManager.LoaderCallbacks.html#onLoadFinished(android.support.v4.content.Loader
@Override
public void onLoadFinished(Loader<HashMap<String, List<Movie>>> arg0,
HashMap<String, List<Movie>> data) {
mRowsAdapter = new ArrayObjectAdapter(new ListRowPresenter());
CardPresenter cardPresenter = new CardPresenter();
int i = 0;
for (Map.Entry<String, List<Movie>> entry : data.entrySet()) {
ArrayObjectAdapter listRowAdapter = new ArrayObjectAdapter(cardPresenter);
List<Movie> list = entry.getValue();
for (int j = 0; j < list.size(); j++) {
listRowAdapter.add(list.get(j));
}
HeaderItem header = new HeaderItem(i, entry.getKey(), null);
i++;
mRowsAdapter.add(new ListRow(header, listRowAdapter));
}
HeaderItem gridHeader = new HeaderItem(i, getString(R.string.more_samples),
null);
GridItemPresenter gridPresenter = new GridItemPresenter();
ArrayObjectAdapter gridRowAdapter = new ArrayObjectAdapter(gridPresenter);
gridRowAdapter.add(getString(R.string.grid_view));
gridRowAdapter.add(getString(R.string.error_fragment));
gridRowAdapter.add(getString(R.string.personal_settings));
mRowsAdapter.add(new ListRow(gridHeader, gridRowAdapter));
setAdapter(mRowsAdapter);
updateRecommendations();
}
在這步中,我們將用view holder創(chuàng)建一個卡片presenter來為卡片視圖呈現(xiàn)媒體項目。注意,每個presenter只能創(chuàng)建一個view類別。如果我們有倆個不同的卡片視圖,我們就得創(chuàng)建倆個不同的presenter
在presenter實現(xiàn)onCreateViewHolder時創(chuàng)建一個可以呈現(xiàn)內(nèi)容項目的view holder。
@Override
public class CardPresenter extends Presenter {
private Context mContext;
private static int CARD_WIDTH = 313;
private static int CARD_HEIGHT = 176;
private Drawable mDefaultCardImage;
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent) {
mContext = parent.getContext();
mDefaultCardImage = mContext.getResources().getDrawable(R.drawable.movie);
...
在onCreateViewHolder方法中,創(chuàng)建呈現(xiàn)內(nèi)容的卡片視圖。下面的例子用的是ImageCardView
當(dāng)卡片被選中時,默認(rèn)的行為是放大展開。如果我們想創(chuàng)建不同顏色的卡片可以向下面這樣調(diào)用setSelected方法中實現(xiàn)。
...
ImageCardView cardView = new ImageCardView(mContext) {
@Override
public void setSelected(boolean selected) {
int selected_background = mContext.getResources().getColor(R.color.detail_background);
int default_background = mContext.getResources().getColor(R.color.default_background);
int color = selected ? selected_background : default_background;
findViewById(R.id.info_field).setBackgroundColor(color);
super.setSelected(selected);
}
};
...
當(dāng)用戶打開我們的應(yīng)用時,Presenter.ViewHolder 為內(nèi)容項目顯示了卡片視圖。我們需要調(diào)用setFocusable(true) 和setFocusableInTouchMode(true)方法設(shè)置接收來自D-pad的焦點控制。
...
cardView.setFocusable(true);
cardView.setFocusableInTouchMode(true);
return new ViewHolder(cardView);
}
當(dāng)用戶選中ImageCardView時,它用我們制定的顏色背景展開文字內(nèi)容,就像下面這樣。
http://wiki.jikexueyuan.com/project/android-training-geek/images/card-view.png" alt="card-view" />