怎么在C#中利用WinForm自定义快捷键-创新互联

怎么在C#中利用WinForm自定义快捷键?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

成都创新互联主要从事网站设计、做网站、网页设计、企业做网站、公司建网站等业务。立足成都服务桐乡,10年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:13518219792

项目开发过程中,需要实现类似有道词典的软件设置中的自定义快捷键功能,如下图所示:


怎么在C#中利用WinForm自定义快捷键

当我们相继按下Ctrl+Alt+M的时候,软件就会自动将快捷键显示在文本框中。

最终的效果如下图所示:

怎么在C#中利用WinForm自定义快捷键

核心代码如下所示:

复制代码 代码如下:


private void keyDown(object sender, KeyEventArgs e)
{
    StringBuilder keyValue = new StringBuilder();
    keyValue.Length = 0;
    keyValue.Append("");
    if (e.Modifiers != 0)
    {
        if (e.Control)
            keyValue.Append("Ctrl + ");
        if (e.Alt)
            keyValue.Append("Alt + ");
        if (e.Shift)
            keyValue.Append("Shift + ");
    }
    if ((e.KeyValue >= 33 && e.KeyValue <= 40) ||
        (e.KeyValue >= 65 && e.KeyValue <= 90) ||   //a-z/A-Z
        (e.KeyValue >= 112 && e.KeyValue <= 123))   //F1-F12
    {
        keyValue.Append(e.KeyCode);
    }
    else if ((e.KeyValue >= 48 && e.KeyValue <= 57))    //0-9
    {
        keyValue.Append(e.KeyCode.ToString().Substring(1));
    }
    this.ActiveControl.Text = "";
    //设置当前活动控件的文本内容
    this.ActiveControl.Text = keyValue.ToString();
}

private void keyUp(object sender, KeyEventArgs e)
{
    string str = this.ActiveControl.Text.TrimEnd();
    int len = str.Length;
    if (len >= 1 && str.Substring(str.Length - 1) == "+")
    {
        this.ActiveControl.Text = "";
    }
}


e.KeyValue和字符的对应关系

字符e.KeyValue
a-z|A-Z65-90
F1-F12112-123
0-948-57
PageUp33
PageDown34
End35
Home36
左(←)37
上( ↑ )38
右(→)39
下( ↓ )40

接着,为textbox控件分别设置_KeyDown和_KeyUp事件,并在其中调用以上2个核心函数。

如下所示:


复制代码 代码如下:


private void textBox1_KeyDown(object sender, KeyEventArgs e)
{
    keyDown(sender, e);
}

private void textBox1_KeyUp(object sender, KeyEventArgs e)
{
    keyUp(sender, e);
}



看完上述内容,你们掌握怎么在C#中利用WinForm自定义快捷键的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!

名称栏目:怎么在C#中利用WinForm自定义快捷键-创新互联
网页链接:https://www.cdcxhl.com/article0/coojio.html

成都网站建设公司_创新互联,为您提供手机网站建设ChatGPT移动网站建设定制开发做网站动态网站

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都app开发公司