#wpf #data-binding #datatemplate
#wpf #привязка данных #datatemplate
Вопрос:
Я пытаюсь создать приложение WPF, в котором у меня есть StackPanel, в котором отображается список учетных записей. В коде для каждой учетной записи есть объект Account, хранящийся в структуре списка. Я хочу привязать это к своему WPF, но мне не нужен listbox.
Вместо этого я определил шаблон для отображения сводки по каждой учетной записи. Затем я хочу сложить их в StackPanel и назвать это днем.
Проблема в том, что привязка данных принимает только первый элемент из списка, и все. Как я могу привязать его так, чтобы это эффективно создавало небольшой сложенный список красиво отформатированных фрагментов данных?
Вот соответствующий код WPF:
<StackPanel Name="sp_AccountList" Margin="0,0,0,0" VerticalAlignment="Top">
<StackPanel.Resources>
<svc:AccountBalanceColorConverter x:Key="accountColorConverter" />
<Style x:Key="AccountSummaryBackgroundGradient" TargetType="{x:Type StackPanel}">
<!-- nice formatting code here -->
</Style>
<Style x:Key="AccountSummaryNameStyle" TargetType="{x:Type TextBlock}">
<Setter Property="Padding" Value="10,0,0,0" />
<Setter Property="FontSize" Value="18" />
<Setter Property="Height" Value="20" />
<Setter Property="FontFamily" Value="Cambria" />
<Setter Property="Foreground" Value="White" />
<Setter Property="Background" Value="Transparent" />
</Style>
<Style x:Key="AccountSummaryBalanceStyle" TargetType="{x:Type TextBlock}">
<Setter Property="Padding" Value="10,0,0,0" />
<Setter Property="FontSize" Value="14" />
<Setter Property="Height" Value="20" />
<Setter Property="FontFamily" Value="Cambria" />
<Setter Property="Background" Value="Transparent" />
</Style>
<ObjectDataProvider x:Key="accounts"
ObjectType="{x:Type svc:AccountService}"
MethodName="ListAccounts" />
<DataTemplate x:Key="AccountSummaryLayout">
<StackPanel Orientation="Vertical" Style="{StaticResource AccountSummaryBackgroundGradient}">
<TextBlock Text="{Binding Path=Name}" Style="{StaticResource AccountSummaryNameStyle}" />
<StackPanel Orientation="Horizontal">
<TextBlock Foreground="{Binding Path=TotalAccountBalance, Converter={StaticResource accountColorConverter} }" Text="{Binding Path=TotalAccountBalance, Mode=OneWay}" Style="{StaticResource AccountSummaryBalanceStyle}" />
<TextBlock Foreground="{Binding Path=AvailableAccountBalance, Converter={StaticResource accountColorConverter} }" Text="{Binding Path=AvailableAccountBalance, Mode=OneWay}" Style="{StaticResource AccountSummaryBalanceStyle}" />
</StackPanel>
</StackPanel>
</DataTemplate>
</StackPanel.Resources>
<StackPanel Orientation="Vertical">
<ContentPresenter x:Name="AccountSummaryPresenter" ContentTemplate="{StaticResource AccountSummaryLayout}" Content="{DynamicResource accounts}" />
</StackPanel>
</StackPanel>
Комментарии:
1. Несколько комментариев: я создал класс AccountService с помощью метода ListAccounts(), который возвращает структуру списка <Учетная запись> . Я подтвердил, что эта функция правильно генерирует список.
Ответ №1:
StackPanel не имеет свойства ItemsSource, его дочерние элементы управления не могут быть привязаны к данным.
Что вы можете сделать, это создать ItemsControl, который использует StackPanel в качестве Itemshost .
<ScrollViewer>
<ItemsControl ItemsSource="{Binding Source={StaticResource accounts}}">
<ItemsControl.ItemsPanel>
<ItemsPanelTemplate>
<StackPanel IsItemsHost="True" Orientation="Vertical" />
</ItemsPanelTemplate>
</ItemsControl.ItemsPanel>
<ItemsControl.ItemTemplate>
...
</ItemsControl.ItemTemplate>
</ItemsControl>
<ScrollViewer>
Комментарии:
1. 1, обратите внимание, что вам может потребоваться улучшить шаблон, чтобы включить средство просмотра прокрутки
2. Хороший вызов, добавлен scrollviewer, а также фрагмент для ItemTemplate
3. Спасибо! Мне не нужно будет добавлять средство просмотра прокрутки, так как мои данные, безусловно, поместятся в окне. Но техника выглядит надежной, я попробую ее.