提供一个Card视图

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

在前面的课程中,我们创建一个目录浏览器,实现了浏览 fragment,显示了媒体项目的列表。在本课程中,我们将创建该卡视图的媒体项目,并在浏览fragment中呈现出来。

BaseCardView类以及子类显示与媒体项目相关联的元数据。在本节课程中使用的ImageCardView类显示随着媒体项目的标题内容的图像。

这节课介绍了GitHub上 Android Leanback sample app的示例应用程序代码。使用该示例代码,开始我们自己的应用程序。

app-browse

创建一个卡片呈现者

Presenter生成视图并把类和它们绑定起来。在我们的浏览 fragment 中将内容呈现给用户,我们为内容卡片创建Presenter并把它传给适配器然后将内容呈现在屏幕上。在下面的代码中,CardPresenter在 LoaderManageronLoadFinished)方法中被创建。

  1. @Override
  2. public void onLoadFinished(Loader<HashMap<String, List<Movie>>> arg0,
  3. HashMap<String, List<Movie>> data) {
  4. mRowsAdapter = new ArrayObjectAdapter(new ListRowPresenter());
  5. CardPresenter cardPresenter = new CardPresenter();
  6. int i = 0;
  7. for (Map.Entry<String, List<Movie>> entry : data.entrySet()) {
  8. ArrayObjectAdapter listRowAdapter = new ArrayObjectAdapter(cardPresenter);
  9. List<Movie> list = entry.getValue();
  10. for (int j = 0; j < list.size(); j++) {
  11. listRowAdapter.add(list.get(j));
  12. }
  13. HeaderItem header = new HeaderItem(i, entry.getKey(), null);
  14. i++;
  15. mRowsAdapter.add(new ListRow(header, listRowAdapter));
  16. }
  17. HeaderItem gridHeader = new HeaderItem(i, getString(R.string.more_samples),
  18. null);
  19. GridItemPresenter gridPresenter = new GridItemPresenter();
  20. ArrayObjectAdapter gridRowAdapter = new ArrayObjectAdapter(gridPresenter);
  21. gridRowAdapter.add(getString(R.string.grid_view));
  22. gridRowAdapter.add(getString(R.string.error_fragment));
  23. gridRowAdapter.add(getString(R.string.personal_settings));
  24. mRowsAdapter.add(new ListRow(gridHeader, gridRowAdapter));
  25. setAdapter(mRowsAdapter);
  26. updateRecommendations();
  27. }

创建一个卡片视图

在这步中,我们将用view holder创建一个卡片presenter来为卡片视图呈现媒体项目。注意,每个presenter只能创建一个view类别。如果我们有俩个不同的卡片视图,我们就得创建俩个不同的presenter

presenter实现onCreateViewHolder)时创建一个可以呈现内容项目的view holder。

  1. @Override
  2. public class CardPresenter extends Presenter {
  3. private Context mContext;
  4. private static int CARD_WIDTH = 313;
  5. private static int CARD_HEIGHT = 176;
  6. private Drawable mDefaultCardImage;
  7. @Override
  8. public ViewHolder onCreateViewHolder(ViewGroup parent) {
  9. mContext = parent.getContext();
  10. mDefaultCardImage = mContext.getResources().getDrawable(R.drawable.movie);
  11. ...

onCreateViewHolder)方法中,创建呈现内容的卡片视图。下面的例子用的是ImageCardView

当卡片被选中时,默认的行为是放大展开。如果我们想创建不同颜色的卡片可以向下面这样调用setSelected)方法中实现。

  1. ...
  2. ImageCardView cardView = new ImageCardView(mContext) {
  3. @Override
  4. public void setSelected(boolean selected) {
  5. int selected_background = mContext.getResources().getColor(R.color.detail_background);
  6. int default_background = mContext.getResources().getColor(R.color.default_background);
  7. int color = selected ? selected_background : default_background;
  8. findViewById(R.id.info_field).setBackgroundColor(color);
  9. super.setSelected(selected);
  10. }
  11. };
  12. ...

当用户打开我们的应用时,Presenter.ViewHolder 为内容项目显示了卡片视图。我们需要调用setFocusable(true) )和setFocusableInTouchMode(true))方法设置接收来自D-pad的焦点控制。

  1. ...
  2. cardView.setFocusable(true);
  3. cardView.setFocusableInTouchMode(true);
  4. return new ViewHolder(cardView);
  5. }

当用户选中ImageCardView时,它用我们制定的颜色背景展开文字内容,就像下面这样。

card-view


下一节:创建详细信息View >