我正在尝试弄清楚如何在单击按钮时划掉ListView中所选行。其中包含一个具有多列的GridView,这些列绑定到我创建的类中的字段,该类被发送到ObservableCollection中,以填充ListView中的数据。
然而,这只会将装饰放在工具提示上,而不是ListView中... 我在下面发布了我的listview和class:
最好在单击按钮后,整个选定的行都会有一条红线划过,尽管此时即使只有每个单元格的文本被划掉我也会很高兴。
我已经尝试了各种方法。我最接近的是,我能够通过将我的预订类中的Notes字段更改为TextBlock并添加TextDecoration来显示带有删除线的文本,如下所示:
Reservation selected = (Reservation)shuttleView.SelectedItem;
TextDecoration td = new TextDecoration(TextDecorationLocation.Strikethrough, new Pen(Brushes.Black, 1), 0, TextDecorationUnit.FontRecommended, TextDecorationUnit.FontRecommended);
selected.Notes.TextDecorations.Add(td);
然而,这只会将装饰放在工具提示上,而不是ListView中... 我在下面发布了我的listview和class:
<ListView Height="287" HorizontalAlignment="Left" Margin="148,12,0,0" Name="shuttleView" VerticalAlignment="Top" Width="720" >
<ListView.ItemContainerStyle>
<Style TargetType="{x:Type ListViewItem}">
<Setter Property="ToolTip" Value="{Binding Notes}" />
</Style>
</ListView.ItemContainerStyle>
<ListView.View>
<GridView>
<GridViewColumn Width="50" Header="Time"
DisplayMemberBinding="{Binding Time}" />
<GridViewColumn Width="50" Header="DO/PU"
DisplayMemberBinding="{Binding DropPickup}" />
<GridViewColumn Width="100" Header="# People"
DisplayMemberBinding="{Binding People}" />
<GridViewColumn Width="100" Header="Room #"
DisplayMemberBinding="{Binding Room}" />
<GridViewColumn Width="100" Header="Hotel"
DisplayMemberBinding="{Binding Hotel}" />
<GridViewColumn Width="112" Header="Location"
DisplayMemberBinding="{Binding Location}" />
<GridViewColumn Width="198" Header="Notes"
DisplayMemberBinding="{Binding Notes}" />
</GridView>
</ListView.View>
</ListView>
class Reservation
{
public string ResID { get; set; }
public string Time { get; set; }
public string DropPickup { get; set; }
public string People { get; set; }
public string Room { get; set; }
public string Hotel { get; set; }
public string Location { get; set; }
public string Notes { get; set; }
public Reservation(string ResID, string Time, string DropPickup, string People, string Room, string Hotel, string Location, string Notes)
{
this.ResID = ResID;
this.Time = Time;
this.DropPickup = DropPickup;
this.People = People;
this.Room = Room;
this.Hotel = Hotel;
this.Location = Location;
this.Notes = Notes;
}
}