【WPF】城市级联(XmlDataProvider)
首先在绑定的时候进行转换:
public class RegionConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
var name = value as string;
var filter = parameter as string;
if (string.IsNullOrEmpty(name) && filter != "country")
{
return null;
}
var provider = new XmlDataProvider();
provider.Source = new Uri("Resources/Region.xml", UriKind.Relative);
if (filter == "country")
{
provider.XPath = "/region/country/@name";
}
else if (filter == "province")
{
provider.XPath = string.Format("/region/country[@name='{0}']/province/@name", name);
}
else if (filter == "city")
{
provider.XPath = string.Format("/region/country/province[@name='{0}']/city/@name", name);
}
else if (filter == "town")
{
provider.XPath = string.Format("/region/country/province/city[@name='{0}']/town/@name", name);
}
return provider;
} public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
throw new NotImplementedException();
}
}
再看以下如何绑定的
<converters:RegionConverter x:Key="region"/>
<ComboBox Grid.Column="" x:Name="country"
DataContext="{Binding Converter={StaticResource region}, ConverterParameter=country}"
SelectedValue="{Binding DataContext.CurrEditorItem.Country,UpdateSourceTrigger=PropertyChanged,
RelativeSource={RelativeSource AncestorType={x:Type mui:ModernWindow}}}"
ItemsSource="{Binding}"
Width="" Style="{StaticResource CommonComboBoxStyle}" />
<ComboBox Grid.Column="" x:Name="province"
DataContext="{Binding SelectedValue, ElementName=country, Converter={StaticResource region}, ConverterParameter=province}"
SelectedValue="{Binding DataContext.CurrEditorItem.Province,UpdateSourceTrigger=PropertyChanged,RelativeSource={RelativeSource AncestorType={x:Type mui:ModernWindow}}}"
ItemsSource="{Binding}"
Width="" Style="{StaticResource CommonComboBoxStyle}" />
<ComboBox Grid.Column="" x:Name="city"
DataContext="{Binding SelectedValue, ElementName=province, Converter={StaticResource region}, ConverterParameter=city}"
SelectedValue="{Binding DataContext.CurrEditorItem.City,UpdateSourceTrigger=PropertyChanged,RelativeSource={RelativeSource AncestorType={x:Type mui:ModernWindow}}}"
ItemsSource="{Binding}"
Width="" Style="{StaticResource CommonComboBoxStyle}" />
<ComboBox Grid.Column="" x:Name="town"
DataContext="{Binding SelectedValue, ElementName=city, Converter={StaticResource region}, ConverterParameter=town}"
SelectedValue="{Binding DataContext.CurrEditorItem.Area,UpdateSourceTrigger=PropertyChanged,RelativeSource={RelativeSource AncestorType={x:Type mui:ModernWindow}}}"
ItemsSource="{Binding}" Text="{Binding Area,UpdateSourceTrigger=PropertyChanged}"
Width="" Style="{StaticResource CommonComboBoxStyle}" />
<TextBlock Grid.Column="" Text="国家" Tag="{Binding SelectedValue, ElementName=country}"
Style="{StaticResource TipTextBlock}"/>
<TextBlock Grid.Column="" Text="省份" Tag="{Binding SelectedValue, ElementName=province}"
Style="{StaticResource TipTextBlock}"/>
<TextBlock Grid.Column="" Text="市/区" Tag="{Binding SelectedValue, ElementName=city}"
Style="{StaticResource TipTextBlock}"/>
<TextBlock Grid.Column="" Text="县/镇" Tag="{Binding SelectedValue, ElementName=town}"
Style="{StaticResource TipTextBlock}"/>
TextBlock放在ComboBox上面,Textblock样式如下
<Style x:Key="TipTextBlock" TargetType="{x:Type TextBlock}">
<Setter Property="IsHitTestVisible" Value="False" />
<Setter Property="HorizontalAlignment" Value="Left"/>
<Setter Property="VerticalAlignment" Value="Center"/>
<Setter Property="Margin" Value="12,0,0,0"/>
<Setter Property="Opacity" Value=""/>
<Style.Triggers>
<Trigger Property="Tag" Value="{x:Null}">
<Setter Property="Opacity" Value=""/>
</Trigger>
</Style.Triggers>
</Style>
枚举在WPF的应用:
<ComboBox x:Name="cbbDataType" ItemsSource="{Binding Source={StaticResource InfoDetailTypeItems}}"
SelectedItem="{Binding CurrEditorItem.DataType, ValidatesOnDataErrors=True}"
ItemTemplate="{StaticResource InfoDetailTypeDataTemplate}"
Grid.Row="" Grid.Column=""
Style="{StaticResource EditorComboBoxStyle}" />
<x:Array x:Key="InfoDetailTypeItems" Type="{x:Type adservice:ShowDataType}">
<adservice:ShowDataType>Image</adservice:ShowDataType>
<adservice:ShowDataType>Video</adservice:ShowDataType>
<adservice:ShowDataType>ThreeDModel</adservice:ShowDataType>
</x:Array>
public ObservableCollection<Employee> userList = new ObservableCollection<Employee>();
public MainWindow()
{
InitializeComponent();
this.List.ItemsSource = userList; ThreadPool.QueueUserWorkItem((m) =>
{
string myfiles = Environment.GetFolderPath(Environment.SpecialFolder.Desktop); var query = from pathname in Directory.GetFiles(myfiles) select new { pathtest = pathname }; foreach (var item in query)
{
this.Dispatcher.BeginInvoke(new Action(() =>
{
userList.Add(new Employee { Name = item.pathtest });
}));
Thread.Sleep(100);
} });
}
private IList<CategoryTreeDataModel> GenerateTree(IEnumerable<CategoryTreeDataModel> list)
{
IDictionary<int, IList<CategoryTreeDataModel>> childDict = new Dictionary<int, IList<CategoryTreeDataModel>>(); // 生成父子关系字典
foreach (var item in list)
{
if (!childDict.ContainsKey(item.ParentId))
childDict.Add(item.ParentId, new List<CategoryTreeDataModel>());
var tempList = childDict[item.ParentId];
tempList.Add(item);
} if (!childDict.ContainsKey(0)) return null; // 生成TreeModel
foreach (var itemList in childDict.Values)
{
foreach (var item in itemList)
{
var parentId = item.CategoryId;
item.Children = childDict.ContainsKey(parentId) ? childDict[parentId] : null;
}
} return GenerateListTree(childDict[0], 0, childDict).ToList();
} /// <summary>
/// 生成拥有子级关系的列表
/// </summary>
/// <param name="list">父级列表</param>
/// <param name="level">树的层级</param>
/// <param name="childDict">父子关系字典</param>
private IEnumerable<CategoryTreeDataModel> GenerateListTree(IEnumerable<CategoryTreeDataModel> list, int level, IDictionary<int, IList<CategoryTreeDataModel>> childDict)
{
if (list == null) yield break; foreach (var item in list)
{ yield return item; if (!childDict.ContainsKey(item.CategoryId)) continue; foreach (var childItem in GenerateListTree(childDict[item.CategoryId], level + 1, childDict))
{
yield return childItem;
}
}
}
【WPF】城市级联(XmlDataProvider)的更多相关文章
- iOS:城市级联列表的使用
1.介绍: 现在越来越多的项目都用到了地址,尤其是电商O2O的购物平台,我之前做的教育产品和电商产品都用到了,而实现地址的设置用到的技术就是城市级联列表,即普遍的做法就是自定义选择器控件UIPicke ...
- GeneXus笔记本—城市级联下拉
最近在交流GeneXus的时候 总是会遇到有城市级联下拉的问题 这里就简单做几种方式 供大家参考参考 第一种就是直接绑定关联信息然后在后者的条件模块设定条件即可 具体如下: 首先我们所需要的表为pro ...
- WPF:ComboBox使用XmlDataProvider做级联
程序功能: 使用ComboBox做级联,数据源为XML文件,适合小数据量呈现 程序代码: <Window x:Class="WpfApplication1.LayouTest" ...
- WPF:在XmlDataProvider上使用主-从绑定(Master-Detail Binding)
原文 http://www.cnblogs.com/mgen/archive/2011/06/19/2084553.html 示例程序: 如上程序截图,一目了然典型的主从模式绑定应用,如果里面的数据不 ...
- Linq 单表城市级联
var list = (from province in db.Areas && province.IsDel == join city in db.Areas on province ...
- WPF:数据和行为
如果自己来做一个UI框架,我们会首先关注哪些方面?我想UI框架主要处理的一定包括两个主要层次的内容,一个是数据展现,另一个就是数据操作,所以UI框架必须能够接收各种不同的数据并通过UI界面展现出来,然 ...
- WPF的本质:数据和行为
如果自己来做一个UI框架,我们会首先关注哪些方面?我想UI框架主要处理的一定包括两个主要层次的内容,一个是数据展现,另一个就是数据操作,所以UI框架必须能够接收各种不同的数据并通过UI界面展现出来,然 ...
- jquery插件课程1 幻灯片、城市选择、日期时间选择、拖放、方向拖动插件
jquery插件课程1 幻灯片.城市选择.日期时间选择.拖放.方向拖动插件 一.总结 一句话总结:都是jquery插件,都还比较小,参数(配置参数.数据)一般都是通过json传递. 1.插件配置数据 ...
- C#源码500份
C Sharp 短信发送平台源代码.rar http://1000eb.com/5c6vASP.NET+AJAX基础示例 视频教程 http://1000eb.com/89jcC# Winform ...
随机推荐
- 「Python」pandas入门教程
pandas适合于许多不同类型的数据,包括: 具有异构类型列的表格数据,例如SQL表格或Excel数据 有序和无序(不一定是固定频率)时间序列数据. 具有行列标签的任意矩阵数据(均匀类型或不同类型) ...
- nodejs使用场景
NodeJS的工作原理其实就是事件循环.可以说每一条NodeJS的逻辑都是写在回调函数里面的,而回调函数都是有返回之后才异步执行的! 既然NodeJS处理并发的能力强,但处理计算和逻辑的能力反而很弱, ...
- Ant Design Upload 组件上传文件到云服务器 - 七牛云、腾讯云和阿里云的分别实现
在前端项目中经常遇到上传文件的需求,ant design 作为 react 的前端框架,提供的 upload 组件为上传文件提供了很大的方便,官方提供的各种形式的上传基本上可以覆盖大多数的场景,但是对 ...
- (知识扩展)R运用领域一览表
• Applications and Case Studies - Lessons and Experiences • Big Data Analytics • Biomedical and Heal ...
- 去掉input获取focus时的边框
贴图,问题如下: 尽管已经设置输入框的border为none,当输入框focus时扔会出现浏览器自带的边框 解决方法,添加如下样式即可,.fs_input为输入框样式 ---------------- ...
- PHP非常好用的分页类
分页类: <?php /* * ********************************************* * @类名: page * @参数: $myde_total - 总记 ...
- java中的matches -> 完全匹配
matches是完全匹配.跟matcher不一样, matcher像perl正则, 能匹配到符合的都会返回true, 而这个matches要完全一模一样才行. import java.util.reg ...
- http之100-continue
[http之100-continue] 1.http 100-continue用于客户端在发送POST数据给服务器前,征询服务器情况,看服务器是否处理POST的数据,如果不处理,客户端则不上传POST ...
- openjudge-NOI 2.6-1944 吃糖果
题目链接:http://noi.openjudge.cn/ch0206/1944/ 题解: 递推,题目中给出了很详细的过程,不讲解 #include<cstdio> int n; int ...
- java版云笔记(二)
云笔记 基本的环境搭建好了,今天做些什么呢,第一是链接数据库(即搭建Spring-Batistas环境),第二是登录预注册. 注:这个项目的sql文件,需求文档,需要的html文件,jar包都可以去下 ...