Как я могу добавить границу для ListViewItem, ListView в режиме GridView - PullRequest
5 голосов
/ 12 мая 2010

Я хочу иметь границу вокруг ListViewItem (строка в моем случае). Источник ListView и столбцы, созданные во время выполнения. В XAML у меня есть такая структура:

<ListView Name="listViewRaw">
   <ListView.View>
      <GridView>
      </GridView>
   </ListView.View>
</ListView>

Во время выполнения я привязываю просмотр списка к DataTable, добавляя необходимые столбцы и привязки:

        var view = (listView.View as GridView);
        view.Columns.Clear();   
        for (int i = 0; i < table.Columns.Count; i++)
        {
            GridViewColumn col = new GridViewColumn();
            col.Header = table.Columns[i].ColumnName;
            col.DisplayMemberBinding = new Binding(string.Format("[{0}]", i.ToString()));
            view.Columns.Add(col);
        }

        listView.CoerceValue(ListView.ItemsSourceProperty);

        listView.DataContext = table;
        listView.SetBinding(ListView.ItemsSourceProperty, new Binding());

Поэтому я хочу добавить границу вокруг каждой строки и установить поведение границы (цвет и т. Д.) С помощью DataTriggers (например, если значение в 1-м столбце = "Visible", установить цвет границы в черный) Могу ли я поставить границу через DataTemplate в ItemTemplate? Я знаю решение, где вы манипулируете с CellTemplates, но мне это не очень нравится. Я хочу что-то подобное, если это вообще возможно.

<DataTemplate>
   <Border Name="Border" BorderBrush="Transparent" BorderThickness="2">
      <ListViewItemRow><!-- Put my row here, but i ll know about table structure only during runtime --></ListViewItemRow>
   </Border>
</DataTemplate>

Ответы [ 2 ]

16 голосов
/ 20 ноября 2014

Если вы используете ListView с GridView, установленным в качестве View, то ListView по умолчанию не показывает вертикальные или горизонтальные линии.

Если вы хотите добавить горизонтальные линии, вы можете изменить границу в ListViewItem, например:

<ListView ...>
    <ListView.ItemContainerStyle>
        <Style TargetType="{x:Type ListViewItem}">
            <Setter Property="BorderBrush" Value="LightGray" />
            <Setter Property="BorderThickness" Value="0,0,0,1" />
        </Style>
    </ListView.ItemContainerStyle>
    <ListView.View>
        <GridView>
            <GridViewColumn ... />
        </GridView>
    </ListView.View>
    ...
12 голосов
/ 12 мая 2010

Вам нужно будет установить границу в шаблоне ControlTemplate

<Style x:Key="BorderedItem" TargetType="ListViewItem">
  <Setter Property="Template">
    <Setter.Value>
      <ControlTemplate TargetType="ListViewItem">
        <Border Name="Border" BorderBrush="Transparent" BorderThickness="2">
          <ContentPresenter />
        </Border>
      </ControlTemplate>
    </Setter.Value>
  </Setter>
</Style>

Теперь вы можете установить этот стиль в вашем ListView

<ListView ItemContainerStyle="{StaticResource BorderedItem}" />
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...