WPF - скрытие элементов списка - PullRequest
17 голосов
/ 15 января 2011

У меня есть список, в котором шаблон элемента использует стиль.Стили задают границу с помощью datatrigger, устанавливающего видимость границы для свертывания в зависимости от свойства.Это работает хорошо, за исключением того, что я все еще вижу очень узкую линию для каждого элемента в списке, который свернут.Я надеялся, что кто-то может помочь с тем, как установить видимость так, чтобы не было видимых следов, поскольку это вполне очевидно, когда последовательные элементы были свернуты.

Таблица данных определяет внешнюю границу с док-панелью внутри этойзатем к нему прикрепляются стековые панели.

Любая помощь приветствуется.

Ну, это упрощенный шаблон:

<DataTemplate x:Key="myTemplate">
    <Border BorderThickness="0">
        <Border.Style>
            <Style>
                <Style.Triggers>
                    <DataTrigger Binding="{Binding Path=IsActive}" Value="False">
                        <Setter Property="Border.Visibility" Value="Collapsed" />
                    </DataTrigger>
                </Style.Triggers>
            </Style>
        </Border.Style>
        <DockPanel LastChildFill="True" HorizontalAlignment="Stretch">
            <StackPanel DockPanel.Dock="Right" HorizontalAlignment="Right"  >
                <TextBlock Text="{Binding Path=SeqNo, Converter={StaticResource SeqToTextConv}}"/>
                <Label Content="..." />
            </StackPanel>
        </DockPanel>
    </Border>
</DataTemplate>

Ответы [ 2 ]

35 голосов
/ 15 января 2011

Вы успешно скрываете свой элемент, однако ListBox оборачивает каждый из ваших элементов в ListBoxItem, это добавляет такие понятия, как выбор к вашему элементу. Я подозреваю, что вы все еще видите ListBoxItem в случае, когда ваши элементы скрыты. Вы можете использовать ItemContainerStyle, чтобы скрыть ListBoxItems ...

<ListBox>
  <ListBox.ItemContainerStyle>
    <Style TargetType="{x:Type ListBoxItem}">
      <Style.Triggers>
        <DataTrigger Binding="{Binding IsActive}" Value="False">
          <Setter Property="Visibility" Value="Collapsed"/>
        </DataTrigger>
      </Style.Triggers>
    </Style>
  </ListBox.ItemContainerStyle>
</ListBox>
0 голосов
/ 01 апреля 2018

Этого также можно достичь, заполнив ListBox.Items только ListBoxItem вместо других элементов управления:

ListBox.Items.Add(new ListBoxItem { 
    Content = new CheckBox {Content = "item 1"} 
    })

или

<ListBox>
    <ListBox.Items>
        <ListBoxItem>
            <CheckBox Content="item 1"/>
        </ListBoxItem>
    </ListBox.Items>
</ListBox>

Затем в коде или втриггер, вы можете скрыть элементы напрямую:

ListBox.Items[0].Visibility = Visibility.Collapse

Это позволит скрыть как элемент, так и границу 4px.Этот метод дает вам контроль видимости для каждого отдельного элемента.

...