Windows端用于开发低功耗蓝牙项目的DLL(二)

各位读者好,新版本的系统平台低功耗蓝牙开发接口库已发布,提供BLE设备的枚举、扫描、连接和检测,蓝牙服务和特征的枚举、读写、订阅,控制器版本查询等API函数。支持Windows、Android等系统。链接:WCHBleLib_MultiOS.ZIP - 南京沁恒微电子股份有限公司

前言

上一篇文章中,介绍了适用于Win10系统对BLE开发的win32动态链接库,并对库函数进行了细致的讲解,也简单说明了下该开发库的使用方法。

这一章,则具体说明了在BLE开发中对该库的具体使用方法,如何使用这些库函数,如何处理预定义的回调函数。

WCH_B LE_DLL开发库和例程下载

1. 上层应用中回调函数的定义

1.1 异步操作正常完成的回调函数

typedef void (CALLBACK* Notify_AppService)(ULONG uAction_Service, PCHAR tmpStr, INT iExtraInfo);

当前BLE操作,已经正常完成时,该回调函数会被调用。桌面应用程序可以定义一个结构相同的回调函数,用来获取BLE操作完成后的返回信息。

e.g.

VOID CALLBACK NotifyAppservice(ULONG uAction_service, PCHAR tmpstr, INT iExtraInfo);

第一个参数uAction_service表示当前已完成的BLE操作序号;

第二个参数tmpstr表示操作完成后的字符串返回信息;

第三个参数iExtraInfo只有在获取BLE设备特征所支持的功能时才会用到,表示具体的功能值。

p.s.具体参数意义可参照第一篇博客中的头文件代码片段。

1.2 扫描附近BLE设备时的回调函数

typedef void (CALLBACK* Notify_DeviceWatcher)(PCHAR deviceName, PCHAR deviceID);

当执行了扫描BLE设备的操作时,每当扫描到任意设备,或是设备的连接状态发生变化时,该回调函数都会被调用。

e.g.

VOID CALLBACK NotifyDeviceWatcher(PCHAR deviceName, PCHAR deviceID)
{
	//...
	// 当deviceName为removed_Device时,表示对应deviceID的BLE设备无法连接,需要剔除
	if (deviceName == L"removed_Device")
	{
		int iCount = m_CtrlList.GetItemCount();
		for (int i = 0; i < iCount; i++)
		{
			CString tmpStr = m_CtrlList.GetItemText(i, 1);
			if (tmpStr == deviceID)
			{
				m_CtrlList.DeleteItem(i);
				break;
			}
		}
	}
	// 把扫描到的deviceID保存
	else
	{
		m_CtrlList.InsertItem(listCount, deviceName);
		m_CtrlList.SetItemText(listCount, 1, deviceID):
		m_CtrlList.EnsureVisible(listCount++, FALSE);
	}

完整代码可参考链接中的MFC例程。

1.3 BLE操作异常时调用的回调函数

typedef void (CALLBACK* Notify_ErrorStatus)(PCHAR errorString);

当前BLE操作出现异常时,该回调函数会被调用,并通过字符串参数传递异常信息。

e.g.

VOID CALLBACK NotifyErrorStatus(PCHAR errorString)

1.4 BLE读取特征值操作和Notify时的回调函数

typedef void (CALLBACK* Notify_ReadBytes)(PUCHAR readBytes, INT iLength);

当前执行的是BLE读取特征值操作或是开启了Notify订阅时,每当读取到特征值时,会调用该回调函数。

e.g.

VOID CALLBACK NotifyReadBytes(PUCHAR readBytes, INT iLength);

第一个参数readBytes表示读取到的Hex值;

第二个参数iLength表示读取到的字节长度。

2. MFC例程使用说明

为方便用户使用该库进行开发,我们做了一个MFC的例程用来示范,软件详细使用说明如下:

2.1 建立后台任务通讯

先按照第一篇博客配置好BLE开发需要的所有设置后,打开MFC例程如上图所示,首先点击新建连接按钮,与UWP任务建立连接。

2.2 扫描附近BLE设备

连接建立成功后,点击开始扫描按钮,开始扫描附近的所有BLE设备,待列表中出现待连接BLE设备时,单击选中它,然后进入下一步。

2.3 发送BLE设备信息

选中BLE设备时,点击传ID把指定的BLE设备信息传给后台处理程序,准备连接。

2.4 建立BLE设备连接

然后开始建立与BLE设备的连接,点击开始连接设备

2.5 获取服务

连接成功后,点击尝试获取服务,可获取该设备的所有服务,显示在列表中。

2.6 获取特征

选中一个服务后,点击尝试获取特征,可获取该服务的所有特征,显示在列表中。

2.7 获取特征支持的操作

选中一个特征后,点击尝试获取操作后,可枚举出该特征所支持的所有功能。

2.8 读,写, Notify

根据支持的不同功能,可分别进行读,写,开启Notify的功能,以下是读功能的示例,点击READ,可读出特征值:

2.9 断开蓝牙连接

操作完成后,点击断开蓝牙连接可断开与BLE设备的通讯。

2.10 断开后台任务通讯

所有操作完成后,点击关闭即可断开所有通讯连接。

posted @ 2022-07-25 10:56  WCH_SoftGroup  阅读(655)  评论(0编辑  收藏  举报