首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

直播应用开发技术:实现直播间内消息的双向传输

在日常生活中,很多人有看直播的习惯,直播也给这些人带来了欢乐,不仅仅是因为直播间里的主播的直播内容的精彩,还有就是他们可以在直播间里进行互动,当然,互动的方式有很多,像是送礼物、点赞、发红包等等,今天我要说的互动方式和这些都不同,但是确是用户观看直播app源码平台直播的主要互动方式,这个互动方式多用于用户与用户之间,可能很多人已经猜到了这个互动方式是什么了,没错,它就是直播app源码平台直播间里的聊天区,那你知道直播app源码平台直播间里的用户聊天区的消息的发送和接收是怎么实现的吗?下面我就将直播应用开发技术直播间内的消息的发送与接收的实现分享给大家。

05

NRF24L01多通道通讯

nRF24L01 是一款工作在 2.4~2.5GHz 世界通用 ISM 频段的单片无线收发器芯片。 NRF24L01 单通道实现通讯很简单,只要收发方地址设置正确,就能正常通讯。 但是 NRF24L01 多通道通信,有很多误区。官网的数据手册描述的也是模糊不清,经过我 不断的调试和收集资料,有了点小成果。 一: NRF24L01 支持多通道收发 对于这个多通道有很多理解,(特别和啊海的理解冲突), 现在实验证明: NRF24L01 只有通道 0 可以发射数据和接收,通道 12345 只能接收数据。 而且通道 2345 的高字节 bit39~8 和地址 1 共用。设置为发送模式时不需要选择通道,因为 硬件默认设置发送模式下为通道 0 发送。 正常通讯的结构是 6 个发射机发数据给 1 个接收机接收。 二: RX --TX 地址设置 一个芯片最多可以设置 6 个接收地址。 所以多对一发送比较简单。 但是想要一对多发送的话 就只能一个一个发送了。 nRF24L01 配置为接收模式时可以接收 6 路不同地址,相同频率 的数据 每个数据通道拥有自己的地址, 并且可以通过寄存器来进行分别配置-。 每一个数据 通道的地址是通过寄存器 RX_ADDR_Px 来配置的,正常通讯情况下不允许不同的数据通 道设置完全相同的地址。 u8 TX_ADDRESS0[TX_ADR_WIDTH]={0x00,0xc2,0xc2,0xc2,0xc2}; //发送地址(地址要和接收通道地址一致) u8 RX_ADDRESS0[RX_ADR_WIDTH]={0x00,0xc2,0xc2,0xc2,0xc2}; //接收0 通道地址(地址要和发射地址一致) u8 RX_ADDRESS1[RX_ADR_WIDTH]={0x01,0xc2,0xc2,0xc2,0xc2};//接收1 通道地址 u8 RX_ADDRESS2[RX_ADR_WIDTH]={0x02,0xc2,0xc2,0xc2,0xc2,};//接收2 通道地址 u8 RX_ADDRESS3[RX_ADR_WIDTH]={0x03,0xc2,0xc2,0xc2,0xc2,};//接收3 通道地址 u8 RX_ADDRESS4[RX_ADR_WIDTH]={0x04,0xc2,0xc2,0xc2,0xc2,};//接收4 通道地址 u8 RX_ADDRESS5[RX_ADR_WIDTH]={0x05,0xc2,0xc2,0xc2,0xc2}; //接收5 通道地址 上面地址标记为蓝色的可以可以随便修改, 其他的被固化了, 不能修改, 写地址时是低位先 写 要想成功通讯的条件: 1 接收地址和发射地址必须一致 2 无线模块 0x05 寄存器的值必须一致(发射/接收这2 模块) 3 无线模块从 0x00 寄存器往后的(各个 bit 位的功能)去看下手册 三:多个 NRF24L01 组网 正常情况下, NRF24L01 只能一对 6 进行通信, 如果超过 6 个模块进行通信就无法实现。 但是可以通过轮询来区分: 比如一个空间内要实现 100 个温度实时监测,就可以主机用轮询的方式来进行通信, 从机地址都可以设置一样, 通过主机给从机发命令, 让指定从机发送数据回来。 在同一 时间内只能是一个从机和主机进行通信,因为多个节点同时发数据有问题,会造成 24L01 芯片死机(我调试时碰到过)。 在用 STM32F103ZET6 板子调试时,发现 24L01 的几个问题: 1. 作为发送时,和容易出现发送-----但是不判断返回值强行发送却 能发送成功。 2、无论发送与接收,数据传输速率很低,实时性很差,反应很迟钝。 3、无论发送与接收,稳定性很差,模块时而检测到时而检测不到;时而接受到数据 ,时而 接收不到数据----不清楚是代码问题还是硬件问题,个人觉得是硬件问题。

01

CANalyzer及CANOE使用五:无DBC,调CSV方式的网关信号转发或单通道信号值控制ECU其他信号变化(包含设计自动化测试)[通俗易懂]

请输入公众号:总线网络。关注我,获取汽车网络开发及测试方面资料,更新干货! 同事:CAN网络用CANalyzer及CANOE测UDS、NM等,都可以实现自动化,功能信号是否也可以?不用HIL测试有简单方法吗?主机厂不给DBC,excel转DBC工具不合适咋办?手动测太累了,矩阵表信号那么多,几十个Bit都够算了,脑袋都昏了。 我:可以哇,那就整一个自动算信号bit值的吧。 同事:不仅要算,还要判断ECU接收某些开关信号、温度、档位等的一系列反应(其他信号值的改变是否正确),还可以通道不同的也可用于网关的,比如说BCM。。 我:可以,整一个。 同事:还有可能有网关转发信号起始bit,bit长度,接收的一方的信号值也要变,用于仪表,AC等。 我:。。。。。。

02

2018年8月16日TCP中三次握手和四次挥手详解

上图中有几个字段需要重点介绍下:         (1)序号:Seq序号,占32位,用来标识从TCP源端向目的端发送的字节流,发起方发送数据时对此进行标记。         (2)确认序号:Ack序号,占32位,只有ACK标志位为1时,确认序号字段才有效,Ack=Seq+1。         (3)标志位:共6个,即URG、ACK、PSH、RST、SYN、FIN等,具体含义如下:                 (A)URG:紧急指针(urgent pointer)有效。                 (B)ACK:确认序号有效。                 (C)PSH:接收方应该尽快将这个报文交给应用层。                 (D)RST:重置连接。                 (E)SYN:发起一个新连接。                 (F)FIN:释放一个连接。         需要注意的是:                 (A)不要将确认序号Ack与标志位中的ACK搞混了。

02
领券