Silverlight用图片替换DataGrid中的绑定到Bool类型的列
2011-09-16 21:53 zhoujie 阅读(1255) 评论(1) 编辑 收藏 举报最终的效果是这样的:
Sex列是bool类型:
public class User
{
public int Age { get; set; }
public string Name { get; set; }
public bool Sex { get; set; }
}
{
public int Age { get; set; }
public string Name { get; set; }
public bool Sex { get; set; }
}
先说一种图片资源的引用方式,在自定义控件中很有用,自定义控件通常我们放在单独的程序集中,只能用下面的方式引用图片:
"/程序集名称;component/图片.png";
实现过程就是:自定义DataGrid模板列和IValueConverter类。
<sdk:DataGrid x:Name="dgTest" AutoGenerateColumns="False">
<sdk:DataGrid.Resources>
<my:BoolToImageConverter x:Key="boolconvert"
TrueValue="/DataGridBoolConvert;component/06.png"
FalseValue="/DataGridBoolConvert;component/07.png"/>
</sdk:DataGrid.Resources>
<sdk:DataGrid.Columns>
<sdk:DataGridTextColumn
Header="Name"
Binding="{Binding Name}" />
<sdk:DataGridTemplateColumn Header="Sex">
<sdk:DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<Image Source="{Binding Sex, Converter={StaticResource boolconvert}}"
Width="20" Height="20" />
</DataTemplate>
</sdk:DataGridTemplateColumn.CellTemplate>
</sdk:DataGridTemplateColumn>
</sdk:DataGrid.Columns>
</sdk:DataGrid>
<sdk:DataGrid.Resources>
<my:BoolToImageConverter x:Key="boolconvert"
TrueValue="/DataGridBoolConvert;component/06.png"
FalseValue="/DataGridBoolConvert;component/07.png"/>
</sdk:DataGrid.Resources>
<sdk:DataGrid.Columns>
<sdk:DataGridTextColumn
Header="Name"
Binding="{Binding Name}" />
<sdk:DataGridTemplateColumn Header="Sex">
<sdk:DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<Image Source="{Binding Sex, Converter={StaticResource boolconvert}}"
Width="20" Height="20" />
</DataTemplate>
</sdk:DataGridTemplateColumn.CellTemplate>
</sdk:DataGridTemplateColumn>
</sdk:DataGrid.Columns>
</sdk:DataGrid>
public class BoolToImageConverter : BoolToValueConverter<string> { }
public class BoolToValueConverter<T> : IValueConverter
{
public T FalseValue { get; set; }
public T TrueValue { get; set; }
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
if (value == null)
return FalseValue;
else
return (bool)value ? TrueValue : FalseValue;
}
public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
return value != null ? value.Equals(TrueValue) : false;
}
}
public class BoolToValueConverter<T> : IValueConverter
{
public T FalseValue { get; set; }
public T TrueValue { get; set; }
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
if (value == null)
return FalseValue;
else
return (bool)value ? TrueValue : FalseValue;
}
public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
return value != null ? value.Equals(TrueValue) : false;
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架