XBee® ZigBee 模块使用方法
Digi的ZigBee模块简称S2,根据芯片版本的不同历史上分别有S2,S2B,S2C等,每次硬件平台升级,都会引入一个新的尾缀字母。历史版本中S2和S2B已经停产并被S2C替代。当前S2C是主流平台,根据产品路线图的规划,后续会升级到S2D。除了硬件平台上的区别,XBee还有固件上的区别,每隔一段时间,Digi会推出某一系列XBee模块的新的固件,这些新的固件或是增加一些功能,或是解决一些微小的bug,但总的来说,不同固件版本在API层面是相互兼容的,除非软件上用到一些和版本号有关的AT参数或指令,新版模块一般都可以直接替换旧有的模块,而无需在软件层面做出修改。因此不论哪个硬件版本或是固件版本,ZigBee模块都是向下兼容的,在ZigBee协议的支持上是一致的。
XBee S2C系列无线模块是支持标准ZigBee PRO 2007协议的无线模块。普通型和增强型均有邮票孔表贴型和双列直插两种封装。同样有各种天线接口的种类繁多的型号。建议用户选择外置天线的型号。这里只列出最常用的型号:
类型 | 型号 |
---|---|
XBee ZigBee Mesh网络开发套件 | XKB2-Z7T-WZM |
XBee ZigBee 双列直插普通型(RPSMA天线接口) | XB24CZ7SIT-004 |
XBee ZigBee 双列直插普通型(鞭状天线) | XB24CZ7WIT-004 |
XBee PRO ZigBee 贴片式普通型(u.FL天线接口) | XB24CZ7UIS-004 |
XBee PRO ZigBee 双列直插增强型(RPSMA天线接口) | XBP24CZ7SIT-004 |
XBee PRO ZigBee 贴片式增强型(PCB天线) | XBP24CZ7PIS-004 |
XBee PRO ZigBee 贴片式增强型(u.FL天线接口) | XBP24CZ7UIS-004 |
XBee 模块的使用方法
XBee模块通过一个UART串行接口与外部MCU进行交互,单片机或ARM等主控器件,只要逻辑电平不高于XBee模块的定义,通常都可以直接连接XBee的UART进行通信,而无需额外的上拉或下拉电阻。外部主控芯片同XBee的连接最简单的情况仅需接收和发送两根线(DIN,DOUT)即可通信,对于大数据量的传输,根据不同场景您有可能还需要加上流控引脚,此外XBee还有些辅助引脚可针对不同应用场景加以应用,简化开发或方便调试。比如入网信号,引脚休眠,配置按钮,IO引脚等,可根据需要决定是否使用。
ZigBee网络基础
ZigBee是由来自全球三百多家知名企业会员民的ZigBee联盟在基于IEEE802.15.4之上定义的一个开放式全球网络协议标准,它在802.15.4的基础上定义了一套网络层协议来实现自组网功能。
ZigBee协议栈由PHY,MAC,网络层和应用支持子层(APS))组成,ZigBee设备对象(ZDO)作为应用程序框架或者说一个特殊的APS子层是每个ZigBee设备都必须拥有的功能。ZigBee协议定义了三种不同的设备节点类型:协调器,路由器,终端节点。
- 协调器
在ZigBee网络中,协调器负责选定一个信道和PAN ID来创建一个网络。它能允许路由器和终端节点加入网络,可作为路由转发数据,可以为休眠子节点缓存数据,但它不可以休眠。
- 路由器
路由器需先加入协调器的网络才能发送,接收或转发数据,加入网络后它能允许路由器或其它节点加入网络,转发数据,可以为休眠子节点缓存数据,同样地,它也不可以休眠。
- 终端节点
节点设备必须加入ZigBee网络才能发送或接收数据,它不能允许其它设备加入网络,总是通过它的父节点发送或接收数据,不能作为路由转发数据。它可以进入低功耗的休眠模式。
Digi的ZigBee模块简单地说,是内置ZigBee协议栈,带有ZDO功能,支持通过串口简单配置来实现使用ZigBee网络进行通信,它能实现ZigBee的全部功能,但用户又不需要深入了解ZigBee协议本身。使用Digi的ZigBee模块能和其它符合标准ZigBee协议的第三方设备进行通信。
XBee S2C组网和通信测试
透传模式通信
您需要有Digi的XBee ZigBee mesh网络开发套件来进行组网和通信操作。开发套件中带有三个不同的模块和底板,天线和USB线缆,方便您使用电脑进行测试。在进行下一步操作之前,您需要装备好至少两个模块和对应的开发底板。
首先,确保您的电脑上已经安装好Digi的开发工具XCTU。将两个Digi的XBee ZigBee模块通过开发底板和电脑连接起来,打开XCTU,用左上角的查找模块按钮来查询连接到电脑上的模块,并把它添加到XCTU左侧的无线模块列表中。在XCTU软件中,默认是位于配置窗口中,点击左边模块,便会读取模块相关的参数,在配置窗口中展现出来。
首次使用,建议用右侧上方的“Default”按钮加载模块的默认参数,并按“Write”写入模块,使模块恢复出厂的配置,确保不会因为之前使用时的不恰当参数影响通信效果。写入默认值后,再按“Read”按钮重新加载一下参数到XCTU右侧的参数栏上。点击左侧另一个模块,用同样的方式恢复一下模块的出厂设置。
在配置模式下,如果仅对某个参数进行读取和写入,可以使用对应参数右方的刷新和写入按钮。
两个ZigBee模块要相互通信,必须在同一个网络中,所以我们需要将一个模块配置成协调器,另一个模块配置成路由器并加入到协调器的网络中。以下两个模块简称A和B。 A模块:CE=1 配置为协调器,DL=FFFF B模块:不改任何参数 将A模块的CE改为1,就把模块配置成协调器了,这时模块会生成一个网络号为ID指定值的ZigBee网络,默认ID=0,因此协调器会生成一个随机64bit的网络号的ZigBee网络。如果刷新模块参数,会发现OP和CH有一个值了,这里OP是指当前的网络号,CH是指当前的信道号。DH和DL组成模块的目标地址,我们把DL改为FFFF,是因为默认DH和DL都为0,这样指代协调器本身,改成FFFF则是广播地址。
B模块是默认的路由器的出厂配置,ID=0表示可以加入任意网络。如果周边没有其它ZigBee网络,B模块又是首次使用,那么它肯定会在10秒内加入A模块的网络,可以读取一下B模块的OP和CH,观察它是否和A模块相同,以此来判断是否在同一个网络中。默认地B模块的DH和DL都是0,表示目标地址是协调器。入网后,模块的入网指示灯会均匀地闪烁,这样我们已经配置好两个对发的模块了。
这时我们可以点击右上角的图标切换到终端窗口,来观察串口数据透传的效果。终端窗口实际上是个带有ASCII和16进制显示终端的串口调试工具,有个串口打开/关闭按钮,以及一个视图分离按钮,方便查看两个模块各自的收发数据。
分别选中模块,并在终端模式中打开串口,将其中一个模块的串口终端视图分离,我们在任意一个终端中输入数据,另一个模块的张端就能收到相同的数据。如下图所示:
在透传模式下,数据送入A模块的串行UART接口,就会被发到目标地址指定的B模块上,从B模块的串行UART中输出,所以称之为透传。平时模块处于空闲或传输数据的状态,当我们需要更改模块参数时,就可以通过向串口发指定时序的特定字符串来进入命令模式,以便更改模块配置。默认地,在空闲期间连续输入三个“+”号可进入命令模式,这时可以通过向串口发AT命令来实现特定功能。比如,我们之前设置协调器的目标地址为0xFFFF,这样网络内所有的模块者能收到该数据并转发,如果我们只需向特定的模块发送数据,就不应该用广播模式,而需要把目标地址设置为特定的模块的MAC地址,下面AT命令演示了读取B模块的自身地址并将它设置为A模块的目标地址的过程。
在B模块上,用“+++“进入命令模式,发ATSH,ATSL分别读出模块64位MAC地址的高位和低位。切换到A模块的终端窗口中,用ATDH和ATDL把刚才获取得的参数设置目标地址,并用ATWR写入flash,这样断电重启后配置不会被清空。注意,默认地在命令模式中如果10秒内无任何输入,就会退出命令模式,回到透传模式的空闲状态。所以AT命令中的字符请连续输入不要间停超过10秒。否则您需要重新用”+++“进入命令模式。
静静等待约10秒钟后模块退出命令模式(也可以发ATCN命令直接退出命令模式),这时在终端窗口中输入数据,另一个模块的终端也能收到数据,只不过,此时作为协调器的A模块不再是广播模式,而是只定向往B模块发数据了。
通过AT命令可以设置很多参数,比如NI是设置模块的ASCII名称,NR是退网命令,ID是指定网络名称,还可以通过AT命令读取或设置模块的IO口状态等。请查阅XCTU或产口手册获取更多信息。下面我们将把A模块的网络ID更改,让B模块重新加入,以下是完整操作过程的相关AT命令。 A模块:读一下CE,以确定是要操作的协调器A模块;读一下当前ID值;写入新的网络ID;配置写入flash;稍等片刻后查询当前工作的网络ID.
B模块:读一下CE,确定是路由器;读一下当前网络ID;读一下当前信道;发退网命令,离开之前加过的网络;稍等片刻查询新加入的网络ID;查询当前信道。
由于透传模式下,需要通过特定字符组合和时序进入命令模式,在一些需要频繁使用AT命令的场景下就显得很不方便,因此Digi的模块除了支持透传模式外,还可以通过API模式更灵活地使用模块。
API模式通信
API模式,是指外部MCU通过向XBee模块的UART发送指定格式的命令帧,来实现发送数据或执行AT命令等功能。API模式下,XBee模块能够实现比透传模式更多的功能,包括:
- 无需配置DHDL,直接向网络内任意模块进行通信
DH,DL是透传模式下才会用到的参数,在API模式下,命令帧中带有目标地址字段和数据字段
- 随时进行发送本地和远程AT命令,而无需切换模式
API模式下,通过命令帧的识别码来区别是数据发送请求,还是本地AT命令或远程AT命令,无需进行模式切换。
- 发送状态可通过反馈包判断,接收到的数据可识别来源
可以通过开启反馈包,判断每个数据包发送成功与否,接收到的数据可以通过数据帧中的源地址判断是从哪个模块发过来的。
- 可以进行ZDO和ZigBee协议的通信
API模式下的明确寻址数据发送命令帧中,可以使用ZigBee协议的Profile,Cluster,Endpoint字段来实现ZigBee协议的通信。 并且固件中自带有ZDO协议栈处理ZCL请求和响应。
- 更多功能,请阅读产品手册
XBee模块可以通过ATAP命令来设置模块的工作模式,AP=0时是透传模式,AP=1是API模式。 在XCTU上方的工具菜单或工具按钮中,可以找到API组帧和解析工具。在API模式的模块终端窗口中,也会有发送帧的生成向导和接收帧的解析窗口。 下面是用API帧生成工具生成的一个发送数据帧例子:
ZigBee网络内的无线模块,可以全部配置成透传模式或API模式,也可以部分配置成API模式,它们之前可以相互通信,下面将演练一下API模式的模块A和透传模式的模块B进行相互通信实验。
A模块:在配置窗口中,直接设置CE=1, AP=1,并按一下配置窗口上方“Read”按钮刷新一下模块信息,我们会发现API模式下左侧列表协调器图标会多出一个红色”C”字。切换到终端模式,我们会发现API的终端模式和透传模式不太一样,它是以API帧为主的信息框和工具框,如下图所示:
这里,我们利用新增命令帧向导添加一个准备用来发送“test”字符的命令帧,注意目标地址字段要用B模块的Mac地址,如下图所示:
根据向导提示,按“OK”和“Add Frame”按钮,把生成的帧添加到发送列表当中。
B模块:保持透传模式不变,确保DH和DL为默认值0,并且是加入A模块的网络。
同样地,将B模块的终端视图分离出主窗口,以便观察它们的相互通信。 当在A模块中选中刚才生成的发送“test”字符的命令帧,按下发送按钮时,B模块的窗口中就收到了“test”字符。如下图所示:
我们还可以看到,默认地,API带有反馈包,在发送端可以看到发送成功与否的结果。
我们在B模块的终端打一个字符“a”,同样地,A模块就收到带有这个字符的API接收帧,我们可以通过A模块的帧信息详情的下拉滑块查看帧的详细说明。
更多的API命令帧说明,请参考产品手册或Digi XBee API进阶应用指南。
关于XBee API模式帧生成工具代码或者说是API驱动库,请参考XBee API驱动
XBee® ZigBee 模块使用方法的更多相关文章
- 《例说XBee无线模块开发》
<例说XBee无线模块开发> 基本信息 原书名:The Hands-on XBee Lab Manual:Experiments that Teach you XBee Wireless ...
- thinkphp访问不存在的模块或者方法跳转到404页面
使用的thinkphp 版本是3.2.0, 在config.php中配置 404地址,即可: 'TMPL_EXCEPTION_FILE' => './Application/Home/View/ ...
- ThinkPHP3.2判断手机端访问并设置默认访问模块的方法
ThinkPHP3.2判断是否为手机端访问并跳转到另一个模块的方法 目录结构 公共模块Common,Home模块,Mobile模块 配置Application/Common/Conf/config.p ...
- apache2服务器mod_rewrite模块 开启方法[linux, ubuntu]
在UBUNTU系统中要启用mod_rewrite的方法有两种: 第一种: 在终端中执行 sudo a2enmod rewrite 指 令后,即启用了 Mod_rewrite 模块, apache2服务 ...
- python在不同层级目录import模块的方法
使用python进行程序编写时,经常会使用第三方模块包.这种包我们可以通过python setup install 进行安装后,通过import XXX或from XXX import yyy 进行导 ...
- Python学习笔记4-如何快速的学会一个Python的模块、方法、关键字
想要快速的学会一个Python的模块和方法,两个函数必须要知道,那就是dir()和help() dir():能够快速的以集合的型式列出该模块下的所有内容(类.常量.方法)例: #--encoding: ...
- 【转】关于python中re模块split方法的使用
注:最近在研究文本处理,需要用到正则切割文本,所以收索到了这篇文章,很有用,谢谢原作者. 原址:http://blog.sciencenet.cn/blog-314114-775285.html 关于 ...
- python有三种导入模块的方法(转)
原文:http://www.cnblogs.com/allenblogs/archive/2011/11/15/2055149.html python有三种导入模块的方法 其一, import mod ...
- Python中os和shutil模块实用方法集…
Python中os和shutil模块实用方法集锦 类型:转载 时间:2014-05-13 这篇文章主要介绍了Python中os和shutil模块实用方法集锦,需要的朋友可以参考下 复制代码代码如下: ...
随机推荐
- arcgis point 随着 line类型的轨迹运动的动画
animate : function(frampoint,topoint,speed = 60){ var path = topoint.geometry.paths[0]; var i = 1; v ...
- Java学习--枚举
枚举类型enum,地位等同于class,interface 使用enum定义的枚举类型,也是一种变量类型,可用于声明变量 枚举的一些特征 1.它不能有public的构造函数,这样做可以保证客户代码没有 ...
- Python 学习笔记02篇
之前很庆幸早点报名课程 可以早点看到视频讲解,不至于后期太赶 不得不说原本21天压缩到14天再压缩到7天,如果可以完整且独立地完成至少三个作业,那水平应该真的很不错吧
- cent os安装filebeat
先贴一下官方文档https://www.elastic.co/guide/en/beats/filebeat/6.6/filebeat-installation.html 我本次使用rpm的方式安装, ...
- jquery中的 parseJSON() 源码分析
parseJSON: function( data ) { // Attempt to parse using the native JSON parser first if ( window.JSO ...
- C#中将ListView数据导出为excel(转载)
首先引用excel库,下面我把代码贴出来. /// <summary> /// 将ListView的内容写入Excel表中 ...
- linux下用数据泵导入导出(impdp、expdp)
expdp和impdp expdp假设a用户的默认表空间是a,导出用户a所有数据: 如果是多实例 需要在命令行或终端手工指定实例 set ORACLE_SID=实例名 否则回报ORA-12560: T ...
- Loadrunner进行HTTPS协议性能测试
1.最简单办法就是在脚本前面加上:web_set_sockets_option("SSL_VERSION","TLS"),一般能解决HTTPS协议的请求问题,无 ...
- Android 添加第三方jar包
1,拷贝jar包到项目的\app\libs文件夹下. 2,打开项目下的build.gradle(Module:app)文件,在“dependencies {}”中添加“compile files('l ...
- mysql学习笔记--go使用mysql
一. 连接数据库 a. //用户名:密码@[连接方式](主机名:端口号)/数据库名 db,_:=sql.Open("mysql","root:7758521123jf@( ...