Silverlight 转换器应用一修改排充图标显示

在项目中要完成一个修改记录排序顺序的需要,通过DataGrid模板列已经绑定,效果如下图

第一行的向上图标和最后一行的向下图标应该隐藏,应该做成如下图效果

我这里使用转换器完成此功能,

转换器代码:

    public class MyConvert:IValueConverter
    {

        #region IValueConverter 成员

        public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
        {
            if (parameter.ToString() == "001"||parameter.ToString()=="002")
            {
                return MainPage.Converter(value,parameter.ToString());
            }
            return null;
        }

        public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
        {
            return null;
        }

        #endregion
    }

使用参数来进行不同操作

001用于控制向上操作,002用于向下操作

这里调用MainPage.xaml中的一个转换方法,传入Id和控制方式,MainPage代码如下:

    public partial class MainPage : UserControl
    {
		private static MainPage self; //保存自己的实例
		private  List<UserInfo> Users; //保存数据集       
        public MainPage()
        {
            self = this;
            InitializeComponent();
        }

        private void UserControl_Loaded(object sender, RoutedEventArgs e)
        {
        }
       
        private void LayoutRoot_Loaded(object sender, RoutedEventArgs e)
        {
            Users=UserInfoDAL.FindAll();
            userInfoDataGrid.ItemsSource = Users;
        }

        public static object Converter(object data,string opt)
        {
            int id = int.Parse(data.ToString());
            var datas = self.Users;

            if (opt == "001")
            {
                return datas[0].Id == id ? Visibility.Collapsed : Visibility.Visible;
            }
            return datas[datas.Count-1].Id == id ? Visibility.Collapsed : Visibility.Visible;
        }
    }

现在只要将ID绑定到图标的Visibility属性上,在DataGrid绑定模板列上操作时我们可以先在DataGrid外边设计好控件然后移动到模板中去,如下图所示:

这样方便绑定数据

然后移动控件:


移到后如下:

代码上传到我的资源,下载源码: http://download.csdn.net/detail/lijun7788/4651319
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值