基于C#实现的支持五笔和拼音输入的输入法

一、核心架构设计


二、关键代码实现

1. 输入法核心类
csharp 复制代码
using System;
using System.Collections.Generic;
using System.Runtime.InteropServices;
using System.Windows.Forms;

public class InputMethod
{
    private const int WH_KEYBOARD_LL = 13;
    private const int WM_KEYDOWN = 0x0100;
    private static LowLevelKeyboardProc _proc;
    private static IntPtr _hookID = IntPtr.Zero;

    // 词库缓存
    private static Dictionary<string, List<string>> _pinyinCache = new();
    private static Dictionary<string, string> _wubiCache = new();

    // 输入模式
    public enum InputMode { Pinyin, Wubi }
    public static InputMode CurrentMode { get; set; }

    // 初始化
    static InputMethod()
    {
        LoadPinyinDictionary("pinyin.txt");
        LoadWubiDictionary("wubi.txt");
    }

    // 安装钩子
    public static void InstallHook()
    {
        _proc = HookCallback;
        _hookID = SetHook(_proc);
    }

    // 卸载钩子
    public static void UninstallHook()
    {
        UnhookWindowsHookEx(_hookID);
    }

    // 键盘事件处理
    private static IntPtr HookCallback(int nCode, IntPtr wParam, IntPtr lParam)
    {
        if (nCode >= 0 && wParam == (IntPtr)WM_KEYDOWN)
        {
            int vkCode = Marshal.ReadInt32(lParam);
            Keys key = (Keys)vkCode;

            if (key == Keys.Space)
            {
                ProcessCommit();
            }
            else if (key == Keys.Back)
            {
                ProcessBackspace();
            }
            else
            {
                ProcessInput(key);
            }
        }
        return CallNextHookEx(_hookID, nCode, wParam, lParam);
    }

    // 输入处理
    private static void ProcessInput(Keys key)
    {
        char c = (char)key;
        string input = c.ToString();

        if (CurrentMode == InputMode.Pinyin)
        {
            UpdatePinyinCandidates(input);
        }
        else if (CurrentMode == InputMode.Wubi)
        {
            UpdateWubiCandidates(input);
        }
    }
}
2. 拼音输入实现
csharp 复制代码
public static class PinyinConverter
{
    private static Pinyin4Net.PinyinHelper _pinyinHelper = new();

    // 拼音转候选词
    public static List<string> GetPinyinCandidates(string pinyin)
    {
        var candidates = new List<string>();
        var pinyinArray = _pinyinHelper.GetPinyinWithToneMark(pinyin);
        
        foreach (var py in pinyinArray)
        {
            if (_pinyinCache.ContainsKey(py))
            {
                candidates.AddRange(_pinyinCache[py]);
            }
        }
        return candidates.Distinct().ToList();
    }
}
3. 五笔输入实现
csharp 复制代码
public static class WubiConverter
{
    // 五笔编码解析
    public static string GetWubiCandidate(string code)
    {
        if (_wubiCache.TryGetValue(code, out string result))
        {
            return result;
        }
        return string.Empty;
    }
}

三、词库管理

1. 词库加载
csharp 复制代码
private static void LoadPinyinDictionary(string path)
{
    var lines = File.ReadAllLines(path);
    foreach (var line in lines)
    {
        var parts = line.Split('\t');
        if (parts.Length == 2)
        {
            _pinyinCache.Add(parts[0], parts[1].Split(',').ToList());
        }
    }
}

private static void LoadWubiDictionary(string path)
{
    var lines = File.ReadAllLines(path);
    foreach (var line in lines)
    {
        var parts = line.Split(' ');
        if (parts.Length == 2)
        {
            _wubiCache.Add(parts[0], parts[1]);
        }
    }
}
2. 示例词库格式

pinyin.txt:

csharp 复制代码
ai	爱,艾,唉
shi	是,事,市

wubi.txt:

csharp 复制代码
aaaa	的
bbbb	一
cccc	是

四、界面实现(WinForm)

1. 候选词窗口
csharp 复制代码
public partial class CandidateForm : Form
{
    private ListBox _candidateList;
    private string _currentInput = string.Empty;

    public CandidateForm()
    {
        InitializeComponent();
        _candidateList = new ListBox { Dock = DockStyle.Fill };
        Controls.Add(_candidateList);
    }

    public void UpdateCandidates(List<string> candidates)
    {
        _candidateList.Items.Clear();
        _candidateList.Items.AddRange(candidates.ToArray());
    }

    private void CandidateForm_KeyDown(object sender, KeyEventArgs e)
    {
        if (e.KeyCode == Keys.Enter)
        {
            string selected = _candidateList.SelectedItem.ToString();
            InputMethod.CommitText(selected);
            this.Hide();
        }
    }
}

五、输入模式切换

csharp 复制代码
public static class InputModeSwitcher
{
    public static void SwitchToPinyin()
    {
        CurrentMode = InputMethod.InputMode.Pinyin;
        // 切换系统输入法到拼音
        SetInputMethod("Microsoft Pinyin");
    }

    public static void SwitchToWubi()
    {
        CurrentMode = InputMethod.InputMode.Wubi;
        // 切换系统输入法到五笔
        SetInputMethod("王码五笔");
    }

    private static void SetInputMethod(string layoutName)
    {
        foreach (InputLanguage lang in InputLanguage.InstalledInputLanguages)
        {
            if (lang.LayoutName.Contains(layoutName))
            {
                InputLanguage.CurrentInputLanguage = lang;
                break;
            }
        }
    }
}

参考代码 C# 版输入法 源码(支持五笔输入、拼音输入) www.youwenfan.com/contentcsp/93154.html

六、部署与使用

1. 项目结构
csharp 复制代码
InputMethodDemo/
├── Libs/
│   ├── pinyin4net.dll
│   └── WubiLib.dll
├── Data/
│   ├── pinyin.txt
│   └── wubi.txt
├── Forms/
│   ├── MainForm.cs
│   └── CandidateForm.cs
└── InputMethod.dll
2. 安装说明
  1. InputMethod.dll注册为全局钩子

  2. 在目标程序中引用输入法库

  3. 初始化词库:

    csharp 复制代码
    InputMethod.LoadPinyinDictionary("Data/pinyin.txt");
    InputMethod.LoadWubiDictionary("Data/wubi.txt");

七、扩展功能建议

  1. 智能联想 根据输入历史记录推荐高频字词
  2. 手写输入 集成微软手写识别SDK
  3. 云词库 通过HTTP接口获取最新词汇
  4. 自定义短语 支持用户自定义短语映射
相关推荐
LDR0064 小时前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术4 小时前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript
码云数智-园园5 小时前
C++20 Modules 模块详解
java·开发语言·spring
swordbob5 小时前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
源分享6 小时前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
Luminous.6 小时前
C语言--day30
c语言·开发语言
何以解忧,唯有..6 小时前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
謓泽6 小时前
C语言不是语法,是通往机器的地图。
c语言·开发语言
云水一下6 小时前
从零开始学 PHP 系列(一):PHP 的前世今生与开发环境搭建
开发语言·php
飞天狗1116 小时前
零基础JavaWeb入门——第五课第二小节:九大内置对象 · 第2个:response(响应对象)
java·开发语言