我正在使用ItemsControl中的ItemsPanel内的WrapPanel。只要添加的项目符合大小,这就完美无缺。为了满足内容超出大小的情况,我添加了一个ScrollViewer。但是现在这些项目只是垂直列出,即使它们都适合。任何想法是否可能以及我必须做什么。
这是我的xaml:
<ItemsControl Name="LicSwUserItemsCtl" Grid.Column="1" Grid.Row="2">
<ItemsControl.Template>
<ControlTemplate>
<ScrollViewer Name="Scroller" VerticalScrollBarVisibility="Auto" HorizontalScrollBarVisibility="Disabled">
<ItemsPresenter />
</ScrollViewer>
</ControlTemplate>
</ItemsControl.Template>
<ItemsControl.ItemsPanel>
<ItemsPanelTemplate>
<toolkit:WrapPanel Orientation="Vertical" HorizontalAlignment="Stretch" Margin="0" Name="wrpPanel" VerticalAlignment="Stretch" />
</ItemsPanelTemplate>
</ItemsControl.ItemsPanel>
<ItemsControl.ItemTemplate>
<DataTemplate>
<Border x:Name="BrdrStkPnlSwLicUser" CornerRadius="2" BorderThickness="1" Width="120" Height="20" Margin="0,0,3,0" BorderBrush="Transparent">
<StackPanel Name="StkPnlSwLicUser" Orientation="Horizontal" Height="18" Width="120" Margin="0" MouseEnter="StackPanel_MouseEnter" MouseLeave="StackPanel_MouseLeave" MouseLeftButtonUp="StackPanel_MouseLeftButtonUp" >
<Image Source="{Binding Converter={StaticResource IconImage}}" Margin="2,0,3,0" Height="16" Width="16" />
<TextBlock Name="txtBlk" Text="{Binding NodeText}" />
</StackPanel>
</Border>
</DataTemplate>
</ItemsControl.ItemTemplate>
答案 0 :(得分:0)
我在发布问题之前就找到了解决方案。但我认为这可能对其他人有用。
我向ScrollViewer添加了一个SizeChanged处理程序。
SizeChanged="Scroller_SizeChanged"
在处理程序中,我添加了以下代码。
private void Scroller_SizeChanged(object sender, SizeChangedEventArgs e)
{
WrapPanel wrpPanel = (WrapPanel)LicSwUserItemsCtl.GetItemsHost();
wrpPanel.MaxHeight = ((ScrollViewer)sender).ActualHeight;
wrpPanel.MaxWidth = ((ScrollViewer)sender).ActualWidth;
}
如果可以通过在xaml中绑定MaxWidth,MaxHeight属性来实现这一点,我会感兴趣。