wpf值转换器IValueConverter例子

转载:http://blog.163.com/[email protected]/blog/static/37140526201085113430862/

值转换器可以把一种类型转换成另一种类型。例如,绑定到一个代表图片地址的字符串,希望显示的是图片,将数据存储为浮点类型,但通过货币的形式呈现;还有将日期存储成DateTime格式,在界面上显示时使用Calender控件等。
下面写一个简单的例子,获得系统当前的时间,显示”now
is 2010-xx-xx xx:xx;xx”。
xaml的代码:

 1
 2 <Window x:Class="VelueConverterTest.Window1"
 3    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
 4    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
 5        xmlns:local="clr-namespace:VelueConverterTest"
 6    Title="Window1" Height="300" Width="300">
 7     <Window.Resources>
 8         <local:DateConverter x:Key="dateConverter"/>
 9     </Window.Resources>
10     <Grid>
11         <Label Margin="53,104,45,130" Name="label1" Content="{Binding Converter={StaticResource dateConverter}}"/>
12     </Grid>
13 </Window>

XAML文件定义了一个dateConverter资源。指向CS文件中的DateConverter类。

  1 1
  2 2
  3 3
  4 4
  5 5
  6 6
  7 7
  8 8
  9 9
 10 10
 11 11
 12 12
 13 13
 14 14
 15 15
 16 16
 17 17
 18 18
 19 19
 20 20
 21 21
 22 22
 23 23
 24 24
 25 25
 26 26
 27 27
 28 28
 29 29
 30 30
 31 31
 32 32
 33 33
 34 34
 35 35
 36 36
 37 37
 38 38
 39 39
 40 40
 41 41
 42 42
 43 43
 44 44
 45 45
 46 46
 47 47
 48 48
 49 49
 50 50
 51 using System;
 52 using System.Collections.Generic;
 53 using System.Linq;
 54 using System.Text;
 55 using System.Windows;
 56 using System.Windows.Controls;
 57 using System.Windows.Data;
 58 using System.Windows.Documents;
 59 using System.Windows.Input;
 60 using System.Windows.Media;
 61 using System.Windows.Media.Imaging;
 62 using System.Windows.Navigation;
 63 using System.Windows.Shapes;
 64 using System.Globalization;
 65
 66 namespace VelueConverterTest
 67 {
 68     public partial class Window1 : Window
 69     {
 70         public DateTime nowtime { get; set; }
 71         public Window1()
 72         {
 73             InitializeComponent();
 74             nowtime = DateTime.Now;
 75             label1.DataContext = nowtime;
 76         }
 77     }
 78
 79    //定义值转换器
 80     [ValueConversion(typeof(DateTime), typeof(String))]
 81     public class DateConverter : IValueConverter
 82     {
 83         public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
 84         {
 85             DateTime date = (DateTime)value;
 86             return "now is "+date.ToString();
 87         }
 88
 89         public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
 90         {
 91             string strValue = value.ToString();
 92             DateTime resultDateTime;
 93             if (DateTime.TryParse(strValue, out resultDateTime))
 94             {
 95                 return resultDateTime;
 96             }
 97             return value;
 98         }
 99     }
100 }

Convert和ConvertBack的区别:
Convert函数表示从数据源到目标的值转换,ConvertBack函数表示从目标到数据源的值转换。因此,如果绑定模式是一次绑定或单向
绑定,只需实现Convert函数;如果绑定模式是双向绑定,需要实现Convert和ConvertBack函数。

xaml中定义了label的Converter,当执行绑定的时候,WPF会把转换前的值,如本例中的nowtime
做为转换器函数Convert的输入值,将返回值显示在label控件上。

时间: 2024-10-05 17:54:13

wpf值转换器IValueConverter例子的相关文章

WPF值转换器

一.摘要 本文通过实例演示WPF值转换器的应用,并在演示过程中,对WPF值转换器的相关知识点进行解释说明. 二.实例演示 1 新建WPF应用程序ConverterExp,程序结构如下图所示. 图1 程序结构图 程序的主画面如下图所示. 图2 程序主画面 程序完成功能: 通过改变画面中ComboBox控件的选中项来改变TextBlock控件的Background值. ComboBox控件的下拉列表中可供选择的项有"red""green"和"blue"

WPF Binding值转换器ValueConverter使用简介(一)

WPF.Silverlight及Windows Phone程序开发中往往需要将绑定的数据进行特定转换,比如DateTime类型的时间转换为yyyyMMdd的日期,再如有一个值是根据另外多组值的不同而异的,此时我们就需要定制自己的Converter. .Net Framework提供了两种Converter接口,单值转换的接口IValueConverter和多值转换的接口IMultiValueConverter,它们都属于System.Windows.Data命名空间,在程序集Presentati

WPF Binding值转换器ValueConverter使用简介(二)-IMultiValueConverter

注: 需要继承IMultiValueConverter接口,接口使用和IValueConverter逻辑相同. 一.MultiBinding+Converter 多值绑定及多值转换实例 当纵向流量大于横向流量时指示灯应为绿色,当纵向流量小于横向流量时指示灯应为红色,否则指示灯为黄色. 1.定制ColorConverter类,此时Convert中参数是object[] values,values[0]对应MultiBinding中的第一个Binding值,这里是纵向流量值,依此类推,可以在Mult

【值转换器】 WPF中Image数据绑定Icon对象

原文:[值转换器] WPF中Image数据绑定Icon对象 ? ? ? ?这是原来的代码: ? ? ? ?<Image Source="{Binding MenuIcon}" ?/> ? ? ? ?这里的MenuIcon是string类型,MenuIcon = "/Image/Tux.ico". ? ? ? ?我遇到的问题是,同事已经封装好的类中的MenuIcon是Icon对象,并不是一个相对或者绝对的路径,另外WPF里也没有可以直接表示Icon对象的控

自定义转换器 IValueConverter

如果要将值转换器与绑定关联,请创建一个实现 IValueConverter 接口的类,然后实现 Convert 和 ConvertBack 方法. 转换器可以将数据从一种类型更改为另一种类型,根据区域性信息转换数据,或修改表示形式的其他方面. 有关某些典型的转换器方案示例,请参见数据绑定概述中的“数据转换”. 值转换器是分区域性的. Convert 和 ConvertBack 方法都具有指示区域性信息的 culture 参数. 如果区域性信息与转换无关,那么在自定义转换器中可以忽略该参数.Con

uwp开发:数据绑定——值转换器 的简单使用

今天,我在做最近正在开发的“简影”uwp应用时遇到一个问题,其中有个栏目,叫做“画报”,是分组显示一组一组的 图片,每组图片在界面上只显示9个,点击去以后显示该组的所有图片. 其中,Model 如下: 画报类,其中有个属性是图片类集合. 在View界面,通过ListView嵌套绑定GridView 如下: 但是,要求是每项只能显示9张图片,而集合内的数据不止9张,如果这样直接绑定到GridView上,那么会将ImagList里面的所以图片都显示出来,那么,要想每项都显示9张.这时候,该怎么办呢?

WPF值转换实例

WPF绑定功能非常方便,有时候点击某值时在另t一处显示此值的另一表现形式或调用其对应的其它值,用WPF值转换功能会很方便,下面就一LISTBOX和TEXTBLOCK控件,把LISTBOX中的值转换成除以1000后的结果显示在TextBlock中 1.值转换类: using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Windows.Data; namesp

3ds Max建模,Blend设计,VS2008控制WPF的3D模型例子

原文:3ds Max建模,Blend设计,VS2008控制WPF的3D模型例子 3ds Max建模,Blend设计,VS2008控制WPF的3D模型例子   所用的软件 3ds Max 9.0,Microsoft Expression Blend,VS 2008 例子下载 例子:http://files.cnblogs.com/wxwinter/wxd_wpf_3d.rar 例子中的文件说明   应用场景 在以前作过的一个系统(MRP)中,需要 用工作流监视设备(工作坏境),并将设备(工作坏境)

WPF:类型转换器的实现

类型转换器提供字符串文本到值的转换方法来帮助WPF设计时在XAML中配置属性.具体用法可以参考MSDN的文档:如何:实现类型转换器. 下面是一个Demo,参考自<WPF葵花宝典自学手册>. 1.MainWindow.xaml 1 <Window x:Class="WpfApplication1.MainWindow" 2 xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"