C# 来自列表的WPF C嵌套数据
我要实现这个原型 这就是到目前为止我的代码中的内容 MainViewModel.csC# 来自列表的WPF C嵌套数据,c#,.net,wpf,C#,.net,Wpf,我要实现这个原型 这就是到目前为止我的代码中的内容 MainViewModel.cs using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using GenericQueueProt.Models; namespace GenericQueueProt.ViewModels { public MainViewModel()
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using GenericQueueProt.Models;
namespace GenericQueueProt.ViewModels
{
public MainViewModel()
{
Properties = new List<Property>
{
new Property
{
State = "Proccess applicaton",
StateDays = 713,
Ward = "WARD1",
CanvassArea = "001 A&G",
PollingDistrict = "CDA",
Office = "0"
},
new Property
{
State = "Due Evaluation",
StateDays = 713,
Ward = "WARD2",
CanvassArea = "034 MILN",
PollingDistrict = "CO",
Office = "0"
},
new Property
{
State = "Due Evaluation",
StateDays = 713,
Ward = "WARD1",
CanvassArea = "003 A&B2",
PollingDistrict = "CDA",
Office = "0"
},
new Property
{
State = "Proccess applicaton",
StateDays = 713,
Ward = "WARD1",
CanvassArea = "031 LYTH",
PollingDistrict = "AW",
Office = "0"
},
new Property
{
State = "Proccess applicaton",
StateDays = 713,
Ward = "WARD1",
CanvassArea = "013 HAW",
PollingDistrict = "AO",
Office = "0"
},
new Property
{
State = "Evaluated",
StateDays = 713,
Ward = "WARD3",
CanvassArea = "031 LYTH",
PollingDistrict = "CI",
Office = "0"
},
new Property
{
State = "Due Evaluation",
StateDays = 713,
Ward = "WARD2",
CanvassArea = "035 S&KL",
PollingDistrict = "CC",
Office = "0"
},
new Property
{
State = "Due Evaluation",
StateDays = 713,
Ward = "WARD2",
CanvassArea = "035 S&KL",
PollingDistrict = "CZ",
Office = "0"
},
new Property
{
State = "Evaluated",
StateDays = 713,
Ward = "WARD3",
CanvassArea = "003 A&B2",
PollingDistrict = "AD",
Office = "0"
},
new Property
{
State = "Proccess applicaton",
StateDays = 713,
Ward = "WARD1",
CanvassArea = "001 A&G",
PollingDistrict = "CD",
Office = "0"
}
};
}
}
}
Property.cs
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using static GenericQueueProt.ViewModels.MainViewModel;
namespace GenericQueueProt.Models
{
public class Property
{
public string State { get; set; }
public int StateDays { get; set; }
public string Ward { get; set; }
public string CanvassArea { get; set; }
public string PollingDistrict { get; set; }
public string Office { get; set; }
public List<Group> Groups {get; set;}
}
}
MainWindow.xaml.cs
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
namespace GenericQueueProt
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
}
}
}
MainWindow.xaml
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:GenericQueueProt"
xmlns:ViewModels="clr-namespace:GenericQueueProt.ViewModels" x:Class="GenericQueueProt.MainWindow"
mc:Ignorable="d"
Title="MainWindow" Height="450" Width="800">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="29*"/>
<ColumnDefinition Width="7*"/>
</Grid.ColumnDefinitions>
<Grid.DataContext>
<ViewModels:MainViewModel/>
</Grid.DataContext>
<Grid x:Name="CheckBoxes">
<StackPanel x:Name="chbPanel" Background="LightGray" Orientation="Horizontal" Margin="0,0,0,384" Grid.ColumnSpan="2" >
<CheckBox Name="stateCheckBox" Margin="10" >State</CheckBox>
<CheckBox Name="stateDaysCheckBox" Margin="10">State Days</CheckBox>
<CheckBox Name="wardCheckBox" Margin="10">ward</CheckBox>
<CheckBox Name="canvassAreaCheckBox" Margin="10">Canvass area</CheckBox>
<CheckBox Name="pdCheckBox" Margin="10" >PD</CheckBox>
<CheckBox Name="officeCheckBox" Margin="10" >Office</CheckBox>
</StackPanel>
</Grid>
<ListView ItemsSource="{Binding Properties}" HorizontalAlignment="Left" Height="369" Margin="40,40,0,0" VerticalAlignment="Top" Width="742" Grid.ColumnSpan="2">
<ListView.Resources>
<DataTemplate x:Key="ShowItems">
<StackPanel>
</StackPanel>
</DataTemplate>
</ListView.Resources>
<ListView.View>
<GridView x:Name="ItemGridView">
<GridView.Columns>
<GridViewColumn Header="State" Width="120" DisplayMemberBinding="{Binding State}"/>
<GridViewColumn Header="State Days" Width="70" DisplayMemberBinding="{Binding StateDays}"/>
<GridViewColumn Header="Ward" Width="100" DisplayMemberBinding="{Binding Ward}"/>
<GridViewColumn Header="Canvass Area" Width="120" DisplayMemberBinding="{Binding CanvassArea}"/>
<GridViewColumn Header="Polling District" Width="120" DisplayMemberBinding="{Binding PollingDistrict}"/>
<GridViewColumn Header="Office" Width="70" DisplayMemberBinding="{Binding Office}"/>
</GridView.Columns>
</GridView>
</ListView.View>
</ListView>
</Grid>
</Window>
问题是,我是这方面的初学者,老实说,我不知道如何实现这一点。所以,如果有人能帮助我,请给我一些参考或任何建议,我将非常感谢。我知道我问得太多了,但实际上,伙计们,我已经为此挣扎了将近两周。不确定我是否正确理解了您的问题,但您应该检查您的复选框是否已选中,然后您可以通过给列表命名来隐藏列表列:
listView1.Columns.RemoveAt(3);
或者把它拿回来
listView1.Columns.Insert(3, "Column Name");
你的具体问题是什么?所以这不是代码编写服务。@mm8我需要一些建议或起点。通过复选框对项目进行分组的语法是什么?如果选中了两个复选框,如何组合?很多细节让我头晕,请直截了当地说。您没有问任何具体的问题,我们想在哪些方面帮助您?@ErwinDraconis我有一个列表。我需要在另一个列表中对该列表进行分组,例如,我选中了“状态”复选框,并按状态进行分组,而不是选中了“状态天数”复选框,我需要将具有相同状态天数的状态分组到不同的组中,如图所示谢谢。我真正需要的是下一步:如果我选中复选框状态,我需要按状态分组。如果我选中state+ward+state days,它应该按这三个组合分组,例如:state:Evaluated | state days:713 | ward 1 | count:1 state:Process application | state days:713 | ward 1 | count:1 state:Due Evaluation | state days:713 | ward 2 | | count 2>>展开,展开时应该显示这两个财产。我需要关于分组的建议。忘记UI我需要关于如何分组属性的帮助选中复选框