在表格中使用快捷键打开和关闭下拉菜单总是很方便的,避免了在表格中编辑数据时频繁的使用鼠标。
在本博客中,将介绍如何使用快捷键打开和关闭Winforms平台下的C1TrueDBGrid控件的列和过滤条的下拉菜单。(快捷键可以设置的尽可能方便)
设置快捷键的代码简单易懂,唯一需要注意的是跟踪C1TrueDBGrid控件里下拉菜单的开闭状态。
重写ProcessCmdKey方法实现自定义快捷键处理,以及使用{Shift+F1}组合键打开下拉菜单,用{Shift+F2}组合键关闭菜单,代码如下所示。
protected override bool ProcessCmdKey(ref Message msg, Keys keyData)
{
if (keyData == (Keys.Shift | Keys.F1)) //Shortcut key to be used
{
if (ddstate == 0)
shrtcutopen = 0;
/*CODE TO OPEN THE DROPDOWNS IN THE GRID CELLS WITH SHORTCUT KEY {SHIFT+F1}*/
if (shrtcutopen == 0)
{
SendKeys.Send("%{DOWN}");
shrtcutopen = 1;
}
++counter;
/*CODE TO OPEN THE DROPDOWNS IN THE FILTERBAR WITH SHORTCUT KEY {SHIFT+F1}*/
if (filter == 0)//&& counter == 1)
{
if (c1TrueDBGrid1.FilterActive)
{
SendKeys.Send("%{DOWN}");
filter = 1;
shrtcutopen = 0;
}
}
return false;
}
if (keyData == (Keys.Shift | Keys.F2)) //Shortcut key to be used
{
/*CODE TO CLOSE THE DROPDOWNS IN THE GRID CELLS WITH SHORTCUT KEY {SHIFT+F2}*/
if (shrtcutclose == 1)
{
SendKeys.Send("%{UP}");
shrtcutclose = 0;
}
/*CODE TO CLOSE THE DROPDOWNS IN THE FILTERBAR WITH SHORTCUT KEY {SHIFT+F2}*/
if (filter == 1)
{
SendKeys.Send("%{UP}");
filter = 0;
shrtcutopen = 0;
}
return false;
}
if (keyData == Keys.Enter)
{
filter = 0;
}
return base.ProcessCmdKey(ref msg, keyData);
}
此外,其他的事件,如DropDownOpen,DropDownClose,FilterButtonClick以及SelChange也用来处理相应的行为。
运行效果如下图:
源代码如下:
ComponentOne Enterprise | 下载试用
ComponentOne 是一套专注于企业 .NET开发、支持 .NET Core 平台,并完美集成于 Visual Studio 的第三方控件集,包含 300 多种 .NET开发控件,提供表格数据管理、数据可视化、报表和文档、日程安排、输入和编辑、导航和布局、系统提升工具等七大功能,被誉为“.NET开发的‘瑞士军刀’”。
ComponentOne 为您提供专业的产品咨询服务,并由技术支持工程师为您1对1解答。>> 发帖提问
葡萄城热门产品


