Я создаю простое LOB-приложение, которое загружает данные из файла XML и отображает их в списке с несколькими кнопками для редактирования.
В моей первой попытке все было в порядке, за исключением того, что список прокручивался вниз в один длинный столбец. Я бы предпочел, чтобы данные переносились так, чтобы внизу окна он начинал второй столбец и т. Д. - если вы изменяете размер окна, данные должны соответственно изменяться.
Во-первых, я просто поместил ListBox в ScrollViewer. Это не имело никакого значения.
Затем я добавил WrapPanel в ItemTemplate. На этом этапе я получил длинный ряд по горизонтали, но он никогда не переносился на второй ряд, несмотря на мою настройку ScrollViewer.HorizontScrollbar = disabled.
Я искал в Интернете различные блоги и форумы, но не вижу разницы между предложениями и моим кодом (см. Ниже). Любые советы будут высоко оценены.
<Window x:Class="MyApp.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="My App" Height="300" Width="400"
FocusManager.FocusedElement="{Binding ElementName=eventsList}">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="*" />
<RowDefinition Height="auto" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<ScrollViewer Grid.Row="0" Grid.Column="0" HorizontalScrollBarVisibility="Disabled" VerticalScrollBarVisibility="Auto">
<ListBox Name="eventsList">
<ListBox.ItemsPanel>
<ItemsPanelTemplate>
<WrapPanel />
</ItemsPanelTemplate>
</ListBox.ItemsPanel>
</ListBox>
</ScrollViewer>
<StackPanel Grid.Row="1" Grid.Column="0" Orientation="Horizontal" HorizontalAlignment="Center" Visibility="Collapsed">
<Button Name="action1Button" />
<Button Name="action2Button" />
<Button Name="action3Button" />
</StackPanel>
</Grid>
</Window>