Interface HeterogeneousExpandableList
- All Known Implementing Classes:
BaseExpandableListAdapter
ExpandableListAdapter
take advantage of the Adapter
view type
mechanism.
An ExpandableListAdapter
declares it has one view type for its group items
and one view type for its child items. Although adapted for most ExpandableListView
s,
these values should be tuned for heterogeneous ExpandableListView
s.
ExpandableListAdapter.getGroupView(int, boolean, View, ViewGroup)
and
ExpandableListAdapter.getChildView(int, int, boolean, View, ViewGroup)
will be of the appropriate group or child type, resulting in a more efficient reuse of the
previously created views.-
Method Summary
Modifier and TypeMethodDescriptionint
getChildType
(int groupPosition, int childPosition) Get the type of child View that will be created byExpandableListAdapter.getChildView(int, int, boolean, View, ViewGroup)
for the specified child item.int
Returns the number of types of child Views that will be created byExpandableListAdapter.getChildView(int, int, boolean, View, ViewGroup)
.int
getGroupType
(int groupPosition) Get the type of group View that will be created byExpandableListAdapter.getGroupView(int, boolean, View, ViewGroup)
.int
Returns the number of types of group Views that will be created byExpandableListAdapter.getGroupView(int, boolean, View, ViewGroup)
.
-
Method Details
-
getGroupType
int getGroupType(int groupPosition) Get the type of group View that will be created byExpandableListAdapter.getGroupView(int, boolean, View, ViewGroup)
. for the specified group item.- Parameters:
groupPosition
- the position of the group for which the type should be returned.- Returns:
- An integer representing the type of group View. Two group views should share the same
type if one can be converted to the other in
ExpandableListAdapter.getGroupView(int, boolean, View, ViewGroup)
. Note: Integers must be in the range 0 togetGroupTypeCount()
- 1.Adapter.IGNORE_ITEM_VIEW_TYPE
can also be returned. - See Also:
-
getChildType
int getChildType(int groupPosition, int childPosition) Get the type of child View that will be created byExpandableListAdapter.getChildView(int, int, boolean, View, ViewGroup)
for the specified child item.- Parameters:
groupPosition
- the position of the group that the child resides inchildPosition
- the position of the child with respect to other children in the group- Returns:
- An integer representing the type of child View. Two child views should share the same
type if one can be converted to the other in
ExpandableListAdapter.getChildView(int, int, boolean, View, ViewGroup)
Note: Integers must be in the range 0 togetChildTypeCount()
- 1.Adapter.IGNORE_ITEM_VIEW_TYPE
can also be returned. - See Also:
-
getGroupTypeCount
int getGroupTypeCount()Returns the number of types of group Views that will be created by
This method will only be called when the adapter is set on theExpandableListAdapter.getGroupView(int, boolean, View, ViewGroup)
. Each type represents a set of views that can be converted inExpandableListAdapter.getGroupView(int, boolean, View, ViewGroup)
. If the adapter always returns the same type of View for all group items, this method should return 1.AdapterView
.- Returns:
- The number of types of group Views that will be created by this adapter.
- See Also:
-
getChildTypeCount
int getChildTypeCount()Returns the number of types of child Views that will be created by
This method will only be called when the adapter is set on theExpandableListAdapter.getChildView(int, int, boolean, View, ViewGroup)
. Each type represents a set of views that can be converted inExpandableListAdapter.getChildView(int, int, boolean, View, ViewGroup)
, for any group. If the adapter always returns the same type of View for all child items, this method should return 1.AdapterView
.- Returns:
- The total number of types of child Views that will be created by this adapter.
- See Also:
-