参考厂商源例程位置:D:\Yifei\Project_Reference\F340_Inforamtion\F340_HID
1. 在项目文件夹内添加下面三个文件
2. 将.lib库添加到工程
在项目头文件中#include “HIDDevice.h”
3. 添加HID相关宏定义
4. 至此,就可以连接HID的,用下面两个函数
GetNumHidDevices(VID_HID, PID_HID);
slabHID.Open(0, VID_HID, PID_HID);
注意,VID和PID,上位机和下位机内要一致。
现在主类中添加HID类成员变量
可以编写一个连接函数使用。
void CslabHIDDlg::AttemptConnection(void)
{
DWORD results;
// Check for connected devices
results = GetNumHidDevices(VID_HID, PID_HID);
// Only proceed if 1 device is found
if (results == 1)
{
// Open connection to device
results = slabHID.Open(0,VID_HID, PID_HID);
// If device connection not established, output failure
if (results != HID_DEVICE_SUCCESS)
{
//SetDlgItemText(IDC_STATIC_HIDSTATUS,_T("Error in connecting to device."));
sTitle = sTitleBase + " Error in connecting to device" ;
// Set dialog title
SetWindowText(sTitle);
}
else
{
//SetDlgItemText(IDC_STATIC_HIDSTATUS,_T("The brothers HID is connected."));
sTitle = sTitleBase + " The debug HID is connected" ;
// Set dialog title
SetWindowText(sTitle);
}
}
else
{
//MessageBox(_T("No device found."));
sTitle = sTitleBase + " No device found" ;
// Set dialog title
SetWindowText(sTitle);
}
}
5. 读写可以分别编写读写函数
// HID
unsigned char Write_HID_Buf[HIDRTSIZE];
unsigned char Read_HID_Buf[HIDRTSIZE];
void CslabHIDDlg::Write_HID()
{
DWORD status;
status = slabHID.SetOutputReport_Interrupt(Write_HID_Buf,OUT_REPORT_BUFFER_SIZE+1);
if ( status != 0)
{
Err_HID_Write ++;
MessageBox( "HID Write Fail!" );
return;
}
else
Err_HID_Write = 0;
memset(Write_HID_Buf,0,sizeof(Write_HID_Buf)); // clear buffer
}
void CslabHIDDlg::Read_HID()
{
memset(Read_HID_Buf,0,sizeof(Read_HID_Buf)); // clear buffer
DWORD results;
DWORD status;
status = slabHID.GetInputReport_Interrupt(Read_HID_Buf,
slabHID.GetInputReportBufferLength(),1,&results);
if ( status != 0)
{
Err_HID_Read ++;
MessageBox( "HID Read Fail!" );
return;
}
else
Err_HID_Read = 0;
// 将返回数据做相应处理
switch(Read_HID_Buf[2])
{
case TYPE_CFGREADDATA:
{
m_configureDlg.SendMessage(WM_CFGDLG_READDATA_EVENT,0,0);
break;
}
case TYPE_GRABMPSENDACK:
{
flag_BmpSendStatus = BMPSENDACK;
break;
}
default:
break;
}
}
注意:HID 读写时发送的第一 byte 必须是 REPORTID_DATA
其中 REPORTID_DATA 是和下位机 HID firmware 的定义一致,如果发送包第一个 byte 不想发 REPORTID_DATA 则下位机 firmware 也要对应修改。
6. 热插拔的实现:
6.1 添加消息映射(直接手动敲就可以了)
6.2 在主类定义中,声明消息相应成员函数:
然后,编写相应函数,就是在这个函数中,针对热插拔的各事件做对应的处理
BOOL CF340HIDDlg::OnDeviceChange(UINT nEventType, DWORD dwData)
{
DWORD results;
switch (nEventType)
{
// A device has been inserted and is now available.
case DBT_DEVICEARRIVAL:
AttemptConnection();
break;
// A device has been removed from USB.
case DBT_DEVICEREMOVECOMPLETE:
// Check for HIDtoUART devices
results = GetNumHidDevices(VID_HID, PID_HID);
if (results == 0)
{
// Close device if found
results = slabHID.Close();
//SetDlgItemText(IDC_STATIC_HIDSTATUS,_T("The brothers HID is removed"));
sTitle = sTitleBase + _T(" The debug HID is removed");
// Set dialog title
SetWindowText(sTitle);
}
break;
default:
break;
}
return TRUE;
}
6.3 注册设备,使用RegisterNotification()函数。
注意,使用该函数用到很多宏定义,需先#include "dbt.h"文件
先在类定义中,定义该成员函数:
然后编写改函数代码:
void CF340HIDDlg::RegisterNotification()
{
// Register device notification
DEV_BROADCAST_DEVICEINTERFACE devIF = { 0 };
GUID hidGuid;
GetHidGuid(&hidGuid);
devIF.dbcc_size = sizeof(devIF);
devIF.dbcc_devicetype = DBT_DEVTYP_DEVICEINTERFACE;
devIF.dbcc_classguid = hidGuid;
m_hNotifyDevNode = RegisterDeviceNotification(GetSafeHwnd(),
&devIF, DEVICE_NOTIFY_WINDOW_HANDLE);
}
热插拔这部分,可以参考https://blog.csdn.net/phenixyf/article/details/48783271 文章后半部分