zoukankan      html  css  js  c++  java
  • 在Dev的GridControl控件的列中显示图片

    (图片来自Silverlight项目的资源中)
    步骤:
    1. 实现转换类
    public class UserIDToImageConverter : IValueConverter
    {
    public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
    {
    if (parameter.ToString() == "text")
    {

    return (int)value + 10000;
    }

    if (parameter.ToString() == "DataGrid")
    {
    BitmapImage bi = new BitmapImage(new Uri("Images/Tulips.jpg", UriKind.Relative));
    if ((int)value == 101)
    bi = new BitmapImage(new Uri("Images/Penguins.jpg", UriKind.Relative));

    if ((int)value == 102)
    bi = new BitmapImage(new Uri("Images/Koala.jpg", UriKind.Relative));

    return bi;
    }

    if (parameter.ToString() == "GridControl")
    {
    BitmapImage bi = new BitmapImage(new Uri("Images/Tulips.jpg", UriKind.Relative));
    //return bi;
    if ((int)value == 101)
    bi = new BitmapImage(new Uri("Images/Penguins.jpg", UriKind.Relative));

    if ((int)value == 102)
    bi = new BitmapImage(new Uri("Images/Koala.jpg", UriKind.Relative));
    Image image = new Image();
    image.Source = bi;

    return bi;
    }
    return value;

    }
    public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
    {
    return 333;
    //return new BitmapImage(new Uri("Images/Tulips.jpg", UriKind.Relative));
    }
    }
    1.1 此类可单独在一个cs文件中或直接放在其他cs文件中。
    1.2 在convert方法中根据传递的参数paramter不同返回不同的值,可以用一个转换类实现多个转换要求,省得每种转换实现一个转换类。
    2. 在XAML文件中引用转换类
    xmlns:convert="clr-namespace:slqmis"
    slqmis是项目的名字。
    3.在XAML文件中建立转换类的映射关系。
    <UserControl.Resources>
    <convert:UserIDToImageConverter x:Key="converter"/>
    </UserControl.Resources>
    UserIDToImageConverter是转换类的名字,converter是在XAML文件中被使用时定义的名字
    4. 在GridColumn中显示图片代码
    <dxg:GridColumn FieldName="msUserID" Header="UserID" Name="gcUserID">
    <dxg:GridColumn.DisplayTemplate>
    <ControlTemplate>
    <StackPanel Orientation="Horizontal">
    <Image Name="PART_Editor" Height="60" Width="66" HorizontalAlignment="Left" Source="{Binding Path=EditValue, Converter={StaticResource converter}, ConverterParameter=GridControl}" Stretch="Fill" VerticalAlignment="Top"/>
    <TextBlock Text="{Binding Path=EditValue}" />
    </StackPanel>
    </ControlTemplate>
    </dxg:GridColumn.DisplayTemplate>
    </dxg:GridColumn>
    如果GridControl仅用于显示不编辑应使用GridColumn的显示模板(DisplayTemplate),如果要改变GridColumn的结构需用CellTemplate模板,如果要编辑需用EditTemplate。需注意Image中Source要绑定到EditValue上。

    5. 在DataGrid中实现此功能1、2、3步骤一样,第四步不同:
    <sdk:DataGridTemplateColumn Header="msUserID" CanUserReorder="True" CanUserResize="True" CanUserSort="True" Width="Auto">
    <sdk:DataGridTemplateColumn.CellTemplate>
    <DataTemplate>
    <Image Name="PART_Image1" Height="60" Width="66" HorizontalAlignment="Left" Source="{Binding Path=msUserID, Converter={StaticResource converter}, ConverterParameter=DataGrid}" Stretch="Fill" VerticalAlignment="Top"/>
    </DataTemplate>
    </sdk:DataGridTemplateColumn.CellTemplate>
    </sdk:DataGridTemplateColumn>
  • 相关阅读:
    HZOJ 通讯
    HZOJ 礼物
    HZOI 可怜与超市
    高二小假期集训—D5
    [BZOJ3566][SHOI2014]概率充电器
    [***]HZOI20190714 T2熟练剖分
    20190714(又一次翻车……)
    HZOI20190714 T3建造游乐场
    模板—慢速乘
    模板—十进制快速幂
  • 原文地址:https://www.cnblogs.com/zhangtao/p/2347510.html
Copyright © 2011-2022 走看看