I am using the SizeChanged event for content inside columns.
<Grid HorizontalAlignment="Stretch" VerticalAlignment="Stretch"> <Grid.ColumnDefinitions> <ColumnDefinition x:Name="leftColumn" MinWidth="268" Width="268*"/> <ColumnDefinition Width="Auto"/> <ColumnDefinition x:Name="centerColumn" MinWidth="327" Width="327*"/> <ColumnDefinition Width="Auto"/> <ColumnDefinition x:Name="rightColumn" MinWidth="393" Width="393*"/> </Grid.ColumnDefinitions> <custom:Control x:Name="panel1" Grid.Column="0" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="5,0,0,5" SizeChanged="PanelSizeChanged"/> <GridSplitter Grid.Column="1" Background="#00000000" HorizontalAlignment="Center" VerticalAlignment="Stretch" ResizeBehavior="PreviousAndNext" Width="5" ResizeDirection="Columns"/> <custom:Control x:Name="panel2" Grid.Column="2" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="5,0,0,5" SizeChanged="PanelSizeChanged"/> <GridSplitter Grid.Column="3" Background="#00000000" HorizontalAlignment="Center" VerticalAlignment="Stretch" ResizeBehavior="PreviousAndNext" Width="5" ResizeDirection="Columns"/> <custom:Control x:Name="panel2" Grid.Column="4" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="5,0,0,5" SizeChanged="PanelSizeChanged"/> </Grid>
I manage all the size changes I need in one PanelSizeChanged callback. Of course, you can use different handlers for each column.
source share