C# TextBox 控件限制输入字符为十六进制字符串

代码功能总结

上述代码用于限制 C# Windows Forms 应用程序中的 TextBox 控件,使其只能输入 16 进制字符(0-9、A-F)和空格,并自动将小写字母转换为大写。主要用途是创建一个用于输入和筛选 16 进制数据的文本框,例如 CAN 总线 ID 过滤、十六进制值搜索等场景。

核心功能

  1. 输入限制:只允许输入数字 0-9、字母 A-F(大小写均可)和空格
  2. 自动转换:自动将输入的小写字母转换为大写
  3. 验证功能:提供方法验证整个文本是否为有效的 16 进制字符串
  4. 清理功能:提供方法获取移除空格后的纯净 16 进制文本

使用方法

  1. 在窗体设计器中添加一个 TextBox 控件(命名为 textBoxFilter
  2. 在窗体类的构造函数中注册事件处理:
cs 复制代码
textBoxFilter.KeyPress += TextBoxFilter_KeyPress;
textBoxFilter.TextChanged += TextBoxFilter_TextChanged;

详细代码

cs 复制代码
using System;
using System.Windows.Forms;

public partial class YourForm : Form
{
    public YourForm()
    {
        InitializeComponent();
        
        // 注册事件处理
        textBoxFilter.KeyPress += TextBoxFilter_KeyPress;
        textBoxFilter.TextChanged += TextBoxFilter_TextChanged;
    }

    private void TextBoxFilter_KeyPress(object sender, KeyPressEventArgs e)
    {
        // 允许的字符:0-9, A-F, a-f, 空格
        if (!char.IsControl(e.KeyChar) && 
            !char.IsDigit(e.KeyChar) && 
            !((e.KeyChar >= 'A' && e.KeyChar <= 'F') || (e.KeyChar >= 'a' && e.KeyChar <= 'f')) && 
            e.KeyChar != ' ')
        {
            e.Handled = true; // 阻止输入无效字符
        }
    }

    private void TextBoxFilter_TextChanged(object sender, EventArgs e)
    {
        // 将小写字符转换为大写
        if (textBoxFilter.Text != null)
        {
            string upperCaseText = textBoxFilter.Text.ToUpper();
            if (upperCaseText != textBoxFilter.Text)
            {
                // 防止递归调用
                textBoxFilter.TextChanged -= TextBoxFilter_TextChanged;
                textBoxFilter.Text = upperCaseText;
                textBoxFilter.SelectionStart = textBoxFilter.Text.Length;
                textBoxFilter.TextChanged += TextBoxFilter_TextChanged;
            }
        }
    }

    // 额外:验证整个文本是否为有效的16进制字符串
    private bool IsValidHexString(string text)
    {
        // 移除所有空格
        string cleanText = text.Replace(" ", "");
        
        // 验证是否为空或仅包含16进制字符
        if (string.IsNullOrEmpty(cleanText))
            return true;
            
        foreach (char c in cleanText)
        {
            if (!char.IsDigit(c) && !(c >= 'A' && c <= 'F'))
                return false;
        }
        
        return true;
    }

    // 额外:获取清理后的16进制文本(移除空格)
    public string GetCleanHexText()
    {
        return textBoxFilter.Text?.Replace(" ", "");
    }
}

实现说明

  1. KeyPress 事件处理

    • 允许输入的字符包括:
      • 控制字符(如退格、删除键)
      • 数字 0-9
      • 大写字母 A-F
      • 小写字母 a-f(会在 TextChanged 中转换为大写)
      • 空格
    • 无效字符会被阻止输入
  2. TextChanged 事件处理

    • 将输入的小写字母自动转换为大写
    • 使用 TextChanged -= TextBoxFilter_TextChanged 防止递归调用
    • 保持光标的正确位置
  3. 额外功能

    • IsValidHexString 方法验证整个文本是否为有效 16 进制字符串
    • GetCleanHexText 方法获取移除空格后的纯净 16 进制文本

使用示例

在窗体设计器中添加一个名为 textBoxFilter 的 TextBox 控件,然后将上述代码添加到窗体类中。当用户在文本框中输入时,会自动:

  • 阻止输入无效字符
  • 将小写字母转换为大写
  • 允许输入空格作为分隔符

注意事项

  1. 性能考虑

    • 文本转换操作在 UI 线程执行,对于短文本输入影响可忽略
  2. 用户体验

    • 保留空格作为分隔符,方便输入多组 16 进制数
    • 实时反馈无效输入,提升用户体验
  3. 扩展可能性

    • 可修改 KeyPress 事件处理逻辑,允许更多字符(如短横线 - 作为分隔符)
    • 可添加输入长度限制

这个实现方案能够有效限制 TextBox 控件只输入 16 进制字符串和空格,并自动将小写字符转换为大写,满足了数据筛选和输入验证的需求。

相关推荐
Larry_Yanan19 小时前
Qt多进程(三)QLocalSocket
开发语言·c++·qt·ui
醒过来摸鱼19 小时前
Java classloader
java·开发语言·python
superman超哥19 小时前
仓颉语言中元组的使用:深度剖析与工程实践
c语言·开发语言·c++·python·仓颉
小鸡吃米…19 小时前
Python - 继承
开发语言·python
JIngJaneIL19 小时前
基于java+ vue农产投入线上管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
祁思妙想19 小时前
Python中的FastAPI框架的设计特点和性能优势
开发语言·python·fastapi
唐装鼠19 小时前
rust自动调用Deref(deepseek)
开发语言·算法·rust
Lucas5555555520 小时前
现代C++四十不惑:AI时代系统软件的基石与新征程
开发语言·c++·人工智能
源代码•宸20 小时前
goframe框架签到系统项目(BITFIELD 命令详解、Redis Key 设计、goframe 框架教程、安装MySQL)
开发语言·数据库·经验分享·redis·后端·mysql·golang
吃喝不愁霸王餐APP开发者20 小时前
Java后端系统对接第三方外卖API时的幂等性设计与重试策略实践
java·开发语言