WPF實(shí)現(xiàn)自定義一個(gè)自刪除的多功能ListBox
我需要一個(gè)ListBox,他在界面上分為幾列,每列對(duì)應(yīng)一系列的數(shù)據(jù)。第一行是各數(shù)據(jù)的標(biāo)題,支持橫向滾動(dòng),豎向只支持?jǐn)?shù)據(jù)源滾動(dòng),標(biāo)題不隨之滾動(dòng)。視覺上與ListView類似。支持等比拉伸,支持多選,支持從界面去更改內(nèi)部數(shù)據(jù)源,支持子項(xiàng)從ListBox中刪除自己。為了實(shí)現(xiàn)這些功能,我決定自定義一個(gè)特殊的列表,當(dāng)然他還是繼承自ListBox。
1.首先他支持等比拉伸,且數(shù)據(jù)分列顯示。首先想到Grid的ColumnDefinitions可以滿足。
<Grid.ColumnDefinitions>
<ColumnDefinition Width="74*" />
<ColumnDefinition Width="179*" />
<ColumnDefinition Width="157*" />
</Grid.ColumnDefinitions>
2.支持從界面去更改內(nèi)部數(shù)據(jù)源,支持子項(xiàng)從ListBox中刪除自己。
為了從界面上滿足功能,需要重寫ItemContainerStyle樣式,繪制出該子項(xiàng)Style。在Style中為了處理事件響應(yīng),可以通過在數(shù)據(jù)源子項(xiàng)中增加Command來對(duì)對(duì)應(yīng)事件進(jìn)行處理。但是處理邏輯可能有點(diǎn)繁雜,而且單從數(shù)據(jù)處理而言,子項(xiàng)無法從父項(xiàng)中刪除自己,只能通過視覺樹獲取父ListBox,實(shí)現(xiàn)該功能。這樣寫的話代碼耦合性會(huì)有點(diǎn)高,且數(shù)據(jù)處理時(shí)會(huì)調(diào)取界面處理。我希望數(shù)據(jù)源內(nèi)部只是在處理數(shù)據(jù),只能通過界面自上而下的訪問數(shù)據(jù)源,而不是數(shù)據(jù)源和界面都有循環(huán)調(diào)用。
第二種方法,我直接重寫一個(gè)控件繼承自ListBoxItem,將之前重寫ItemContainerStyle樣式復(fù)制到該控件前臺(tái),并在后臺(tái)代碼中對(duì)相應(yīng)事件進(jìn)行處理。代碼如下:
public partial class TestItem : ListBoxItem
{
public TestItem()
{
InitializeComponent();
}
private void Delete_Click(object sender, RoutedEventArgs e)
{
}
}
因?yàn)槲沂抢^承自ListBoxItem的,所以可以通過
ItemsControl.ItemsControlFromItemContainer(this) is ListBox listBox
獲取到父listbox的對(duì)象,獲取到父對(duì)象后,就可以從ListBox中刪除自己。或是更改ListBox中綁定的數(shù)據(jù)源。
3.我們還需要把這個(gè)自定義的ListBoxItem放到我們自定義的ListBox中,讓所有子項(xiàng)都應(yīng)用這個(gè)自定義的ListboxItem,而不是默認(rèn)的ListboxItem。代碼如下:
internal class TestListBox : ListBox
{
protected override DependencyObject GetContainerForItemOverride()
{
return new TestItem();
}
}
4.為了實(shí)現(xiàn)數(shù)據(jù)與標(biāo)題分離的滾動(dòng)效果,我單獨(dú)將標(biāo)題拿到外部,對(duì)標(biāo)題進(jìn)行單獨(dú)顯示,Listbox只顯示數(shù)據(jù)。外部滑動(dòng)條支持整體橫向滑動(dòng),Listbox內(nèi)部滑動(dòng)條支持內(nèi)部豎向滑動(dòng)。給兩個(gè)滑動(dòng)條都加上最小寬度。
<ScrollViewer
Grid.Row="1"
Margin="0,20,0,0"
HorizontalScrollBarVisibility="Auto"
VerticalScrollBarVisibility="Disabled">
<Border
MinWidth="{Binding MinWidth, ElementName=listbox}"
BorderBrush="#DFDFDF"
BorderThickness="1">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="52" />
<RowDefinition />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="79*" />
<ColumnDefinition Width="104*" />
<ColumnDefinition Width="80*" />
</Grid.ColumnDefinitions>
<Border Grid.ColumnSpan="20" Background="#F2F2F2" />
<TextBlock Text="ID" />
<TextBlock Grid.Column="1" Text="編號(hào)" />
<TextBlock Grid.Column="2" Text="操作" />
<controls:TestListBox
x:Name="listbox"
Grid.Row="1"
Grid.ColumnSpan="3"
MinWidth="1100"
ItemsSource="{Binding ItemsSourceData}"
Style="{StaticResource BaseListBoxStyle.WithOutHorizontalScrollViewer}" />
</Grid>
</Border>
</ScrollViewer>
在Listbox的樣式中取消了橫向滑動(dòng)條的顯示。
<Style x:Key="BaseListBoxStyle.WithOutScrollViewer" TargetType="ListBox">
<Setter Property="BorderThickness" Value="0" />
<Setter Property="Background" Value="Transparent" />
<Setter Property="FocusVisualStyle" Value="{x:Null}" />
<Setter Property="ScrollViewer.CanContentScroll" Value="False" />
<Setter Property="ScrollViewer.PanningMode" Value="Both" />
<Setter Property="Stylus.IsFlicksEnabled" Value="False" />
<Setter Property="VerticalContentAlignment" Value="Center" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="ListBox">
<Border
x:Name="Bd"
Background="{TemplateBinding Background}"
BorderBrush="{TemplateBinding BorderBrush}"
BorderThickness="{TemplateBinding BorderThickness}"
SnapsToDevicePixels="true">
<ScrollViewer
Focusable="false"
HorizontalScrollBarVisibility="Disabled"
VerticalScrollBarVisibility="Auto">
<ItemsPresenter Margin="{TemplateBinding Padding}" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" />
</ScrollViewer>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>到此這篇關(guān)于WPF實(shí)現(xiàn)自定義一個(gè)自刪除的多功能ListBox的文章就介紹到這了,更多相關(guān)WPF自刪除多功能ListBox內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
logback如何去掉DubboMonitor煩人的INFO日志
這篇文章主要介紹了logback如何去掉DubboMonitor煩人的INFO日志方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07
SpringMVC攔截器實(shí)現(xiàn)監(jiān)聽session是否過期詳解
這篇文章主要介紹了SpringMVC攔截器實(shí)現(xiàn)監(jiān)聽session是否過期詳解,還是比較不錯(cuò)的,這里分享給大家,供需要的朋友參考。2017-11-11
SpringBoot_Cache自定義使用SimpleCacheManager方式
這篇文章主要介紹了SpringBoot_Cache自定義使用SimpleCacheManager方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
Simple Java Mail郵件發(fā)送實(shí)現(xiàn)過程解析
這篇文章主要介紹了Simple Java Mail郵件發(fā)送實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11
Java代碼如何判斷l(xiāng)inux系統(tǒng)windows系統(tǒng)
這篇文章主要介紹了Java代碼如何判斷l(xiāng)inux系統(tǒng)windows系統(tǒng)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01
Spring Boot中使用Server-Sent Events (SSE) 實(shí)
Server-Sent Events (SSE) 是HTML5引入的一種輕量級(jí)的服務(wù)器向?yàn)g覽器客戶端單向推送實(shí)時(shí)數(shù)據(jù)的技術(shù),本文主要介紹了Spring Boot中使用Server-Sent Events (SSE) 實(shí)現(xiàn)實(shí)時(shí)數(shù)據(jù)推送教程,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03
java異常繼承何類,運(yùn)行時(shí)異常與一般異常的區(qū)別(詳解)
下面小編就為大家?guī)硪黄猨ava異常繼承何類,運(yùn)行時(shí)異常與一般異常的區(qū)別(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-11-11

