I have Expander with nested DataGrid on WPF application - it creates usercontrols. I create this control on codebehind for each element from data (from database) list. Finally, I have the list where each element is Expadned with nested DataGrid. When i develop the item I see DataDrid, but when I will develop many components I must scroll the content. When the cursor there is on the expander, the element scroll works but when I mouse hover the DataGrid, the scroll doesn't work.
Sample code:
<ScrollViewer HorizontalAlignment="Left">
<DockPanel>
<Expander x:Name="Expander1" Expanded="Expander1_Expanded">
<Expander.Content>
<DataGrid x:Name="DataGrid1" MouseLeftButtonUp="DataGrid1_MouseLeftButtonDown" ScrollViewer.HorizontalScrollBarVisibility="Hidden" ScrollViewer.VerticalScrollBarVisibility="Hidden" >
<DataGrid.CellStyle>
<Style TargetType="DataGridCell">
<Setter Property="BorderThickness" Value="0"/>
</Style>
</DataGrid.CellStyle>
<DataGrid.Columns>
<DataGridTextColumn Header="name1" Binding="{Binding Name}" IsReadOnly="True" />
<DataGridTextColumn Header="name2" Binding="{Binding Value}" IsReadOnly="True"/>
<DataGridTextColumn Header="name3" Binding="{Binding UnitName}" IsReadOnly="True"/>
</DataGrid.Columns>
</DataGrid>
</Expander.Content>
<Expander.Style>
<Style TargetType="Expander">
<Setter Property="IsExpanded" Value="False" />
<Style.Triggers>
<DataTrigger Binding="{Binding IsExpanded, RelativeSource={RelativeSource Self}}" Value="True">
</DataTrigger>
</Style.Triggers>
</Style>
</Expander.Style>
</Expander>
// and mor expander, added from codebehind
</DockPanel>
</ScrollViewer>
Finally grid:
When mouse is where green ring scroll to the right works
This happens since the
DataGrid
itself may contain aScrollViewer
, which will appear when you have more items than what fits within a given height. In those cases, you will want to allow theDataGrid
to attempt to handle the scroll event first, and if it doesn't know what to do about it, for instance when you are trying to scroll down while already at the bottom, pass the scroll event along to its parent.Now, it looks like your
DataGrid
s are not actually scrollable which means that the following might be a bit overkill, but a general solution which achieves the above is obtained by introducing the following modification to the mouse wheel handler:Here, the hardcoded
3
is the number of rows to scroll in theDataGrid
. You would then apply this corrector to all relevantDataGrid
s. For instance, to use it on all grids in the application, you could add it to yourApplication.Resources
inApp.xaml
as follows:Credit: This solution is somewhat based on/inspired by the one mentioned in this blog post but it restricts its function to
DataGrid
(since in my experience, it will otherwise break a bunch of other controls that aren't prepared to tunnel their events).