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 android.graphics.drawable.Drawable; 17 import android.text.TextUtils; 18 19 import java.util.ArrayList; 20 21 /** 22 * An action contains one or two lines of text, an optional image and an optional id. It may also 23 * be invoked by one or more keycodes. 24 */ 25 public class Action { 26 27 /** Indicates that an id has not been set. */ 28 public static final long NO_ID = -1; 29 30 private long mId = NO_ID; 31 private Drawable mIcon; 32 private CharSequence mLabel1; 33 private CharSequence mLabel2; 34 private ArrayList<Integer> mKeyCodes = new ArrayList<>(); 35 36 /** 37 * Constructor for an Action. 38 * 39 * @param id The id of the Action. 40 */ Action(long id)41 public Action(long id) { 42 this(id, ""); 43 } 44 45 /** 46 * Constructor for an Action. 47 * 48 * @param id The id of the Action. 49 * @param label The label to display for the Action. 50 */ Action(long id, CharSequence label)51 public Action(long id, CharSequence label) { 52 this(id, label, null); 53 } 54 55 /** 56 * Constructor for an Action. 57 * 58 * @param id The id of the Action. 59 * @param label1 The label to display on the first line of the Action. 60 * @param label2 The label to display on the second line of the Action. 61 */ Action(long id, CharSequence label1, CharSequence label2)62 public Action(long id, CharSequence label1, CharSequence label2) { 63 this(id, label1, label2, null); 64 } 65 66 /** 67 * Constructor for an Action. 68 * 69 * @param id The id of the Action. 70 * @param label1 The label to display on the first line of the Action. 71 * @param label2 The label to display on the second line of the Action. 72 * @param icon The icon to display for the Action. 73 */ Action(long id, CharSequence label1, CharSequence label2, Drawable icon)74 public Action(long id, CharSequence label1, CharSequence label2, Drawable icon) { 75 setId(id); 76 setLabel1(label1); 77 setLabel2(label2); 78 setIcon(icon); 79 } 80 81 /** 82 * Sets the id for this Action. 83 */ setId(long id)84 public final void setId(long id) { 85 mId = id; 86 } 87 88 /** 89 * Returns the id for this Action. 90 */ getId()91 public final long getId() { 92 return mId; 93 } 94 95 /** 96 * Sets the first line label for this Action. 97 */ setLabel1(CharSequence label)98 public final void setLabel1(CharSequence label) { 99 mLabel1 = label; 100 } 101 102 /** 103 * Returns the first line label for this Action. 104 */ getLabel1()105 public final CharSequence getLabel1() { 106 return mLabel1; 107 } 108 109 /** 110 * Sets the second line label for this Action. 111 */ setLabel2(CharSequence label)112 public final void setLabel2(CharSequence label) { 113 mLabel2 = label; 114 } 115 116 /** 117 * Returns the second line label for this Action. 118 */ getLabel2()119 public final CharSequence getLabel2() { 120 return mLabel2; 121 } 122 123 /** 124 * Sets the icon drawable for this Action. 125 */ setIcon(Drawable icon)126 public final void setIcon(Drawable icon) { 127 mIcon = icon; 128 } 129 130 /** 131 * Returns the icon drawable for this Action. 132 */ getIcon()133 public final Drawable getIcon() { 134 return mIcon; 135 } 136 137 /** 138 * Adds a keycode used to invoke this Action. 139 */ addKeyCode(int keyCode)140 public final void addKeyCode(int keyCode) { 141 mKeyCodes.add(keyCode); 142 } 143 144 /** 145 * Removes a keycode used to invoke this Action. 146 */ removeKeyCode(int keyCode)147 public final void removeKeyCode(int keyCode) { 148 mKeyCodes.remove(keyCode); 149 } 150 151 /** 152 * Returns true if the Action should respond to the given keycode. 153 */ respondsToKeyCode(int keyCode)154 public final boolean respondsToKeyCode(int keyCode) { 155 return mKeyCodes.contains(keyCode); 156 } 157 158 @Override toString()159 public String toString(){ 160 StringBuilder sb = new StringBuilder(); 161 if (!TextUtils.isEmpty(mLabel1)) { 162 sb.append(mLabel1); 163 } 164 if (!TextUtils.isEmpty(mLabel2)) { 165 if (!TextUtils.isEmpty(mLabel1)) { 166 sb.append(" "); 167 } 168 sb.append(mLabel2); 169 } 170 if (mIcon != null && sb.length() == 0) { 171 sb.append("(action icon)"); 172 } 173 return sb.toString(); 174 } 175 } 176