WPF分页DataGrid(二)列右键菜单实现

16 篇文章 5 订阅
4 篇文章 0 订阅

在"WPF分页DataGrid"中介绍了如何实现分页功能,本文中介绍如果实现右键菜单。见下图:

点击菜单项Age,将Age列隐藏,再点击则显示;并实现移动列后,同步显示。

要实现功能需要在Loaded事件时给列添加右键菜单。

public class PagingDataGrid : DataGrid {
	……
	void PagingDataGrid_Loaded(object sender, RoutedEventArgs e) {
		RaisePageChanged();
		//设置列的右键菜单
		SetColumnContextMenu();
        }

	void SetColumnContextMenu() {

	}
}


见SetColumnContextMenu方法:
先枚举所有的列,然后创建相同的菜单项,将列是否显示绑定到菜单项是否选中上,这里需要用代码Binding,右键事件中判断是否为DataGridColumnHeader,是则显示右键菜单。ColumnReordering和ColumnReordeed则是移动列的事件,不要也行,但是菜单项顺序和实际移动后的顺序不同。

void SetColumnContextMenu() {
	ContextMenu cm = new ContextMenu();
	Visibility2BooleanConverter converter = new Visibility2BooleanConverter();
	foreach (DataGridColumn col in this.Columns) {
		MenuItem mi = new MenuItem { Header = col.Header };
		Binding isCheckedBinding = new Binding {
			Path=new PropertyPath("Visibility"),
			Source=col,
			Mode=BindingMode.TwoWay,
			Converter=converter,
		};
		mi.SetBinding(MenuItem.IsCheckedProperty, isCheckedBinding);
		mi.Click += (s, e) => {
			mi.IsChecked = !mi.IsChecked;
		};
		cm.Items.Add(mi);
	}

	//右键列名,触发右键菜单显示
	this.MouseRightButtonDown += (s, e) => {
		DependencyObject obj = e.OriginalSource as DependencyObject;
		while (obj != null && !(obj is DataGridColumnHeader)) {
			obj = VisualTreeHelper.GetParent(obj);
		}
		if (obj != null && obj is DataGridColumnHeader) {
			((DataGridColumnHeader)obj).ContextMenu = cm;
		}
	};

	int startColumnIndex = 0, endColumnIndex = 0;
	object tmpMenuItem=null;
	this.ColumnReordering += (s, e) => {
		startColumnIndex = e.Column.DisplayIndex;
		tmpMenuItem = cm.Items[startColumnIndex];
		cm.Items.RemoveAt(startColumnIndex);
	};
	this.ColumnReordered += (s, e) => {
		endColumnIndex = e.Column.DisplayIndex;
		cm.Items.Insert(endColumnIndex, tmpMenuItem);
	};
}


其中,需要自己建立一个Converter类,作用是将Visibility转换为bool类型

/// <summary>
/// Visibility to Boolean的转换类
/// </summary>
public class Visibility2BooleanConverter:IValueConverter {
	public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture) {
		return (Visibility)value == Visibility.Visible;
	}

	public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture) {
		return (bool)value ? Visibility.Visible : Visibility.Collapsed;
	}
}



 代码:http://download.csdn.net/detail/qing2005/4385971

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
WPF中,可以通过以下步骤为DataGrid增加右键菜单: 1. 首先,在XAML文件中定义一个ContextMenu,用于作为右键菜单的内容。可以在Window或者UserControl的资源部分定义ContextMenu,例如: ```xaml <Window.Resources> <ContextMenu x:Key="DataGridContextMenu"> <MenuItem Header="编辑" Click="EditMenuItem_Click"/> <MenuItem Header="删除" Click="DeleteMenuItem_Click"/> </ContextMenu> </Window.Resources> ``` 2. 然后,在DataGrid的样式中,使用EventSetter来为DataGrid的PreviewMouseRightButtonDown事件添加处理程序。在处理程序中,将ContextMenu设置为右键菜单,并设置菜单的PlacementTarget为DataGrid,以确保菜单DataGrid关联。例如: ```xaml <DataGrid> <DataGrid.RowStyle> <Style TargetType="DataGridRow"> <EventSetter Event="PreviewMouseRightButtonDown" Handler="DataGridRow_PreviewMouseRightButtonDown"/> </Style> </DataGrid.RowStyle> </DataGrid> ``` 3. 最后,在代码文件中实现事件处理程序,将ContextMenu设置为右键菜单,并将菜单的PlacementTarget设置为DataGrid。例如: ```csharp private void DataGridRow_PreviewMouseRightButtonDown(object sender, MouseButtonEventArgs e) { DataGridRow row = sender as DataGridRow; if (row != null) { DataGrid dataGrid = FindVisualParent<DataGrid>(row); if (dataGrid != null) { ContextMenu contextMenu = dataGrid.Resources["DataGridContextMenu"] as ContextMenu; if (contextMenu != null) { contextMenu.PlacementTarget = dataGrid; contextMenu.IsOpen = true; e.Handled = true; } } } } private static T FindVisualParent<T>(UIElement element) where T : UIElement { UIElement parent = element; while (parent != null) { T foundElement = parent as T; if (foundElement != null) { return foundElement; } parent = VisualTreeHelper.GetParent(parent) as UIElement; } return null; } ``` 这样,当在DataGrid的行上右键点击时,就会显示出定义的右键菜单

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值