19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/* 29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2006 The Android Open Source Project 39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License"); 59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License. 69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at 79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software 119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS, 129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and 149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License. 159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.widget; 189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.Context; 209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.database.DataSetObserver; 219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.Parcelable; 229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.SystemClock; 239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.util.AttributeSet; 249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.util.SparseArray; 259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.ContextMenu; 268c6c79f0909ceabeb8abe1013648c31c7582b7adSvetoslav Ganovimport android.view.ContextMenu.ContextMenuInfo; 2775986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganovimport android.view.SoundEffectConstants; 289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.View; 299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.view.ViewDebug; 3075986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganovimport android.view.ViewGroup; 3175986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganovimport android.view.accessibility.AccessibilityEvent; 324213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganovimport android.view.accessibility.AccessibilityManager; 33d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganovimport android.view.accessibility.AccessibilityNodeInfo; 349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/** 369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * An AdapterView is a view whose children are determined by an {@link Adapter}. 379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p> 399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See {@link ListView}, {@link GridView}, {@link Spinner} and 409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link Gallery} for commonly used subclasses of AdapterView. 4161fd1e8d8c3ccf2d6b7d4af1c19e8f0988d5a1ecJoe Fernandez * 4261fd1e8d8c3ccf2d6b7d4af1c19e8f0988d5a1ecJoe Fernandez * <div class="special reference"> 4361fd1e8d8c3ccf2d6b7d4af1c19e8f0988d5a1ecJoe Fernandez * <h3>Developer Guides</h3> 4461fd1e8d8c3ccf2d6b7d4af1c19e8f0988d5a1ecJoe Fernandez * <p>For more information about using AdapterView, read the 4561fd1e8d8c3ccf2d6b7d4af1c19e8f0988d5a1ecJoe Fernandez * <a href="{@docRoot}guide/topics/ui/binding.html">Binding to Data with AdapterView</a> 4661fd1e8d8c3ccf2d6b7d4af1c19e8f0988d5a1ecJoe Fernandez * developer guide.</p></div> 479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic abstract class AdapterView<T extends Adapter> extends ViewGroup { 499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The item view type returned by {@link Adapter#getItemViewType(int)} when 529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the adapter does not want the item's view recycled. 539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int ITEM_VIEW_TYPE_IGNORE = -1; 559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The item view type returned by {@link Adapter#getItemViewType(int)} when 589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the item is a header or footer. 599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int ITEM_VIEW_TYPE_HEADER_OR_FOOTER = -2; 619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The position of the first child displayed 649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 65bea95162ca25bd00b0479d93739b6283795c3986Konstantin Lopyrev @ViewDebug.ExportedProperty(category = "scrolling") 669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int mFirstPosition = 0; 679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The offset in pixels from the top of the AdapterView to the top 709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of the view to select during the next layout. 719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int mSpecificTop; 739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Position from which to start looking for mSyncRowId 769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int mSyncPosition; 789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Row id to look for when data has changed 819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long mSyncRowId = INVALID_ROW_ID; 839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Height of the view when mSyncPosition and mSyncRowId where set 869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long mSyncHeight; 889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * True if we need to sync to mSyncRowId 919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean mNeedSync = false; 939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Indicates whether to sync based on the selection or position. Possible 969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * values are {@link #SYNC_SELECTED_POSITION} or 979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link #SYNC_FIRST_POSITION}. 989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int mSyncMode; 1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Our height after the last layout 1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private int mLayoutHeight; 1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Sync based on the selected child 1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project static final int SYNC_SELECTED_POSITION = 0; 1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Sync based on the first child displayed 1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project static final int SYNC_FIRST_POSITION = 1; 1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Maximum amount of time to spend in {@link #findSyncPosition()} 1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project static final int SYNC_MAX_DURATION_MILLIS = 100; 1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Indicates that this view is currently being laid out. 1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean mInLayout = false; 1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The listener that receives notifications when an item is selected. 1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project OnItemSelectedListener mOnItemSelectedListener; 1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The listener that receives notifications when an item is clicked. 1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project OnItemClickListener mOnItemClickListener; 1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The listener that receives notifications when an item is long clicked. 1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project OnItemLongClickListener mOnItemLongClickListener; 1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * True if the data has changed since the last layout 1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean mDataChanged; 1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The position within the adapter's data set of the item to select 1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * during the next layout. 1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 150bea95162ca25bd00b0479d93739b6283795c3986Konstantin Lopyrev @ViewDebug.ExportedProperty(category = "list") 1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int mNextSelectedPosition = INVALID_POSITION; 1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The item id of the item to select during the next layout. 1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long mNextSelectedRowId = INVALID_ROW_ID; 1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The position within the adapter's data set of the currently selected item. 1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 161bea95162ca25bd00b0479d93739b6283795c3986Konstantin Lopyrev @ViewDebug.ExportedProperty(category = "list") 1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int mSelectedPosition = INVALID_POSITION; 1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The item id of the currently selected item. 1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long mSelectedRowId = INVALID_ROW_ID; 1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * View to show if there are no items to show. 1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 172b6af533114cfa5a4547990e79e96bd0402c47e72Mihai Preda private View mEmptyView; 1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The number of items in the current adapter. 1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 177bea95162ca25bd00b0479d93739b6283795c3986Konstantin Lopyrev @ViewDebug.ExportedProperty(category = "list") 1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int mItemCount; 1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1815e25c2c14593caee5638603120553ae1ec530f85Chet Haase * The number of items in the adapter before a data changed event occurred. 1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int mOldItemCount; 1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Represents an invalid position. All valid positions are in the range 0 to 1 less than the 1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * number of items in the current adapter. 1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final int INVALID_POSITION = -1; 1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Represents an empty or invalid row id 1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static final long INVALID_ROW_ID = Long.MIN_VALUE; 1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The last selected position we used when notifying 1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int mOldSelectedPosition = INVALID_POSITION; 2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The id of the last selected position we used when notifying 2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long mOldSelectedRowId = INVALID_ROW_ID; 2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Indicates what focusable state is requested when calling setFocusable(). 2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * In addition to this, this view has other criteria for actually 2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * determining the focusable state (such as whether its empty or the text 2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * filter is shown). 2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #setFocusable(boolean) 2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @see #checkFocus() 2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private boolean mDesiredFocusableState; 2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private boolean mDesiredFocusableInTouchModeState; 2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 218ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette /** Lazily-constructed runnable for dispatching selection events. */ 2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private SelectionNotifier mSelectionNotifier; 220ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette 221ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette /** Selection notifier that's waiting for the next layout pass. */ 222ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette private SelectionNotifier mPendingSelectionNotifier; 223ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette 2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * When set to true, calls to requestLayout() will not propagate up the parent hierarchy. 2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This is used to layout the children during a layout pass. 2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean mBlockLayoutRequests = false; 2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public AdapterView(Context context) { 231d6479ec5eec13914f656f6be996d95fe1610fd57Alan Viverette this(context, null); 2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public AdapterView(Context context, AttributeSet attrs) { 235d6479ec5eec13914f656f6be996d95fe1610fd57Alan Viverette this(context, attrs, 0); 2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 238617feb99a06e7ffb3894e86a286bf30e085f321aAlan Viverette public AdapterView(Context context, AttributeSet attrs, int defStyleAttr) { 239617feb99a06e7ffb3894e86a286bf30e085f321aAlan Viverette this(context, attrs, defStyleAttr, 0); 240617feb99a06e7ffb3894e86a286bf30e085f321aAlan Viverette } 241617feb99a06e7ffb3894e86a286bf30e085f321aAlan Viverette 242617feb99a06e7ffb3894e86a286bf30e085f321aAlan Viverette public AdapterView(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) { 243617feb99a06e7ffb3894e86a286bf30e085f321aAlan Viverette super(context, attrs, defStyleAttr, defStyleRes); 2444213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov 2454213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov // If not explicitly specified this view is important for accessibility. 2464213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov if (getImportantForAccessibility() == IMPORTANT_FOR_ACCESSIBILITY_AUTO) { 2474213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov setImportantForAccessibility(IMPORTANT_FOR_ACCESSIBILITY_YES); 2484213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov } 2499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Interface definition for a callback to be invoked when an item in this 2539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * AdapterView has been clicked. 2549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public interface OnItemClickListener { 2569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Callback method to be invoked when an item in this AdapterView has 2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * been clicked. 2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * <p> 2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Implementers can call getItemAtPosition(position) if they need 2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * to access the data associated with the selected item. 2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param parent The AdapterView where the click happened. 2659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param view The view within the AdapterView that was clicked (this 2669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * will be a view provided by the adapter) 2679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param position The position of the view in the adapter. 2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param id The row id of the item that was clicked. 2699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void onItemClick(AdapterView<?> parent, View view, int position, long id); 2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Register a callback to be invoked when an item in this AdapterView has 2759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * been clicked. 2769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param listener The callback that will be invoked. 2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setOnItemClickListener(OnItemClickListener listener) { 2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mOnItemClickListener = listener; 2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The callback to be invoked with an item in this AdapterView has 2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * been clicked, or null id no callback has been set. 2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final OnItemClickListener getOnItemClickListener() { 2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mOnItemClickListener; 2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 292fed60953b09c6cd06f7b9579d103c94c0480ddf0Alan Viverette * Call the OnItemClickListener, if it is defined. Performs all normal 293fed60953b09c6cd06f7b9579d103c94c0480ddf0Alan Viverette * actions associated with clicking: reporting accessibility event, playing 294fed60953b09c6cd06f7b9579d103c94c0480ddf0Alan Viverette * a sound, etc. 2959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param view The view within the AdapterView that was clicked. 2979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param position The position of the view in the adapter. 2989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param id The row id of the item that was clicked. 2999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return True if there was an assigned OnItemClickListener that was 3009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * called, false otherwise is returned. 3019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean performItemClick(View view, int position, long id) { 3039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mOnItemClickListener != null) { 3049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project playSoundEffect(SoundEffectConstants.CLICK); 305996a63859fd6e1e77f88ae465afa2c71e4dd3245Alan Viverette mOnItemClickListener.onItemClick(this, view, position, id); 306cbff417962b06cb2d80fe8efe8de31482e7bfcbbAdam Powell if (view != null) { 307cbff417962b06cb2d80fe8efe8de31482e7bfcbbAdam Powell view.sendAccessibilityEvent(AccessibilityEvent.TYPE_VIEW_CLICKED); 308cbff417962b06cb2d80fe8efe8de31482e7bfcbbAdam Powell } 3099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 3109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 3139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Interface definition for a callback to be invoked when an item in this 3179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * view has been clicked and held. 3189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public interface OnItemLongClickListener { 3209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Callback method to be invoked when an item in this view has been 3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * clicked and held. 3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Implementers can call getItemAtPosition(position) if they need to access 3259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * the data associated with the selected item. 3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param parent The AbsListView where the click happened 3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param view The view within the AbsListView that was clicked 3299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param position The position of the view in the list 3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param id The row id of the item that was clicked 3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return true if the callback consumed the long click, false otherwise 3339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id); 3359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Register a callback to be invoked when an item in this AdapterView has 3409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * been clicked and held 3419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param listener The callback that will run 3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setOnItemLongClickListener(OnItemLongClickListener listener) { 3459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!isLongClickable()) { 3469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project setLongClickable(true); 3479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mOnItemLongClickListener = listener; 3499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The callback to be invoked with an item in this AdapterView has 3539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * been clicked and held, or null id no callback as been set. 3549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final OnItemLongClickListener getOnItemLongClickListener() { 3569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mOnItemLongClickListener; 3579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Interface definition for a callback to be invoked when 3619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * an item in this view has been selected. 3629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public interface OnItemSelectedListener { 3649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 365f18c8ddd0f466de4b2f819fbbd612949bd71c532Romain Guy * <p>Callback method to be invoked when an item in this view has been 366f18c8ddd0f466de4b2f819fbbd612949bd71c532Romain Guy * selected. This callback is invoked only when the newly selected 367f18c8ddd0f466de4b2f819fbbd612949bd71c532Romain Guy * position is different from the previously selected position or if 368f18c8ddd0f466de4b2f819fbbd612949bd71c532Romain Guy * there was no selected item.</p> 3699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Impelmenters can call getItemAtPosition(position) if they need to access the 3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * data associated with the selected item. 3729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param parent The AdapterView where the selection happened 3749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param view The view within the AdapterView that was clicked 3759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param position The position of the view in the adapter 3769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param id The row id of the item that is selected 3779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void onItemSelected(AdapterView<?> parent, View view, int position, long id); 3799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Callback method to be invoked when the selection disappears from this 3829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * view. The selection can disappear for instance when touch is activated 3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * or when the adapter becomes empty. 3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param parent The AdapterView that now contains no selected item. 3869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void onNothingSelected(AdapterView<?> parent); 3889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Register a callback to be invoked when an item in this AdapterView has 3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * been selected. 3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param listener The callback that will run 3969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setOnItemSelectedListener(OnItemSelectedListener listener) { 3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mOnItemSelectedListener = listener; 3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public final OnItemSelectedListener getOnItemSelectedListener() { 4029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mOnItemSelectedListener; 4039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Extra menu information provided to the 4079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * {@link android.view.View.OnCreateContextMenuListener#onCreateContextMenu(ContextMenu, View, ContextMenuInfo) } 4089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * callback when a context menu is brought up for this AdapterView. 4099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static class AdapterContextMenuInfo implements ContextMenu.ContextMenuInfo { 4129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public AdapterContextMenuInfo(View targetView, int position, long id) { 4149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project this.targetView = targetView; 4159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project this.position = position; 4169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project this.id = id; 4179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The child view for which the context menu is being displayed. This 4219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * will be one of the children of this AdapterView. 4229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public View targetView; 4249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The position in the adapter for which the context menu is being 4279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * displayed. 4289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int position; 4309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The row id of the item for which the context menu is being displayed. 4339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public long id; 4359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Returns the adapter currently associated with this widget. 4399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The adapter used to provide this view's content. 4419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract T getAdapter(); 4439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Sets the adapter that provides the data and the views to represent the data 4469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * in this widget. 4479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param adapter The adapter to use to create this view's content. 4499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setAdapter(T adapter); 4519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This method is not supported and throws an UnsupportedOperationException when called. 4549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param child Ignored. 4569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws UnsupportedOperationException Every time this method is invoked. 4589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 4609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void addView(View child) { 4619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new UnsupportedOperationException("addView(View) is not supported in AdapterView"); 4629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This method is not supported and throws an UnsupportedOperationException when called. 4669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param child Ignored. 4689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param index Ignored. 4699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws UnsupportedOperationException Every time this method is invoked. 4719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 4739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void addView(View child, int index) { 4749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new UnsupportedOperationException("addView(View, int) is not supported in AdapterView"); 4759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This method is not supported and throws an UnsupportedOperationException when called. 4799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param child Ignored. 4819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param params Ignored. 4829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws UnsupportedOperationException Every time this method is invoked. 4849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 4859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 4869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void addView(View child, LayoutParams params) { 4879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new UnsupportedOperationException("addView(View, LayoutParams) " 4889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project + "is not supported in AdapterView"); 4899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 4929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This method is not supported and throws an UnsupportedOperationException when called. 4939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param child Ignored. 4959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param index Ignored. 4969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param params Ignored. 4979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 4989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws UnsupportedOperationException Every time this method is invoked. 4999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 5019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void addView(View child, int index, LayoutParams params) { 5029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new UnsupportedOperationException("addView(View, int, LayoutParams) " 5039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project + "is not supported in AdapterView"); 5049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This method is not supported and throws an UnsupportedOperationException when called. 5089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param child Ignored. 5109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws UnsupportedOperationException Every time this method is invoked. 5129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 5149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void removeView(View child) { 5159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new UnsupportedOperationException("removeView(View) is not supported in AdapterView"); 5169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This method is not supported and throws an UnsupportedOperationException when called. 5209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param index Ignored. 5229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws UnsupportedOperationException Every time this method is invoked. 5249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 5269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void removeViewAt(int index) { 5279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new UnsupportedOperationException("removeViewAt(int) is not supported in AdapterView"); 5289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This method is not supported and throws an UnsupportedOperationException when called. 5329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws UnsupportedOperationException Every time this method is invoked. 5349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 5369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void removeAllViews() { 5379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new UnsupportedOperationException("removeAllViews() is not supported in AdapterView"); 5389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 5419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project protected void onLayout(boolean changed, int left, int top, int right, int bottom) { 5429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mLayoutHeight = getHeight(); 5439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Return the position of the currently selected item within the adapter's data set 5479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return int Position (starting at 0), or {@link #INVALID_POSITION} if there is nothing selected. 5499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @ViewDebug.CapturedViewProperty 5519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int getSelectedItemPosition() { 5529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mNextSelectedPosition; 5539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The id corresponding to the currently selected item, or {@link #INVALID_ROW_ID} 5579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * if nothing is selected. 5589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @ViewDebug.CapturedViewProperty 5609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public long getSelectedItemId() { 5619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mNextSelectedRowId; 5629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The view corresponding to the currently selected item, or null 5669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * if nothing is selected 5679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract View getSelectedView(); 5699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The data corresponding to the currently selected item, or 5729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * null if there is nothing selected. 5739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public Object getSelectedItem() { 5759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project T adapter = getAdapter(); 5769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int selection = getSelectedItemPosition(); 5779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (adapter != null && adapter.getCount() > 0 && selection >= 0) { 5789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return adapter.getItem(selection); 5799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 5809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return null; 5819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The number of items owned by the Adapter associated with this 5869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * AdapterView. (This is the number of data items, which may be 5875e25c2c14593caee5638603120553ae1ec530f85Chet Haase * larger than the number of visible views.) 5889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 5899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @ViewDebug.CapturedViewProperty 5909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int getCount() { 5919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mItemCount; 5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 5959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Get the position within the adapter's data set for the view, where view is a an adapter item 5969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * or a descendant of an adapter item. 5979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param view an adapter item, or a descendant of an adapter item. This must be visible in this 5999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * AdapterView at the time of the call. 6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return the position within the adapter's data set of the view, or {@link #INVALID_POSITION} 6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * if the view does not correspond to a list item (or it is not currently visible). 6029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int getPositionForView(View view) { 6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project View listItem = view; 6059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try { 6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project View v; 6079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while (!(v = (View) listItem.getParent()).equals(this)) { 6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project listItem = v; 6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } catch (ClassCastException e) { 6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // We made it up to the window without find this list view 6129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return INVALID_POSITION; 6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Search the children for the list item 6169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final int childCount = getChildCount(); 6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project for (int i = 0; i < childCount; i++) { 6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (getChildAt(i).equals(listItem)) { 6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mFirstPosition + i; 6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Child not found! 6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return INVALID_POSITION; 6259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 6289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Returns the position within the adapter's data set for the first item 6299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * displayed on screen. 6309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 6319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The position within the adapter's data set 6329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int getFirstVisiblePosition() { 6349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mFirstPosition; 6359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 6389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Returns the position within the adapter's data set for the last item 6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * displayed on screen. 6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 6419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The position within the adapter's data set 6429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int getLastVisiblePosition() { 6449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mFirstPosition + getChildCount() - 1; 6459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 64875986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov * Sets the currently selected item. To support accessibility subclasses that 64975986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov * override this method must invoke the overriden super method first. 65075986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov * 6519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param position Index (starting at 0) of the data item to be selected. 6529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public abstract void setSelection(int position); 6549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 6569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Sets the view to show if the adapter is empty 6579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6581480fddea874a42adb43b4bcdac6704e4c3e110bAdam Cohen @android.view.RemotableViewMethod 6599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setEmptyView(View emptyView) { 6609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mEmptyView = emptyView; 6619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6624213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov // If not explicitly specified this view is important for accessibility. 663f937313944e0e9dfa4375a275710e420c2a92554Mindy Pereira if (emptyView != null 664f937313944e0e9dfa4375a275710e420c2a92554Mindy Pereira && emptyView.getImportantForAccessibility() == IMPORTANT_FOR_ACCESSIBILITY_AUTO) { 6654213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov emptyView.setImportantForAccessibility(IMPORTANT_FOR_ACCESSIBILITY_YES); 6664213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov } 6674213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov 6689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final T adapter = getAdapter(); 6699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final boolean empty = ((adapter == null) || adapter.isEmpty()); 6709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project updateEmptyStatus(empty); 6719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 6749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * When the current adapter is empty, the AdapterView can display a special view 6759525f2a72e2786f1b53927878dd8234859ea5c39Mark Doliner * called the empty view. The empty view is used to provide feedback to the user 6769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * that no data is available in this AdapterView. 6779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 6789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The view to show if the adapter is empty. 6799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public View getEmptyView() { 6819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return mEmptyView; 6829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 6859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Indicates whether this view is in filter mode. Filter mode can for instance 6869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * be enabled by a user when typing on the keyboard. 6879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 6889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return True if the view is in filter mode, false otherwise. 6899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 6909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean isInFilterMode() { 6919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 6959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setFocusable(boolean focusable) { 6969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final T adapter = getAdapter(); 6979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final boolean empty = adapter == null || adapter.getCount() == 0; 6989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mDesiredFocusableState = focusable; 7009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!focusable) { 7019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mDesiredFocusableInTouchModeState = false; 7029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project super.setFocusable(focusable && (!empty || isInFilterMode())); 7059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 7089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setFocusableInTouchMode(boolean focusable) { 7099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final T adapter = getAdapter(); 7109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final boolean empty = adapter == null || adapter.getCount() == 0; 7119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mDesiredFocusableInTouchModeState = focusable; 7139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (focusable) { 7149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mDesiredFocusableState = true; 7159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project super.setFocusableInTouchMode(focusable && (!empty || isInFilterMode())); 7189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void checkFocus() { 7219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final T adapter = getAdapter(); 7229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final boolean empty = adapter == null || adapter.getCount() == 0; 7239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final boolean focusable = !empty || isInFilterMode(); 7249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // The order in which we set focusable in touch mode/focusable may matter 7259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // for the client, see View.setFocusableInTouchMode() comments for more 7269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // details 7279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project super.setFocusableInTouchMode(focusable && mDesiredFocusableInTouchModeState); 7289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project super.setFocusable(focusable && mDesiredFocusableState); 7299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mEmptyView != null) { 7309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project updateEmptyStatus((adapter == null) || adapter.isEmpty()); 7319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 7359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Update the status of the list based on the empty parameter. If empty is true and 7369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * we have an empty view, display it. In all the other cases, make sure that the listview 7379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is VISIBLE and that the empty view is GONE (if it's not null). 7389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 7399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private void updateEmptyStatus(boolean empty) { 7409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (isInFilterMode()) { 7419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project empty = false; 7429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (empty) { 7459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mEmptyView != null) { 7469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mEmptyView.setVisibility(View.VISIBLE); 7479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project setVisibility(View.GONE); 7489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 7499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // If the caller just removed our empty view, make sure the list view is visible 7509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project setVisibility(View.VISIBLE); 7519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // We are now GONE, so pending layouts will not be dispatched. 7549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Force one here to make sure that the state of the list matches 7559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // the state of the adapter. 7569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mDataChanged) { 7579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project this.onLayout(false, mLeft, mTop, mRight, mBottom); 7589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 7609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mEmptyView != null) mEmptyView.setVisibility(View.GONE); 7619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project setVisibility(View.VISIBLE); 7629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 7669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Gets the data associated with the specified position in the list. 7679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 7689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param position Which data to get 7699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The data associated with the specified position in the list 7709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 7719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public Object getItemAtPosition(int position) { 7729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project T adapter = getAdapter(); 7739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return (adapter == null || position < 0) ? null : adapter.getItem(position); 7749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public long getItemIdAtPosition(int position) { 7779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project T adapter = getAdapter(); 7789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return (adapter == null || position < 0) ? INVALID_ROW_ID : adapter.getItemId(position); 7799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 7829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setOnClickListener(OnClickListener l) { 7839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new RuntimeException("Don't call setOnClickListener for an AdapterView. " 7849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project + "You probably want setOnItemClickListener instead"); 7859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 7889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Override to prevent freezing of any views created by the adapter. 7899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 7909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 7919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project protected void dispatchSaveInstanceState(SparseArray<Parcelable> container) { 7929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project dispatchFreezeSelfOnly(container); 7939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 7949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 7959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 7969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Override to prevent thawing of any views created by the adapter. 7979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 7989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 7999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project protected void dispatchRestoreInstanceState(SparseArray<Parcelable> container) { 8009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project dispatchThawSelfOnly(container); 8019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project class AdapterDataSetObserver extends DataSetObserver { 8049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private Parcelable mInstanceState = null; 8069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 8089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void onChanged() { 8099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mDataChanged = true; 8109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mOldItemCount = mItemCount; 8119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mItemCount = getAdapter().getCount(); 8129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Detect the case where a cursor that was previously invalidated has 8149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // been repopulated with new data. 8159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (AdapterView.this.getAdapter().hasStableIds() && mInstanceState != null 8169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project && mOldItemCount == 0 && mItemCount > 0) { 8179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project AdapterView.this.onRestoreInstanceState(mInstanceState); 8189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mInstanceState = null; 8199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 8209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project rememberSyncState(); 8219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project checkFocus(); 8239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project requestLayout(); 8249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 8279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void onInvalidated() { 8289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mDataChanged = true; 8299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (AdapterView.this.getAdapter().hasStableIds()) { 8319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Remember the current state for the case where our hosting activity is being 8329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // stopped and later restarted 8339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mInstanceState = AdapterView.this.onSaveInstanceState(); 8349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Data is invalid so we should reset our state 8379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mOldItemCount = mItemCount; 8389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mItemCount = 0; 8399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSelectedPosition = INVALID_POSITION; 8409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSelectedRowId = INVALID_ROW_ID; 8419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mNextSelectedPosition = INVALID_POSITION; 8429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mNextSelectedRowId = INVALID_ROW_ID; 8439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mNeedSync = false; 8449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project checkFocus(); 8469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project requestLayout(); 8479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void clearSavedState() { 8509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mInstanceState = null; 8519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8549c17a4c11005877b65d841f4fbd810df89c7c206Adam Powell @Override 8559c17a4c11005877b65d841f4fbd810df89c7c206Adam Powell protected void onDetachedFromWindow() { 8569c17a4c11005877b65d841f4fbd810df89c7c206Adam Powell super.onDetachedFromWindow(); 8579c17a4c11005877b65d841f4fbd810df89c7c206Adam Powell removeCallbacks(mSelectionNotifier); 8589c17a4c11005877b65d841f4fbd810df89c7c206Adam Powell } 8599c17a4c11005877b65d841f4fbd810df89c7c206Adam Powell 8609c17a4c11005877b65d841f4fbd810df89c7c206Adam Powell private class SelectionNotifier implements Runnable { 8619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void run() { 862ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette mPendingSelectionNotifier = null; 863ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette 86499a82437ed8e0537d9a355a124d2bb30aea46ad8Svet Ganov if (mDataChanged && getViewRootImpl() != null 86599a82437ed8e0537d9a355a124d2bb30aea46ad8Svet Ganov && getViewRootImpl().isLayoutRequested()) { 866ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette // Data has changed between when this SelectionNotifier was 867ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette // posted and now. Postpone the notification until the next 868ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette // layout is complete and we run checkSelectionChanged(). 8699c17a4c11005877b65d841f4fbd810df89c7c206Adam Powell if (getAdapter() != null) { 870ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette mPendingSelectionNotifier = this; 8719c17a4c11005877b65d841f4fbd810df89c7c206Adam Powell } 8729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 873ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette dispatchOnItemSelected(); 8749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 8789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void selectionChanged() { 879ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette // We're about to post or run the selection notifier, so we don't need 880ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette // a pending notifier. 881ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette mPendingSelectionNotifier = null; 882ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette 8834213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov if (mOnItemSelectedListener != null 8844213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov || AccessibilityManager.getInstance(mContext).isEnabled()) { 8859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mInLayout || mBlockLayoutRequests) { 8869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // If we are in a layout traversal, defer notification 8879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // by posting. This ensures that the view tree is 888ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette // in a consistent state and is able to accommodate 8899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // new layout or invalidate requests. 8909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mSelectionNotifier == null) { 8919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSelectionNotifier = new SelectionNotifier(); 892ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette } else { 893ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette removeCallbacks(mSelectionNotifier); 8949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8959c17a4c11005877b65d841f4fbd810df89c7c206Adam Powell post(mSelectionNotifier); 8969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 897ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette dispatchOnItemSelected(); 8989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 8999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 902ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette private void dispatchOnItemSelected() { 903ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette fireOnSelected(); 904ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette performAccessibilityActionsOnSelected(); 905ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette } 906ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette 9079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private void fireOnSelected() { 9084213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov if (mOnItemSelectedListener == null) { 9099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return; 9104213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov } 9114213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov final int selection = getSelectedItemPosition(); 9129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (selection >= 0) { 9139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project View v = getSelectedView(); 9149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mOnItemSelectedListener.onItemSelected(this, v, selection, 9159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project getAdapter().getItemId(selection)); 9169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 9179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mOnItemSelectedListener.onNothingSelected(this); 9189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9214213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov private void performAccessibilityActionsOnSelected() { 9224213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov if (!AccessibilityManager.getInstance(mContext).isEnabled()) { 9234213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov return; 9244213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov } 9254213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov final int position = getSelectedItemPosition(); 9264213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov if (position >= 0) { 9274213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov // we fire selection events here not in View 9284213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov sendAccessibilityEvent(AccessibilityEvent.TYPE_VIEW_SELECTED); 9294213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov } 9304213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov } 9314213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov 9329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 93375986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov public boolean dispatchPopulateAccessibilityEvent(AccessibilityEvent event) { 9340b0a41d8e26eaf0f1d9d922621494daf40964a9aSvetoslav Ganov View selectedView = getSelectedView(); 935d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov if (selectedView != null && selectedView.getVisibility() == VISIBLE 936d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov && selectedView.dispatchPopulateAccessibilityEvent(event)) { 937d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov return true; 9380b0a41d8e26eaf0f1d9d922621494daf40964a9aSvetoslav Ganov } 939bad9d97693a784ea37f1510550e0e4a98f9a9180Svetoslav Ganov return false; 940bad9d97693a784ea37f1510550e0e4a98f9a9180Svetoslav Ganov } 941bad9d97693a784ea37f1510550e0e4a98f9a9180Svetoslav Ganov 942bad9d97693a784ea37f1510550e0e4a98f9a9180Svetoslav Ganov @Override 943bad9d97693a784ea37f1510550e0e4a98f9a9180Svetoslav Ganov public boolean onRequestSendAccessibilityEvent(View child, AccessibilityEvent event) { 9446179ea3196e9306d3f14361fe9ef14191b1edba6Svetoslav Ganov if (super.onRequestSendAccessibilityEvent(child, event)) { 9456179ea3196e9306d3f14361fe9ef14191b1edba6Svetoslav Ganov // Add a record for ourselves as well. 9466179ea3196e9306d3f14361fe9ef14191b1edba6Svetoslav Ganov AccessibilityEvent record = AccessibilityEvent.obtain(); 9476179ea3196e9306d3f14361fe9ef14191b1edba6Svetoslav Ganov onInitializeAccessibilityEvent(record); 9486179ea3196e9306d3f14361fe9ef14191b1edba6Svetoslav Ganov // Populate with the text of the requesting child. 9496179ea3196e9306d3f14361fe9ef14191b1edba6Svetoslav Ganov child.dispatchPopulateAccessibilityEvent(record); 9506179ea3196e9306d3f14361fe9ef14191b1edba6Svetoslav Ganov event.appendRecord(record); 9516179ea3196e9306d3f14361fe9ef14191b1edba6Svetoslav Ganov return true; 9526179ea3196e9306d3f14361fe9ef14191b1edba6Svetoslav Ganov } 9536179ea3196e9306d3f14361fe9ef14191b1edba6Svetoslav Ganov return false; 954736c2756bf3c14ae9fef7255c119057f7a2be1edSvetoslav Ganov } 9553fb3d7c4e756bd32d5abde0abca9ab52d559bc84Adam Powell 956736c2756bf3c14ae9fef7255c119057f7a2be1edSvetoslav Ganov @Override 957d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov public void onInitializeAccessibilityNodeInfo(AccessibilityNodeInfo info) { 958d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov super.onInitializeAccessibilityNodeInfo(info); 9598a78fd4d9572dff95432fcc4ba0e87563415b728Svetoslav Ganov info.setClassName(AdapterView.class.getName()); 960d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov info.setScrollable(isScrollableForAccessibility()); 961d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov View selectedView = getSelectedView(); 962d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov if (selectedView != null) { 963d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov info.setEnabled(selectedView.isEnabled()); 964d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov } 965d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov } 966d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov 967d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov @Override 96830401328c1026389171d454c934c15875c3f7ff0Svetoslav Ganov public void onInitializeAccessibilityEvent(AccessibilityEvent event) { 96930401328c1026389171d454c934c15875c3f7ff0Svetoslav Ganov super.onInitializeAccessibilityEvent(event); 9708a78fd4d9572dff95432fcc4ba0e87563415b728Svetoslav Ganov event.setClassName(AdapterView.class.getName()); 971d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov event.setScrollable(isScrollableForAccessibility()); 972736c2756bf3c14ae9fef7255c119057f7a2be1edSvetoslav Ganov View selectedView = getSelectedView(); 973736c2756bf3c14ae9fef7255c119057f7a2be1edSvetoslav Ganov if (selectedView != null) { 974736c2756bf3c14ae9fef7255c119057f7a2be1edSvetoslav Ganov event.setEnabled(selectedView.isEnabled()); 975736c2756bf3c14ae9fef7255c119057f7a2be1edSvetoslav Ganov } 976eb0c52e491d89543d0e9573b81fdb9145d680059Svetoslav Ganov event.setCurrentItemIndex(getSelectedItemPosition()); 977d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov event.setFromIndex(getFirstVisiblePosition()); 978d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov event.setToIndex(getLastVisiblePosition()); 9790e6fa8b60d113883c92dd754f5e3f8bb8b17e073Svetoslav Ganov event.setItemCount(getCount()); 980d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov } 981d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov 982d9ee72fddb8be40e414a831fb80458dc48699613Svetoslav Ganov private boolean isScrollableForAccessibility() { 98398348517fde86f993b5720a862bce5c2a5f1a06fSvetoslav Ganov T adapter = getAdapter(); 98498348517fde86f993b5720a862bce5c2a5f1a06fSvetoslav Ganov if (adapter != null) { 98598348517fde86f993b5720a862bce5c2a5f1a06fSvetoslav Ganov final int itemCount = adapter.getCount(); 98698348517fde86f993b5720a862bce5c2a5f1a06fSvetoslav Ganov return itemCount > 0 98798348517fde86f993b5720a862bce5c2a5f1a06fSvetoslav Ganov && (getFirstVisiblePosition() > 0 || getLastVisiblePosition() < itemCount - 1); 98898348517fde86f993b5720a862bce5c2a5f1a06fSvetoslav Ganov } 98998348517fde86f993b5720a862bce5c2a5f1a06fSvetoslav Ganov return false; 99075986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov } 99175986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov 99275986cf9bc57ef11ad70f36fb77fbbf5d63af6ecsvetoslavganov @Override 9939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project protected boolean canAnimate() { 9949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return super.canAnimate() && mItemCount > 0; 9959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 9969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 9979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void handleDataChanged() { 9989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final int count = mItemCount; 9999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean found = false; 10009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (count > 0) { 10029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int newPos; 10049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Find the row we are supposed to sync to 10069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mNeedSync) { 10079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Update this first, since setNextSelectedPositionInt inspects 10089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // it 10099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mNeedSync = false; 10109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // See if we can find a position in the new data with the same 10129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // id as the old selection 10139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project newPos = findSyncPosition(); 10149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (newPos >= 0) { 10159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Verify that new selection is selectable 10169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int selectablePos = lookForSelectablePosition(newPos, true); 10179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (selectablePos == newPos) { 10189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Same row id is selected 10199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project setNextSelectedPositionInt(newPos); 10209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project found = true; 10219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!found) { 10259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Try to use the same position if we can't find matching data 10269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project newPos = getSelectedItemPosition(); 10279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Pin position to the available range 10299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (newPos >= count) { 10309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project newPos = count - 1; 10319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (newPos < 0) { 10339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project newPos = 0; 10349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Make sure we select something selectable -- first look down 10379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int selectablePos = lookForSelectablePosition(newPos, true); 10389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (selectablePos < 0) { 10399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Looking down didn't work -- try looking up 10409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project selectablePos = lookForSelectablePosition(newPos, false); 10419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (selectablePos >= 0) { 10439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project setNextSelectedPositionInt(selectablePos); 10449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project checkSelectionChanged(); 10459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project found = true; 10469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!found) { 10509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Nothing is selected 10519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSelectedPosition = INVALID_POSITION; 10529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSelectedRowId = INVALID_ROW_ID; 10539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mNextSelectedPosition = INVALID_POSITION; 10549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mNextSelectedRowId = INVALID_ROW_ID; 10559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mNeedSync = false; 10569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project checkSelectionChanged(); 10579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10584213804541a8b05cd0587b138a2fd9a3b7fd9350Svetoslav Ganov 105900dbe81fea7be57ee2ff8a97844faf1bc15a427fSvetoslav notifySubtreeAccessibilityStateChangedIfNeeded(); 10609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1062ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette /** 1063ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette * Called after layout to determine whether the selection position needs to 1064ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette * be updated. Also used to fire any pending selection events. 1065ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette */ 10669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void checkSelectionChanged() { 10679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((mSelectedPosition != mOldSelectedPosition) || (mSelectedRowId != mOldSelectedRowId)) { 10689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project selectionChanged(); 10699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mOldSelectedPosition = mSelectedPosition; 10709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mOldSelectedRowId = mSelectedRowId; 10719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1072ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette 1073ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette // If we have a pending selection notification -- and we won't if we 1074ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette // just fired one in selectionChanged() -- run it now. 1075ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette if (mPendingSelectionNotifier != null) { 1076ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette mPendingSelectionNotifier.run(); 1077ec8e720ae209d975ac34dc66e51f280d9a9482efAlan Viverette } 10789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 10819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Searches the adapter for a position matching mSyncRowId. The search starts at mSyncPosition 10829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * and then alternates between moving up and moving down until 1) we find the right position, or 10839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2) we run out of time, or 3) we have looked at every position 10849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 10859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return Position of the row that matches mSyncRowId, or {@link #INVALID_POSITION} if it can't 10869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * be found 10879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 10889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int findSyncPosition() { 10899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int count = mItemCount; 10909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (count == 0) { 10929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return INVALID_POSITION; 10939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 10949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long idToMatch = mSyncRowId; 10969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int seed = mSyncPosition; 10979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 10989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // If there isn't a selection don't hunt for it 10999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (idToMatch == INVALID_ROW_ID) { 11009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return INVALID_POSITION; 11019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Pin seed to reasonable values 11049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project seed = Math.max(0, seed); 11059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project seed = Math.min(count - 1, seed); 11069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long endTime = SystemClock.uptimeMillis() + SYNC_MAX_DURATION_MILLIS; 11089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long rowId; 11109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // first position scanned so far 11129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int first = seed; 11139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // last position scanned so far 11159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int last = seed; 11169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // True if we should move down on the next iteration 11189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean next = false; 11199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // True when we have looked at the first item in the data 11219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean hitFirst; 11229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // True when we have looked at the last item in the data 11249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean hitLast; 11259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Get the item ID locally (instead of getItemIdAtPosition), so 11279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // we need the adapter 11289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project T adapter = getAdapter(); 11299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (adapter == null) { 11309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return INVALID_POSITION; 11319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while (SystemClock.uptimeMillis() <= endTime) { 11349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project rowId = adapter.getItemId(seed); 11359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (rowId == idToMatch) { 11369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Found it! 11379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return seed; 11389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project hitLast = last == count - 1; 11419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project hitFirst = first == 0; 11429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (hitLast && hitFirst) { 11449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Looked at everything 11459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project break; 11469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (hitFirst || (next && !hitLast)) { 11499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Either we hit the top, or we are trying to move down 11509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project last++; 11519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project seed = last; 11529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Try going up next time 11539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project next = false; 11549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else if (hitLast || (!next && !hitFirst)) { 11559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Either we hit the bottom, or we are trying to move up 11569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project first--; 11579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project seed = first; 11589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Try going down next time 11599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project next = true; 11609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return INVALID_POSITION; 11659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Find a position that can be selected (i.e., is not a separator). 11699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 11709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param position The starting position to look at. 11719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param lookDown Whether to look down for other positions. 11729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return The next selectable position starting at position and then searching either up or 11739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * down. Returns {@link #INVALID_POSITION} if nothing can be found. 11749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int lookForSelectablePosition(int position, boolean lookDown) { 11769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return position; 11779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Utility to keep mSelectedPosition and mSelectedRowId in sync 11819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param position Our current position 11829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void setSelectedPositionInt(int position) { 11849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSelectedPosition = position; 11859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSelectedRowId = getItemIdAtPosition(position); 11869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 11879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 11889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 11899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Utility to keep mNextSelectedPosition and mNextSelectedRowId in sync 11909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param position Intended value for mSelectedPosition the next time we go 11919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * through layout 11929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 11939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void setNextSelectedPositionInt(int position) { 11949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mNextSelectedPosition = position; 11959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mNextSelectedRowId = getItemIdAtPosition(position); 11969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // If we are trying to sync to the selection, update that too 11979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mNeedSync && mSyncMode == SYNC_SELECTED_POSITION && position >= 0) { 11989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSyncPosition = position; 11999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSyncRowId = mNextSelectedRowId; 12009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 12039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 12049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Remember enough information to restore the screen state when the data has 12059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * changed. 12069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 12079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 12089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project void rememberSyncState() { 12099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (getChildCount() > 0) { 12109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mNeedSync = true; 12119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSyncHeight = mLayoutHeight; 12129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mSelectedPosition >= 0) { 12139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Sync the selection state 12149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project View v = getChildAt(mSelectedPosition - mFirstPosition); 12159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSyncRowId = mNextSelectedRowId; 12169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSyncPosition = mNextSelectedPosition; 12179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (v != null) { 12189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSpecificTop = v.getTop(); 12199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSyncMode = SYNC_SELECTED_POSITION; 12219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 12229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project // Sync the based on the offset of the first view 12239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project View v = getChildAt(0); 12249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project T adapter = getAdapter(); 12259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mFirstPosition >= 0 && mFirstPosition < adapter.getCount()) { 12269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSyncRowId = adapter.getItemId(mFirstPosition); 12279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } else { 12289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSyncRowId = NO_ID; 12299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSyncPosition = mFirstPosition; 12319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (v != null) { 12329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSpecificTop = v.getTop(); 12339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mSyncMode = SYNC_FIRST_POSITION; 12359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 12389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 1239