1/* 2 * Copyright (C) 2006 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17package android.widget; 18 19import android.annotation.Widget; 20import android.content.Context; 21import android.content.res.TypedArray; 22import android.util.AttributeSet; 23import android.widget.RelativeLayout; 24 25/** 26 * <p>A view group with two children, intended for use in ListViews. This item has two 27 * {@link android.widget.TextView TextViews} elements (or subclasses) with the ID values 28 * {@link android.R.id#text1 text1} 29 * and {@link android.R.id#text2 text2}. There is an optional third View element with the 30 * ID {@link android.R.id#selectedIcon selectedIcon}, which can be any View subclass 31 * (though it is typically a graphic View, such as {@link android.widget.ImageView ImageView}) 32 * that can be displayed when a TwoLineListItem has focus. Android supplies a 33 * {@link android.R.layout#two_line_list_item standard layout resource for TwoLineListView} 34 * (which does not include a selected item icon), but you can design your own custom XML 35 * layout for this object. 36 * 37 * @attr ref android.R.styleable#TwoLineListItem_mode 38 * 39 * @deprecated This class can be implemented easily by apps using a {@link RelativeLayout} 40 * or a {@link LinearLayout}. 41 */ 42@Deprecated 43@Widget 44public class TwoLineListItem extends RelativeLayout { 45 46 private TextView mText1; 47 private TextView mText2; 48 49 public TwoLineListItem(Context context) { 50 this(context, null, 0); 51 } 52 53 public TwoLineListItem(Context context, AttributeSet attrs) { 54 this(context, attrs, 0); 55 } 56 57 public TwoLineListItem(Context context, AttributeSet attrs, int defStyleAttr) { 58 this(context, attrs, defStyleAttr, 0); 59 } 60 61 public TwoLineListItem(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) { 62 super(context, attrs, defStyleAttr, defStyleRes); 63 64 final TypedArray a = context.obtainStyledAttributes( 65 attrs, com.android.internal.R.styleable.TwoLineListItem, defStyleAttr, defStyleRes); 66 67 a.recycle(); 68 } 69 70 @Override 71 protected void onFinishInflate() { 72 super.onFinishInflate(); 73 74 mText1 = (TextView) findViewById(com.android.internal.R.id.text1); 75 mText2 = (TextView) findViewById(com.android.internal.R.id.text2); 76 } 77 78 /** 79 * Returns a handle to the item with ID text1. 80 * @return A handle to the item with ID text1. 81 */ 82 public TextView getText1() { 83 return mText1; 84 } 85 86 /** 87 * Returns a handle to the item with ID text2. 88 * @return A handle to the item with ID text2. 89 */ 90 public TextView getText2() { 91 return mText2; 92 } 93 94 @Override 95 public CharSequence getAccessibilityClassName() { 96 return TwoLineListItem.class.getName(); 97 } 98} 99