diff options
| author | Alan Viverette <alanv@google.com> | 2013-08-28 10:43:07 -0700 |
|---|---|---|
| committer | Alan Viverette <alanv@google.com> | 2013-08-28 10:43:07 -0700 |
| commit | 5b2081dc41cccd76780a2cb4e9a973505c13446c (patch) | |
| tree | 8d46eeca6026120c4f9ad4785355056a8234d1ce /core/java/android/widget/GridView.java | |
| parent | 116c12ef4c5fc2d5e5e90a417c4386c1f9a3ddf6 (diff) | |
Implement new accessibility APIs in lists, text view
Sets contentInvalid for TextViews with errors, sets collection
and item properties in AbsListView, GridView, and ListView.
BUG: 10391326
Change-Id: I91191c8ce1e10a1112f74215e30b26349396344b
Diffstat (limited to 'core/java/android/widget/GridView.java')
| -rw-r--r-- | core/java/android/widget/GridView.java | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/core/java/android/widget/GridView.java b/core/java/android/widget/GridView.java index a7d546af071c..15daf83c6003 100644 --- a/core/java/android/widget/GridView.java +++ b/core/java/android/widget/GridView.java @@ -30,7 +30,10 @@ import android.view.ViewDebug; import android.view.ViewGroup; import android.view.accessibility.AccessibilityEvent; import android.view.accessibility.AccessibilityNodeInfo; +import android.view.accessibility.AccessibilityNodeInfo.CollectionInfo; +import android.view.accessibility.AccessibilityNodeInfo.CollectionItemInfo; import android.view.animation.GridLayoutAnimationController; +import android.widget.AbsListView.LayoutParams; import android.widget.RemoteViews.RemoteView; @@ -2259,5 +2262,37 @@ public class GridView extends AbsListView { public void onInitializeAccessibilityNodeInfo(AccessibilityNodeInfo info) { super.onInitializeAccessibilityNodeInfo(info); info.setClassName(GridView.class.getName()); + + final int columnsCount = getNumColumns(); + final int rowsCount = getCount() / columnsCount; + final CollectionInfo collectionInfo = CollectionInfo.obtain(columnsCount, rowsCount, false); + info.setCollectionInfo(collectionInfo); + } + + @Override + public void onInitializeAccessibilityNodeInfoForItem( + View view, int position, AccessibilityNodeInfo info) { + super.onInitializeAccessibilityNodeInfoForItem(view, position, info); + + final int count = getCount(); + final int columnsCount = getNumColumns(); + final int rowsCount = count / columnsCount; + + final int row; + final int column; + if (!mStackFromBottom) { + column = position % columnsCount; + row = position / columnsCount; + } else { + final int invertedIndex = count - 1 - position; + + column = columnsCount - 1 - (invertedIndex % columnsCount); + row = rowsCount - 1 - invertedIndex / columnsCount; + } + + final LayoutParams lp = (LayoutParams) view.getLayoutParams(); + final boolean isHeading = lp != null && lp.viewType != ITEM_VIEW_TYPE_HEADER_OR_FOOTER; + final CollectionItemInfo itemInfo = CollectionItemInfo.obtain(column, 1, row, 1, isHeading); + info.setCollectionItemInfo(itemInfo); } } |
