Как отобразить заголовок HeaderedItemsControl? - PullRequest
4 голосов
/ 28 августа 2011

У меня есть следующий код:

 <Window.Resources>      
       <DataTemplate x:Key="SectionTemplate" >                          
              <TextBlock Text="{Binding Path=Name}" />                  
       </DataTemplate>
 </Window.Resources>
 <Grid >        
   <Border>
       <HeaderedItemsControl Header="Top1"
                             ItemsSource="{Binding Path=List1}" 
                             ItemTemplate="{StaticResource SectionTemplate}"/>
    </Border>       
 </Grid>
public class MainWindow
{
   public List<Item> List1
   {
      get { return list1; }
      set { list1 = value; }
   }

   public MainWindow()
   {             
      list1.Add(new Item { Name = "abc" });
      list1.Add(new Item { Name = "xxx" });

      this.DataContext = this;      
      InitializeComponent();       
   }   
}

public class Item
{     
    public string Name { get; set; }
}

По какой-то причине Items отображается, но без заголовка.

1 Ответ

7 голосов
/ 28 августа 2011

Как документация указывает:

HeaderedItemsControl имеет ограниченный стиль по умолчанию. Чтобы создать HeaderedItemsControl с пользовательским внешним видом, создайте новый ControlTemplate .

Поэтому, когда вы создаете этот шаблон, обязательно включите в него ContentPresenter, который связан с Header (например, с использованием ContentSource)

, например

<HeaderedItemsControl.Template>
    <ControlTemplate TargetType="{x:Type HeaderedItemsControl}">
        <Border>
            <Grid>
                <Grid.RowDefinitions>
                    <RowDefinition Height="Auto" />
                    <RowDefinition Height="Auto" />
                    <RowDefinition />
                </Grid.RowDefinitions>
                <ContentPresenter ContentSource="Header" />
                <Separator Grid.Row="1" />
                <ItemsPresenter Grid.Row="2" />
            </Grid>
        </Border>                       
    </ControlTemplate>
</HeaderedItemsControl.Template>

( Все привязки по умолчанию (поля, фон и т. Д.) Опущены. )

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...