Android 提供一個(gè)Card視圖

2018-08-02 17:58 更新

編寫:huanglizhuo - 原文:http://developer.android.com/training/tv/playback/card.html

在前面的課程中,我們創(chuàng)建一個(gè)目錄瀏覽器,實(shí)現(xiàn)了瀏覽 fragment,顯示了媒體項(xiàng)目的列表。在本課程中,我們將創(chuàng)建該卡視圖的媒體項(xiàng)目,并在瀏覽fragment中呈現(xiàn)出來(lái)。

BaseCardView類以及子類顯示與媒體項(xiàng)目相關(guān)聯(lián)的元數(shù)據(jù)。在本節(jié)課程中使用的ImageCardView類顯示隨著媒體項(xiàng)目的標(biāo)題內(nèi)容的圖像。

這節(jié)課介紹了GitHub上 Android Leanback sample app的示例應(yīng)用程序代碼。使用該示例代碼,開(kāi)始我們自己的應(yīng)用程序。

app-browse

創(chuàng)建一個(gè)卡片呈現(xiàn)者

Presenter生成視圖并把類和它們綁定起來(lái)。在我們的瀏覽 fragment 中將內(nèi)容呈現(xiàn)給用戶,我們?yōu)閮?nèi)容卡片創(chuàng)建Presenter并把它傳給適配器然后將內(nèi)容呈現(xiàn)在屏幕上。在下面的代碼中,CardPresenter在 LoaderManageronLoadFinished)方法中被創(chuàng)建。

@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();
}

創(chuàng)建一個(gè)卡片視圖

在這步中,我們將用view holder創(chuàng)建一個(gè)卡片presenter來(lái)為卡片視圖呈現(xiàn)媒體項(xiàng)目。注意,每個(gè)presenter只能創(chuàng)建一個(gè)view類別。如果我們有倆個(gè)不同的卡片視圖,我們就得創(chuàng)建倆個(gè)不同的presenter

presenter實(shí)現(xiàn)onCreateViewHolder)時(shí)創(chuàng)建一個(gè)可以呈現(xiàn)內(nèi)容項(xiàng)目的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)卡片被選中時(shí),默認(rèn)的行為是放大展開(kāi)。如果我們想創(chuàng)建不同顏色的卡片可以向下面這樣調(diào)用setSelected)方法中實(shí)現(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)用戶打開(kāi)我們的應(yīng)用時(shí),Presenter.ViewHolder 為內(nèi)容項(xiàng)目顯示了卡片視圖。我們需要調(diào)用setFocusable(true) )和setFocusableInTouchMode(true))方法設(shè)置接收來(lái)自D-pad的焦點(diǎn)控制。

...
    cardView.setFocusable(true);
    cardView.setFocusableInTouchMode(true);
    return new ViewHolder(cardView);
}

當(dāng)用戶選中ImageCardView時(shí),它用我們制定的顏色背景展開(kāi)文字內(nèi)容,就像下面這樣。

card-view


下一節(jié):創(chuàng)建詳細(xì)信息View >


以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)