[英]Grid inside Scrollview not scrolling by mouse wheel
我在包含3 GroupBoxe
的網格中有一列。 最后一個GroupBox
具有一個包含兩個元素的Grid
:一個Button
和一個TreeView
(垂直)。 TreeView
應該具有動態高度,因為它包含可以擴展/折疊的元素。
包含所有元素的窗口可由用戶調整大小。
如果窗口太小,您將看不到所有分組框,因此我需要滾動條。 我可以向下滾動,但是如果要通過鼠標滾輪在TreeView
滾動,則不會發生任何事情。
這是我的代碼:
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="Auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>
<GroupBox Header="Test 1" Grid.Row="0">...</GroupBox>
<GroupBox Header="Test 2" Grid.Row="1">...</GroupBox>
<GroupBox Header="Test 3" Grid.Row="2">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>
<CheckBox Content="All" Grid.Row="0"/>
<TreeView x:Name="NameTree"
Grid.Row="1"
ItemsSource="{Binding Names}"/>
</Grid>
</GroupBox>
</Grid>
一種解決方法是將第三行設置為固定大小,而不使用*。 在這種情況下,我將使用兩個滾動條(ScrollViewer和TreeViews滾動條,但是我希望動態設置第三個分組框的高度。
您必須將PreviewMouseWheel事件“重定向”到父級:
<TreeView PreviewMouseWheel="TreeView_MouseWheel" >
<TreeViewItem Header="North America">
<TreeViewItem Header="USA"></TreeViewItem>
<TreeViewItem Header="Canada"></TreeViewItem>
<TreeViewItem Header="Mexico"></TreeViewItem>
</TreeViewItem>
<TreeViewItem Header="South America">
<TreeViewItem Header="Argentina"></TreeViewItem>
<TreeViewItem Header="Brazil"></TreeViewItem>
<TreeViewItem Header="Uruguay"></TreeViewItem>
</TreeViewItem>
后面的代碼:
private void TreeView_MouseWheel(object sender, MouseWheelEventArgs e)
{
if (!e.Handled)
{
e.Handled = true;
var eventArg = new MouseWheelEventArgs(
e.MouseDevice, e.Timestamp, e.Delta);
eventArg.RoutedEvent = UIElement.MouseWheelEvent;
eventArg.Source = sender;
var parent = ((Control)sender).Parent as UIElement;
parent.RaiseEvent(eventArg);
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.