WPF ContentPresenter отображает только первый элемент в списке

#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. Спасибо! Мне не нужно будет добавлять средство просмотра прокрутки, так как мои данные, безусловно, поместятся в окне. Но техника выглядит надежной, я попробую ее.