copy from http://blog.csdn.net/luckywang1103/article/details/12393889#  

HID是Human Interface Devices的缩写,即人机接口设备。HID设备的一大优势就是操作系统已经内置了HID设备驱动,一般不需要安装驱动程序。通用的HID设备可以直接使用HID设备类驱动程序(hidclass.sys)和HID小驱动程序(hidusb.sys).

在应用程序内引入头文件

extern "C"

{

  #include "hidsdi.h"

  #include <setupapi.h>

}

1:查找设备

在应用程序能与HID设备交换数据之前,它先要找到设备,获取关于它的报告信息。

1)HidD_GetHidGuid(&guidHID);来获取HID设备的标示,HID类设备是通过GUID类型值作为标示的。GUID是16字节大小的结构,用来标示通信接口及类对象,他的定义为:

2)还需要调用其他与硬件相关的API函数,这些函数都在setupapi.h 中定义。

  SetupDiGetClassDevs函数用来获得一类硬件设备的信息,设备信息集句柄hDevInfo

  HDEVINFO hDevInfo = SetupDiGetClassDevs(

    &guidHID,//这类设备配置或接口类GUID

    NULL,// 特定的字符串,用来选择合适条件的蛇别

    0,//  与获得信息相关的顶层窗体句柄

    DIGCF_PRESENT | DIGCF_DEVICEINTERFACE //给出了设置信息的方式

    );

3)SetupDiEnumDeviceInterface函数得到设备接口信息,反复调用得到所有设备接口信息strInterfaceData,若要找到特定设备,可在循环语句内调用该函数,直到找到预期设备或函数返回False值,定义为:

  Bool bSuccess = SetupDiEnumDeviceInterface(

    hDevInfo,  //感兴趣的接口句柄

    NULL, //指向SP_DEVINFO_DATA类型结构的指针,该结构定义额特定接口

    &guidHID,  //确定了接口的GUID标示

    Index,  //所关心的索引号,以0为起点

    &strInterfaceData,  //指向SP_DEVICE_INTERFACE_DATA类型的指针,他所指向的内容就是调用函数的目的所在,当函数返回时,strInterfaceData指向的结构就存在相关接口信息  );

  }

  其中SP_DEVINFO_DATA结构定义为:

  typedef struct SP_DEVINFO_DATA{

  DWORD cbsize;//指向结构的大小

  GUID calssGUID; //设备的GUID标志

  DWORD DevInst;//用来访问设备的句柄

  ULONG_PTR Reserved;

  }SP_DEVINFO_DATA,*PSP_DEVINFO_DATA;

  SP_DEVICE_INTERFACE_DATA结构的定义如下:

  typedef struct SP_DEVICE_INTERFACE_DATA{

  DWORD cssize;  //是SP_DEVICE_INTERFACE_DATA结构的大小

  GUID InterfaceClassGuid;  //指定了接口的GUID标示

  DWORD Flags;  //接口所处状态

  ULONG_PTR Reserved;

  }SP_DEVICE_INTERFACE_DATA,*PSP_DEVICE_INTERFACE_DATA;

4) SetupDiGetDeviceInterfaceDetail()

  long Result = SetupDiGetDeviceInterfaceDetail(

  hDevInfo,  //设备信息集句柄

  &strInterfaceData,  //设备接口信息

  NULL,

  0,

  &Length,

  NULL);

  再次调用为了得到strInterfaceDetailData

  long Result = SetupDiGetDeviceInterfaceDetail(

  hDeviceInfo,

  &strInterfaceData,

  strInterfaceDetailData,

  Length,

  &Required,

  NULL);

2,与USB设备交换数据

  在Windows中,读写端口与读写文件都是调用同样的API函数,打开或创建端口用CreateFile,从端口读取数据ReadFile,用WriteFile向端口写入数据

  1) 设备的打开与关闭

    用API函数CreateFIle来打开或者创建设备

    HANDLE hCom = CreateFile(

    strInterfaceDetailData->DevicePath,

    GENERIC_READ | GENERIC_WRITE,

    0,

    NULL,

    OPEN_EXISTING,

    FILE_ATTRIBUTE_NORMAL,

    NULL,

    );

  如果调用成功,函数则返回文件的句柄,如果调用失败,则返回INVALID_HANDLE_VALUE,在打开通信设备是,应该以独占方式打开,不再使用设备句柄时,应该调用CloseHandle(hCom)函数来关闭。

  2)Bool Result = HidD_GetAttributes(hCom,&strAttrib);

    其中hCom是对应于选定设备的句柄,strAttribute则是指向HIDD_ATTRIBUTES类型的指针,当函数返回时即得到了指定设备的属性

    typedef struct _HIDD_ATTRIBUTES{

    ULONG Size;

    USHORT VendorID;

    USHORT VersionNumber;

    }HIDD_ATTRIBUTES,*PHIDD_ATTRIBUTES;

  3) 设备的读写操作,读写通信设备可用同步方式执行

    HANDEL hCom;

    void *pBuffer;

    DWORD iLength;

    DWORD pReadFace;

    Bool ReadFile(hCom,pBuffer,iLength,&pReadFact,NULL);

   读取刀的数据放在pBuffer中,pBuffer要先申请内存空间,iLength为需要读的数据长度,pReadFact存放实际的数据长度。读写设备前,应该调用ClearCommError函数清除,该函数负责报告指定的设备的当前状态,调用PrugeComm函数可以更改正在进行的读写操作方式

 

USB接口程序编写的更多相关文章

  1. Linux驱动之USB鼠标驱动编写

    本篇博客分以下几部分讲解 1.介绍USB四大描述 2.介绍USB鼠标驱动程序功能及框架 3.介绍程序用到的结构体 4.介绍程序用到的函数 5.编写程序 6.测试程序 1.介绍USB四大描述符 USB设 ...

  2. 20151009 C# 第一篇 程序编写规范

    20151009 程序编写规范 1. 代码书写规则: 1).尽量使用接口,然后使用类实现接口. 2).关键语句写注释 3).避免写超过5个参数的方法,如果要传递多个参数,则使用结构 4).避免代码量过 ...

  3. [转]支付宝接口程序、文档及解读(ASP.NET)

    本文转自:http://www.cnblogs.com/blodfox777/archive/2009/11/03/1595223.html 最近需要为网站加入支付宝的充值接口,而目前关于支付宝接口开 ...

  4. Android Camera 相机程序编写

    Android Camera 相机程序编写 要自己写一个相机应用直接使用相机硬件,首先应用需要一个权限设置,在AndroidManifest.xml中加上使用设备相机的权限: <uses-per ...

  5. 基于Asterisk的VoIP开发指南——(2)Asterisk AGI程序编写指南

    原文:基于Asterisk的VoIP开发指南--(2)Asterisk AGI程序编写指南 5. Asterisk AGI程序编写指南 5.1概述 很多时候,我们需要在拨号方案中做某些业务逻辑的判断或 ...

  6. rockchip 3128 平台USB接口鼠标U盘功能调试日记

    2019-04-12 关键词: rk3128 OTG.rk3128外接鼠标U盘.RK外接鼠标U盘 本篇文章是笔者根据自己当前所掌握知识对 rk3128 平台 USB 接口接鼠标实现输入功能调试的一个记 ...

  7. 直接端口打印 支持USB接口的打印机吗?解决办法

    直接端口打印 支持USB接口的打印机吗?解决办法 www.MyException.Cn  网友分享于:2013-09-15  浏览:488次       直接端口打印 支持USB接口的打印机吗?问题如 ...

  8. 支付宝接口程序、文档及解读(ASP.NET)

    最近需要为网站加入支付宝的充值接口,而目前关于支付宝接口开发的资料比较杂乱,这里就我此次开发所用到的资料进行汇总整理,希望能够帮助需要的朋友. 开发步骤: 1. 确定签约类型 支付宝的接口有多种类型, ...

  9. Mathcad 是一种工程计算软件,主要运算功能:代数运算、线性代数、微积分、符号计算、2D和3D图表、动画、函数、程序编写、逻辑运算、变量与单位的定义和计算等。

    Mathcad软件包Mathcad是由MathSoft公司(2006 年4 月被美国PTC收购)推出的一种交互式数值计算系统. Mathcad 是一种工程计算软件,作为工程计算的全球标准,与专有的计算 ...

随机推荐

  1. 转:AMD规范与CMD规范的区别是什么?

    AMD规范与CMD规范的区别是什么?    在比较之前,我们得先来了解下什么是AMD规范?什么是CMD规范?当然先申明一下,我个人也是总结下而已,也是网上看到的资料,自己总结下或者可以说整理下而已,供 ...

  2. iOS 证书 设置指南

    点击这里跳转到改链接:http://docs.jpush.cn/pages/viewpage.action?pageId=1343727

  3. P1001 第K极值

    P1001 第K极值 时间: 1000ms / 空间: 131072KiB / Java类名: Main 背景 成成第一次模拟赛 第一道 描述 给定一个长度为N(0<n<=10000)的序 ...

  4. [Algorithm] A nonrecursive algorithm for enumerating all permutations of the numbers {1,2,...,n}

    def permutationN(n): a=[None]*n for i in range(n): a[i]=i+1 sum=1 for j in range(n): sum*=(j+1) i=0 ...

  5. 国内Ubuntu镜像源

    国内有很多Ubuntu的镜像源,包括阿里的.网易的,还有很多教育网的源,比如:清华源.中科大源. 我们这里以中科大的源为例讲解如何修改Ubuntu 18.04里面默认的源. 编辑/etc/apt/so ...

  6. centos yum出现no module named yum

    运行yum出现如下错误 There was a problem importing one of the Python modules required to run yum. The error l ...

  7. POJ2182 Lost Cows

    题意 Language:Default Lost Cows Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 13448 Accep ...

  8. sql server 循环操作

    使用的sql 语句如下: declare @userid int ;set @userid=0while(@userid<20)begin print 'the result is :'+STR ...

  9. C#常用插件和工具

    Code generation(代码自动生成) NVelocity CodeSmith X-Code .NET XGoF - NMatrix / DEVerest Compilation(编译工具) ...

  10. Linux性能测试工具安装全集

    stress 下载地址:http://people.seas.harvard.edu/~apw/stress/ 一.stress工具安装:1.获取stress源码安装包(stress-1.0.4.ta ...