Привязать сетку данных к списку ObservableCollection

1

Я новичок в WPF, и я хотел бы привязываться от xaml к ObservableCollection. В настоящее время я делаю так:

в xaml:

<Grid Grid.Column="1">
            <local:ProcessingStep DataContext="{Binding ProcessingSteps[0]}" HorizontalAlignment="Stretch" VerticalAlignment="Stretch"/>
</Grid>
<Grid Grid.Column="2">
<local:ProcessingStep DataContext="{Binding ProcessingSteps[1]}" HorizontalAlignment="Stretch" VerticalAlignment="Stretch"/>
</Grid>
<Grid Grid.Column="3">
     <local:ProcessingStep DataContext="{Binding ProcessingSteps[2]}" HorizontalAlignment="Stretch" VerticalAlignment="Stretch"/>
</Grid>

в cs:

public ObservableCollection<ProcessingStepView> ProcessingSteps
{
     get
     {
        return m_ProcessingSteps ??
             (m_ProcessingSteps = new ObservableCollection<ProcessingStepViewl>
                       {
                           new ProcessingStepView("Step1"),
                           new ProcessingStepView("Step2"),
                           new ProcessingStepView("Step3")
                       });
      }
}

Как связать список напрямую с wpf? например: если у меня есть 100 шагов, нехорошо делать один за другим.

Теги:
wpf

1 ответ

2

Вы можете использовать ItemsControl с ItemTemplate и связать свой список:

<ItemsControl ItemsSource="{Binding ProcessingSteps}">
    <ItemsControl.ItemsPanel>
        <ItemsPanelTemplate>
            <StackPanel Orientation="Horizontal"/>
        </ItemsPanelTemplate>
    </ItemsControl.ItemsPanel>
    <ItemsControl.ItemTemplate>
        <DataTemplate>
            <local:ProcessingStep />
        </DataTemplate>
    </ItemsControl.ItemTemplate>
</ItemsControl>

ItemsControl - это в основном просто ретранслятор без выбора, который будет повторять ItemTemplate столько раз, сколько есть в ProcessingSteps и помещать их в любую выбранную вами панель. В этом случае горизонтальная StackPanel

  • 0
    здорово. оно работает. я выучил урок сегодня. спасибо @dkozl
  • 0
    Нет проблем @olidev. Кстати, если вы не предоставите ItemsPanel по умолчанию, она будет использовать вертикальную StackPanel но вы можете изменить ее на любую Panel , такую как Grid , WrapPanel , Canvas или UniformGrid . Каждый элемент управления списком наследуется от ItemsControl , например ListBox это ItemsControl с функциональностью выбора элементов, добавленной сверху, но механизм остается тем же

Ещё вопросы

Сообщество Overcoder
Наверх
Меню