1 /* 2 * Copyright (C) 2014 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except 5 * in compliance with the License. You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software distributed under the License 10 * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express 11 * or implied. See the License for the specific language governing permissions and limitations under 12 * the License. 13 */ 14 package androidx.leanback.widget; 15 16 import static androidx.leanback.widget.ObjectAdapter.NO_ID; 17 18 /** 19 * The base class for all rows. A commonly used subclass is the {@link ListRow}. Custom 20 * subclasses may define other types of rows. 21 */ 22 public class Row { 23 24 private static final int FLAG_ID_USE_MASK = 1; 25 private static final int FLAG_ID_USE_HEADER = 1; 26 private static final int FLAG_ID_USE_ID = 0; 27 28 private int mFlags = FLAG_ID_USE_HEADER; 29 private HeaderItem mHeaderItem; 30 private long mId = NO_ID; 31 32 /** 33 * Constructor for a Row. 34 * 35 * @param id The id of the row. 36 * @param headerItem The {@link HeaderItem} for this Row, or null if there 37 * is no header. 38 */ Row(long id, HeaderItem headerItem)39 public Row(long id, HeaderItem headerItem) { 40 setId(id); 41 setHeaderItem(headerItem); 42 } 43 44 /** 45 * Constructor for a Row. 46 * 47 * @param headerItem The {@link HeaderItem} for this Row, or null if there 48 * is no header. 49 */ Row(HeaderItem headerItem)50 public Row(HeaderItem headerItem) { 51 setHeaderItem(headerItem); 52 } 53 54 /** 55 * Constructor for a Row. 56 */ Row()57 public Row() { 58 } 59 60 /** 61 * Returns the {@link HeaderItem} that represents metadata for the row. 62 * 63 * @return The HeaderItem for this row, or null if unset. 64 */ getHeaderItem()65 public final HeaderItem getHeaderItem() { 66 return mHeaderItem; 67 } 68 69 /** 70 * Sets the {@link HeaderItem} that represents metadata for the row. 71 * 72 * @param headerItem The HeaderItem for this Row, or null if there is no 73 * header. 74 */ setHeaderItem(HeaderItem headerItem)75 public final void setHeaderItem(HeaderItem headerItem) { 76 mHeaderItem = headerItem; 77 } 78 79 /** 80 * Sets the id for this row. 81 * 82 * @param id The id of the row. 83 */ setId(long id)84 public final void setId(long id) { 85 mId = id; 86 setFlags(FLAG_ID_USE_ID, FLAG_ID_USE_MASK); 87 } 88 89 /** 90 * Returns a unique identifier for this row. This id can come from one of 91 * three places: 92 * <ul> 93 * <li>If {@link #setId(long)} is ever called on this row, it will return 94 * this id. 95 * <li>If {@link #setId(long)} has not been called but the header item is 96 * not null, the result of {@link HeaderItem#getId()} is returned. 97 * <li>Otherwise {@link ObjectAdapter#NO_ID NO_ID} is returned. 98 * </ul> 99 */ getId()100 public final long getId() { 101 if ( (mFlags & FLAG_ID_USE_MASK) == FLAG_ID_USE_HEADER) { 102 HeaderItem header = getHeaderItem(); 103 if (header != null) { 104 return header.getId(); 105 } 106 return NO_ID; 107 } else { 108 return mId; 109 } 110 } 111 setFlags(int flags, int mask)112 final void setFlags(int flags, int mask) { 113 mFlags = (mFlags & ~mask) | (flags & mask); 114 } 115 getFlags()116 final int getFlags() { 117 return mFlags; 118 } 119 120 /** 121 * Returns true if this Row can be rendered in a visible row view, false otherwise. For example 122 * {@link ListRow} is rendered by {@link ListRowPresenter}. {@link PageRow}, 123 * {@link SectionRow}, {@link DividerRow} are rendered as invisible row views. 124 * @return True if this Row can be rendered in a visible row view, false otherwise. 125 */ isRenderedAsRowView()126 public boolean isRenderedAsRowView() { 127 return true; 128 } 129 } 130