【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 ...
随机推荐
- [Java多线程]-Thread和Runable源码解析之基本方法的运用实例
前面的文章:多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类) 多线程爬坑之路-Thread和Runable源码解析 前面 ...
- OpenCV---边缘保留滤波EPF
OpenCV经典的两种实现EPF方法:高斯双边和均值迁移 一:双边模糊 差异越大,越会完整保留 def bi_demo(image): dst = cv.bilateralFilter(image,0 ...
- Vue.js随笔二(新建路由+component+添加样式+变量的显示)
创建一个页面: 1.首先让我们看一下整个vue.js的目录,如下图所示: 2.现在让我们创建一个页面吧: 2-1首先你需要新建路由(就和建立一个如何找到项目文件的目录一个意思):进入src/route ...
- centos7下安装配置jenkins+git+maven+jdk
环境 centos7 jdk1.8 maven3 git 在安装jenkins之前,先安装jdk1.8.maven.git 一. 安装jdk1.8 第一步:下载 jdk-8u131-linux-x64 ...
- JS数组---转及补充--
javascript之数组操作 1.数组的创建 var arr=Array();//写的角标数及直接写角标对应的内容简写 var arr=Array("我","爱&quo ...
- 使用HttpClient4来构建Spring RestTemplate
Spring RestTemplate简单说明 现在REST服务已经很普及了,在我们的程序中,经常会需要调用REST API,这时候会有很多选择,原始一点的JDK自带的,再进一步点使用HttpClie ...
- asp.net中模拟测试smtp发邮件
最近在编程人生里要测试一个会员邮件的功能,就写了下面的代码. 在asp.net 中,有时要测试发信SMTP,但如果在单元测试中,如果没方便好用的 smtp怎么办,其实还是有办法模拟的,下面讲解下: 在 ...
- SDUT 3929
Description 蓝色空间号和万有引力号进入了四维水洼,发现了四维物体--魔戒. 这里我们把飞船和魔戒都抽象为四维空间中的一个点,分别标为 "S" 和 "E&quo ...
- Ubuntu 下 CodeBlocks 修改用户自定义颜色主题 及 更新CodeBlocks到最新版本
Code::Blocks默认的白色编辑器界面看久了眼睛很累, 所以想换成dark的主题, 眼睛会舒服些. 1. 安装好codeblocks后, 先运行一次, 关闭, 这时程序会提示你是否要保存defa ...
- MSSQL ADO.NET
为什么要学ADO.NET 之前我们所学的只能在查询分析器里查看数据,操作数据,我们让普通用户去学sql,所以我们搭建了一个界面(Web/Winform) 让用户方面的操作数据库中的数据 什么是ADO. ...