I have a multiband grid where a child band is bound to a bindinglist. The list can be empty. I set the ExpansionIndicator on the parent band to CheckOnDisplay so that the indicator only appears if there are any items in the list.
Is it possible to also automatically expand the parent band when the indicator appears?
If you have a reasonably small number of rows in the grid, then I would use the InitializeRow event and simply set e.Row.Expanded = true. That will expand every row as it is initialized.
Another option could be to call grid.Rows.ExpandAll immediately after setting the grid's DataSource.
If your data set is large, though, both of these approaches may cause a performance issue, since retrieving child rows from a DataSet can be a costly operation.
In that case, you might be able to do something more efficiently, by handling the AfterRowRegionScroll event and looping through only the grid.ActiveRowScrollRegion.VisibleRows collection and expanding the rows that are visible on the screen. The only problem with this is that expanding a row might cause the grid to scroll, your code might have to use the EventManager to prevent recursion.
Mike Saltzman"] In that case, you might be able to do something more efficiently, by handling the AfterRowRegionScroll event and looping through only the grid.ActiveRowScrollRegion.VisibleRows collection and expanding the rows that are visible on the screen. The only problem with this is that expanding a row might cause the grid to scroll, your code might have to use the EventManager to prevent recursion.
Worked great, thanks for the suggestion.
In my case, I am change a column's value in the parent band that creates rows in the child band. So as soon as the change is committed, I'd like the child band to expand.
I guess I have then a number of choices as far as event handlers to call Expand.
UPDATE:
I am calling ExpandAll on the row in AfterCellUpdate event but it's not taking effect for some reason. Is AfterCellUpdate not the right place to call ExpandAll?
UPDATE2:
Setting Row.Expanded = true worked. I guess I should have read Mike's instructions more carefully.