抓取扫描枪扫描数据的案例.docx

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
抓取扫描枪扫描数据的案例

背景: 最近要做一个抓取扫描枪扫描条形码获取条形码数据的功能,以前没有玩过扫描枪,但是因为做过很多其他方面的外设获取数据的项目,所以原理也明白,都是相当于键盘输入,所以相当的是通过获取键盘输入的方案实现,因为这个功能点是用于整个pc上所有扫描枪程序的数据的抓取,就是其他程序用扫描枪,我做的这个程序也能抓取到数据,并对数据进行相应的处理,至于数据处理那是后面自己所做的业务需求的处理了,和抓取扫描枪扫描数据无关了,所以可以通过全局键盘钩子抓取键盘的输入去实现,这样能够去获取每个键盘输入的值,想法有了,那就是实现功能了,至于代码方面吗!由于鄙人做的是Windows客户端的功能,熟悉C#,所以下面的演示是通过WPF展示。Solution: 有了想法肯定要实际去操作了,首先知道通过全局键盘钩子去抓取键盘输入的数据,那就调用Win32Api创建键盘钩子Hook去实现,这个功能实现代码在网上一搜,那是太容易找到了,博客园里面也有,但是一个完整的功能自己还是自己Copy一下吧!里面注释很全面,都能看懂! 1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Runtime.InteropServices; 5 using System.Text; 6 using System.Threading.Tasks; 7 using System.Windows.Forms; 8 9 namespace MedicalMain 10 { 11 public class KeyboardHook 12 { 13 public event KeyEventHandler KeyDownEvent; 14 public event KeyPressEventHandler KeyPressEvent; 15 public event KeyEventHandler KeyUpEvent; 16 17 public delegate int HookProc(int nCode, Int32 wParam, IntPtr lParam); 18 static int hKeyboardHook = 0; //声明键盘钩子处理的初始值 19 //值在Microsoft SDK的Winuser.h里查询 20 public const int WH_KEYBOARD_LL = 13;//线程键盘钩子监听键盘消息设为2,全局键盘监听鼠标消息设为13 21 HookProc KeyboardHookProcedure; //声明KeyboardHookProcedure作为HookProc类型 22 //键盘结构 23 [StructLayout(LayoutKind.Sequential)] 24 public class KeyboardHookStruct 25 { 26 public int vkCode; //定一个虚拟键码。该代码必须有一个价值的范围1至254 27 public int scanCode; // 指定的硬件扫描码的关键 28 public int flags; // 键标志 29 public int time; // 指定的时间戳记的这个讯息 30 public int dwExtraInfo; // 指定额外信息相关的信息 31 } 32 //使用此功能,安装了一个钩子 33 [DllImport(user32.dll, CharSet = CharSet.Auto, CallingConvention = CallingConvention.StdCall)] 34 public static extern int SetWindowsHookEx(int idHook, HookProc lpfn, IntPtr hInstance, int threadId); 35 36 37 //调用此函数卸载钩子 38 [DllImport(user32.dll, CharSet = CharSet.Auto, CallingConvention = CallingConvention.StdCall)] 39 public static extern bool UnhookWindowsHookEx(int idHook); 40 41 42 //使用此功能,通过信息钩子继续下一个钩子 43 [DllImport(user32.dll, CharSet = CharSet.Auto, CallingConvention = CallingConvention.StdCall)] 44 public

文档评论(0)

shaoye348 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档