gpt4 book ai didi

wpf - 是否可以在 WPF ItemsControl 中模拟边框折叠(ala CSS)?

转载 作者:行者123 更新时间:2023-12-03 23:50:09 26 4
gpt4 key购买 nike

我正在为 WPF 中的项目设置样式 ListBox ,并希望在每个项目周围放置一个边框。与 BorderThickness例如,设置为 1,相邻项之间的上下边框都被绘制,因此比侧边框显得“更厚”,如图所示:

ListBoxItem border example

产生这些的项目模板 ListBoxItems是:

<DataTemplate>
<Border BorderThickness="1" BorderBrush="DarkSlateGray" Background="DimGray" Padding="8 4 8 4">
<TextBlock Text="{Binding Name}" FontSize="16"/>
</Border>
</DataTemplate>

我想“折叠”这些相邻的边界,例如, through CSS .我知道 BorderThickness可以为左/右/上/下边框单独定义,但这也会影响第一个或最后一个项目的边框,这是不希望的。

有没有办法用 WPF 来实现这一点? Border的属性(property)我失踪了,还是需要不同的方法来创建边界?

最佳答案

使用 BorderThickness="1,0,1,1"和一个 DataTrigger检查 RelativeSource={RelativeSource Mode=PreviousData}正在 null设置 BorderThickness="1,1,1,1" :

<Window x:Class="CollapseBordersDemo.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:sys="clr-namespace:System;assembly=mscorlib"
Title="MainWindow" Height="239" Width="525">
<Window.Resources>
<x:Array x:Key="ListBoxItems" Type="{x:Type sys:String}">
<sys:String>Alice</sys:String>
<sys:String>Bob</sys:String>
<sys:String>Colleen</sys:String>
</x:Array>
<DataTemplate x:Key="ListBoxTemplate">
<Border x:Name="Border" BorderThickness="1,0,1,1" BorderBrush="DarkSlateGray" Background="LightGray" Padding="8 4 8 4">
<TextBlock Text="{Binding}" FontSize="16"/>
</Border>
<DataTemplate.Triggers>
<DataTrigger Binding="{Binding RelativeSource={RelativeSource Mode=PreviousData}}" Value="{x:Null}">
<Setter TargetName="Border" Property="BorderThickness" Value="1,1,1,1"/>
</DataTrigger>
</DataTemplate.Triggers>
</DataTemplate>
</Window.Resources>
<Grid>
<ListBox ItemsSource="{StaticResource ListBoxItems}" ItemTemplate="{StaticResource ListBoxTemplate}" HorizontalContentAlignment="Stretch" />
</Grid>
</Window>

关于wpf - 是否可以在 WPF ItemsControl 中模拟边框折叠(ala CSS)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4572631/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com