原文:C# Winform制作虚拟键盘,支持中文

          最近在做一个虚拟键盘功能,代替鼠标键盘操作,效果如下:

       实现思路:

         1  构建中文-拼音 数据库,我用的是SQLite数据库,如

              

         2 构建布局,如效果图

代码:

  数据库代码文件  SqlHandler.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SQLite;
using System.Configuration;
using System.IO;
using System.Reflection;
using System.Windows.Forms; namespace TestKeyBord
{ public class SqlHandler
{
public static void InitSQLite(string db,string table)
{
try
{
DbName = db;
TableName = table; if (CreateDataBase())
{
_SQLiteCommand = _SQLiteConn.CreateCommand();
_SQLiteCommand.Connection = _SQLiteConn;
DesignerTable();
}
}
catch
{ }
} public static System.Data.ConnectionState SqliteState
{
get { return _SQLiteConn.State; }
} #region 数据成员定义 public static string DbName = "MedicalSystemLog";
public static string TableName = "MedicalLog";
public static string _SQLiteConnString = string.Empty; public static SQLiteConnection _SQLiteConn = new SQLiteConnection(); public static SQLiteCommand _SQLiteCommand = new SQLiteCommand(); #endregion #region 创建数据库文件 public static bool CreateDataBase()
{
try
{
_SQLiteConnString = "Data Source=" + DbName + ".db";
_SQLiteConn = new SQLiteConnection(_SQLiteConnString);
_SQLiteConn.Open();
_SQLiteCommand = _SQLiteConn.CreateCommand();
_SQLiteCommand.Connection = _SQLiteConn; if (File.Exists(DbName + ".db"))
{
return true;
}
}
catch
{
// MessageBox.Show("日志系统加载失败!");
}
return false;
} #endregion /// <summary>
/// 矩阵是否连接
/// </summary>
public static bool MatrixIsConnected = false; #region 创建表 public static void DesignerTable()
{
try
{
if (_SQLiteConn.State != System.Data.ConnectionState.Open)
{
_SQLiteConn.Open();
} List<string> list = new List<string> { };
list.Add("ID VARCHAR(5)");//汉字ID
list.Add("Chinese VARCHAR(5)");//汉字
list.Add("English VARCHAR(10)");//拼音
CreateTabel(TableName, list);
list.Clear();
}
catch
{
// MessageBox.Show("创建日志数据库失败!");
}
} public static bool ClearSystemLog()
{
try
{ if (_SQLiteConn.State != System.Data.ConnectionState.Open)
{
_SQLiteConn.Open();
} if (_SQLiteConn.State == System.Data.ConnectionState.Open)
{ _SQLiteCommand.CommandText = "delete from " + TableName + ";";
_SQLiteCommand.ExecuteNonQuery(); } _SQLiteConn.Close();
} catch (Exception ex)
{
// MessageBox.Show("清除日志失败:" + ex.Message);
return false;
}
return true;
} public static bool InsertData(string cn,string en,string id)
{
try
{ if (_SQLiteConn.State != System.Data.ConnectionState.Open)
{
_SQLiteConn.Open();
} if (_SQLiteConn.State == System.Data.ConnectionState.Open)
{ _SQLiteCommand.CommandText = "insert into " + TableName + " values('" +
id + "','" + cn + "','" + en + "');";
_SQLiteCommand.ExecuteNonQuery(); } _SQLiteConn.Close();
}
catch (Exception ex)
{
// MessageBox.Show("日志写入失败:" + ex.Message);
return false;
}
return true;
} public static List<string[]> GetData(string en)
{
List<string[]> list = new List<string[]> { }; try
{ _SQLiteCommand.CommandText = "select * from " + TableName + " where English='"+en+"';"; using (SQLiteDataReader reader = _SQLiteCommand.ExecuteReader())
{ string[] items = new string[] { }; while (reader.Read())
{
items = new string[]
{
reader[0].ToString(),
reader[1].ToString(),
reader[2].ToString(),
};
list.Add(items);
} }
} catch (Exception ex)
{
MessageBox.Show(ex.Message + "=== GetDocInfo() ===" + ex.StackTrace);
}
return list;
} public static List<string> GetZnData(string en)
{ en = en.ToLower(); ; List<string> list = new List<string> { }; try
{ _SQLiteCommand.CommandText = "select * from " + TableName + " where English='" + en + "';";
// MessageBox.Show(_SQLiteCommand.CommandText);
using (SQLiteDataReader reader = _SQLiteCommand.ExecuteReader())
{ string[] items = new string[] { }; while (reader.Read())
{ list.Add(reader["Chinese"].ToString());
} }
} catch (Exception ex)
{
MessageBox.Show(ex.Message + "=== GetDocInfo() 2222 ===" + ex.StackTrace);
}
return list;
} public static void CreateTabel(string tableName,List<string> columes )
{
if (_SQLiteConn.State != System.Data.ConnectionState.Open)
{
_SQLiteConn.Open();
} if (_SQLiteConn.State == System.Data.ConnectionState.Open)
{ string sql = "SELECT COUNT(*) FROM sqlite_master where type='table' and name='" + tableName + "';"; _SQLiteCommand.CommandText = sql; if (Convert.ToInt32(_SQLiteCommand.ExecuteScalar()) == 0)//1表示存在,0表示不存
{
sql = string.Empty; foreach (string str in columes)
{
sql += str + ",";
} _SQLiteCommand.CommandText = string.Format(
"CREATE TABLE {0} (" + sql.Substring(0, sql.Length - 1) + ")"
, tableName); _SQLiteCommand.ExecuteNonQuery();
_SQLiteConn.Close();
} }
else
{
MessageBox.Show("创建表失败,请打开数据库!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
} public static string PinConvert(string en)
{
string data = "";
string enLow = en.ToLower();
for (int i = 0; i < enLow.Length; i++)
{
if (enLow[i].ToString() == "ā")
{ }
}
return data;
} #endregion
}
}

源码下载地址: http://download.csdn.net/detail/taoerit/9686889

更新 2017-2-13 ,还有个简单的方法 

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Runtime.InteropServices; namespace TestForm
{
public partial class Form1 : Form
{
[DllImport("user32.dll", EntryPoint = "keybd_event")]
public static extern void keybd_event(
byte bVk, //定义一个虚据拟键码。键码值必须在1~254之间。
byte bScan, //定义该键的硬件扫描码
int dwFlags,
int dwExtraInfo
); private void button1_Click(object sender, EventArgs e)
{
// 81 表示Q,具体看虚拟键盘表示码
textBox1.Focus();
keybd_event(81, 0, 0, 0); //Q压下
keybd_event(81, 0, 0x02, 0); //Q弹起
} public Form1()
{
InitializeComponent();
} private void Form1_Load(object sender, EventArgs e)
{
} }
}

虚拟键盘码


C# Winform制作虚拟键盘,支持中文的更多相关文章

  1. C# WinForm制作电子琴键盘

    上一篇 http://hovertree.com/h/bjaf/y8qol2p4.htm 再上一篇的基础上,使用WinForm制作了一个电子琴键盘: 演示地址 http://hovertree.com ...

  2. 利用zxing制作彩色,高容错,支持中文等UTF编码的QR二维码图片

    利用zxing制作彩色,高容错,支持中文等UTF编码的QR二维码图片.代码如下 import java.awt.Color;import java.io.File;import java.util.H ...

  3. 《Genesis-3D开源游戏引擎--横版格斗游戏制作教程08:虚拟键盘实现》--本系列完结

    8.虚拟键盘实现 概述: 硬键盘就是物理键盘,平时敲的那种.软键盘是虚拟的键盘,不是在键盘上,而是在"屏幕"上.虚拟按键就是虚拟键盘的一部分,根据功能需求,提供部分按键效果的UI可 ...

  4. Xcode6.1模拟器ios8.1模拟器不能弹出虚拟键盘及虚拟键盘无法切换中文输入的解决办法

    1.不能弹出虚拟键盘的解决办法 模拟器菜单Hardware->Keyboard->Connect Hardware Keyboard取消选中,快捷键commad+shift+K 2.虚拟键 ...

  5. [原创]cocos2d-x研习录-第三阶 特性之按键与虚拟键盘

    Cocos2D-x引擎支持按键事件,它能检测设备的键盘输入并处理相应的事件.而基于不同操作系统的移动设备,可供用户操作的按键数量和功能都存在差异.   Cocos2D-x使用CCKeypadDeleg ...

  6. 重新想象 Windows 8 Store Apps (49) - 输入: 获取输入设备信息, 虚拟键盘, Tab 导航, Pointer, Tap, Drag, Drop

    [源码下载] 重新想象 Windows 8 Store Apps (49) - 输入: 获取输入设备信息, 虚拟键盘, Tab 导航, Pointer, Tap, Drag, Drop 作者:weba ...

  7. Ubuntu CTRL+ALT+F1~F6 进入命令模式后不支持中文显示的解决办法

    前言 我在实验进入linux系统启动xwindow server而不启动KDE GNOME等桌面系统时遇到的问题.只启动x server而不启动桌面系统,在xserver之上运行一个全屏的图形界面程序 ...

  8. 隐藏虚拟键盘,解决键盘挡住UITextField问题

    再正式开始之前,先来介绍一下IOS的键盘类型: 一.键盘风格 UIKit框架支持8种风格键盘 ? 1 2 3 4 5 6 7 8 9 10 typedef enum {      UIKeyboard ...

  9. 收起虚拟键盘的各种方法 -- IOS

    使用虚拟键盘来输入资讯,是 iOS 的重要互动方式之一,虚拟键盘通常会自动出现在可以编辑的 UITextField 或是 UITextView 的编辑事件中,叫出键盘固然容易,但是要把它收起来,可就没 ...

随机推荐

  1. MySQL的表空间管理

    表空间: MySQL没有真正意义上的表空间管理. MySQL的Innodb包含两种表空间文件模式,默认的共享表空间和每个表分离的独立表空间. 一般来说,当数据量很小的时候建议使用共享表空间的管理方式. ...

  2. CentOS 7安装fcitx中文输入法

    安装过程例如以下: 1.增加EPEL源 EPEL7差点儿是CentOS必备的源: sudo yum install epel-release 2.加入mosquito-myrepo源 mosquito ...

  3. C/C++ 变量的初始化

    局部变量,初始化为垃圾值,局部静态变量初始化为 0: 1. 二维数组 // 作为局部变量 int arr[4]; // 全是垃圾值 int arr[4] = {1}; // 第一个元素为 1,其他默认 ...

  4. Google Guava官方教程

    原文链接 译文链接 译者: 沈义扬,罗立树,何一昕,*武祖 * 校对:方腾飞 引言 Guava工程包含了若干被Google的 Java项目广泛依赖 的核心库,例如:集合 [collections] . ...

  5. 使用Fernflower 比较准确的反编译整个java项目

    以前一直使用jd-gui.exe  ,都说是最好用的,但是编译总是有问题,还得修改,使用idea 后,感觉反编译的相当好,看注释是 Fernflower,然后参考 http://the.bytecod ...

  6. 版本控制— SVN & git

    版本控制—— SVN & GIT 提问 什么是版本控制? 是能够一直监视代码文件的变更,并存储这些文件以便将来引用的一种机制(软件) 为什么要使用版本控制? (1)记录哪个开发人员做了变更 ( ...

  7. 验证redis的快照和AOF

    http://blog.csdn.net/lichangzai/article/details/8692103 redis持久化简介: redis是一个支持持久化的内存数据库,也就是说redis需要经 ...

  8. 【codeforces 768A】Oath of the Night's Watch

    [题目链接]:http://codeforces.com/contest/768/problem/A [题意] 让你统计这样的数字x的个数; x要满足有严格比它小和严格比它大的数字; [题解] 排个序 ...

  9. 利用SendMessage实现窗口拖动

    原文:利用SendMessage实现窗口拖动 利用SendMessage实现窗口拖动                                            周银辉 想想以前用跟踪鼠标位 ...

  10. Linux下安装mysql(1)(CentOS)

    标题是(1)也就是说这次是基础安装,这种方式安装,没有组的创建,权限管理,配置文件更改等,仅仅是最基本的安装,适合第一次在linux上安装mysql的新手 1.准备好安装包(Linux-Generic ...