在表格中使用快捷键打开和关闭下拉菜单总是很方便的,避免了在表格中编辑数据时频繁的使用鼠标。

在本博客中,将介绍如何使用快捷键打开和关闭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也用来处理相应的行为。

运行效果如下图:


源代码如下:

Win_TDBG_CloseFilterDropDown_VB.zip (17.34 kb)

Win_TDBG_CloseFilterDropDown_CS.zip (15.96 kb)