I'm currently working on a project in which I need something like the following:
- MainGroup 1 (Expandable) - SubGroup 1 (Expandable) - SubSubGroup 1 (Expandable) - Child View - Child View - ... - SubSubGroup 2 (Expandable) - Child View - Child View - ... - SubGroup 2 (Expandable) - SubSubGroup 3 (Expandable) - Child View - ... - SubSubGroup 4 (Expandable) - Child View - ... - SubGroup 3 (Expandable) - Child View - ... - MainGroup 2 (Expandable) - ...
At most it would be an ExpandableListView
inside an ExpandableListView
inside an ExpandableListView
- so 3 layers of ExpandableListView
:
MainGroup
would only hold other ExpandableListView
.SubGroup
would hold other ExpandableListView
except for the last two, which will allways just be ChildViews
. (I'm thinking those two could just be substituted with the one for SubSubGroup
)SubSubGroup
would allways hold ChildViews
.My problem is that I think I fail to understand the basic principles of how the ExpandableListView
layouts it's children. I've looked at examples like this, but can't get my head around the functionality.
I've tried simply adding an ExpandableListView
as a child in another - but something doesn't work as only the first item of the inner ExpandableListView
is visible if you expand one of the outer groups. I can however by setting the height of the outer groups container manually make it big enough to show all items in the inner ExpandableListView
. To be optimal, calculation of height should of course be done on the fly.
So, to get to some more solid questions:
ExpandableListView
"lifecycle" (by this I mean instantation, re-use of views, expand/collapse listeners) including: ExpandableListView
notified that a child is expanded/collapsed?ExpandableListView
know how much space to make for all children to fit into a group container?ExpandableListView
to create the above, compared to just mixing together my own solution using some LinearLayouts
and some OnClickListeners
?Edit
For my last question I might note that there can be anywhere from 1 to 20+ MainGroups
.
Android ExpandableListView is a view that shows items in a vertically scrolling two-level list. It differs from a ListView by allowing two levels which are groups that can be easily expanded and collapsed by touching to view and their respective children items.
A view that shows items in a vertically scrolling two-level list. This differs from the ListView by allowing two levels: groups which can individually be expanded to show its children. The items come from the ExpandableListAdapter associated with this view.
First of all, let me recommend you GrepCode site. It has sources of Android SDK classes. Thanks for them, I've found out base principles of AdapterViews (I gave you a link to ExpandableListView, but it's better if you research not only it, but its class-parents as well).
Now, your questions and my answers:
How and when is an ExpandableListView notified that a child is expanded/collapsed?
See method handleItemClick(View v, int position, long id)
How does the ExpandableListView know how much space to make for all children to fit into a group container?
I didn't research this question well, but as far as I know, it's made by the method requestLayout(). Also we found out that one scrollable View cannot be embedded into another scrollable View. (It's wide-known mistake: to put ListView into ScrollView or ListView into ExpandableListView).
How much benefit is there in using the ExpandableListView to create the above, compared to just mixing together my own solution using some LinearLayouts and some OnClickListeners?
AdapterViews are faster. But your construction is too complex even for ExpandableListView. You may use 2 solutions.
You might want to check this project out. I haven't tried it, but I guess it's worth a try. The default ExpanadableListView is quite limited, designed originally to support only 2 levels. You can hack around with it to get it to support more levels than that, but it'll get messy.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With