Skip to content

Latest commit

 

History

History
70 lines (48 loc) · 2.68 KB

README.md

File metadata and controls

70 lines (48 loc) · 2.68 KB

#CYLAN rtmp demo code http://www.cylan.com.cn/

============================= Compile: 1. 修改编译平台 PLATFORM=hisi_3518e CROSS_COMPILE=/opt/hisi-linux-3518e/x86-arm/arm-hisiv300-linux/bin/arm-hisiv300-linux-uclibcgnueabi-

2. 添加 mbedtls 编译平台下的toolchain
	cp hisi_3518e.toolchain.cmake ${PLATFORM}.toolchain.cmake
	
	添加对应平台的platform 工具目录
	if [[ "${PLATFORM}" == "hisi_3518e" ]];then
		export PATH=/opt/hisi-linux-3518e/x86-arm/arm-hisiv300-linux/target/bin/:${INITPATH}
	fi
	
3. 在顶层目录编译demo 
	$ make

Modify:

1. 升级
	demo 采用的开源库是 rtmpdump-2.4 & mbedtls-2.3.0 & zlib-1.2.11
	今后如若想升级开源库,只需要去下载相应的开源库,解压到相应的 librtmp   mbedtls zlib 目录下
	并修改Makefile 目录中相应编译的版本,从新编译即可
	
2. 修改democode
	次demo 针对 Cylan hisi3518 摄像头开发测试,测试针对固定h264视屏文件,推流到指定服务器
	
	针对开发厂商可能需要更改一下相应参数,从服务器获取推流 url 地址
	#define ROBOT_SERVER_PORT "443"
	#define ROBOT_SERVER_NAME "www.robotscloud.com (此处填入服务器地址)"
	#define ROBOT_SERVICE_KEY "此处填入用户在萝卜头注册、开通云存储服务的 key"
	#define VID         "此处填入用户在萝卜头注册的企业ID"
	#define SN          "此处填入鉴别设备的唯一序列号"
	#define ACCOUNT     "此处填入设备使用者的账户"
	
	由于测试使用https 从服务器获取推流地址,因此开发者需要修改相应的测试参数,
	从自己的平台获取相应的url 地址用于推流

3. 编译运行
	编译完成后,拷贝到自己的开发平台,并拷贝待发送测试的 video.h264 测试文件到同一目录下
	运行
	./rtmpsend

Tips: 此demo 采用https 获取 url 地址,解析json 返回数据,因为每个服务器返回数据格式可能存在差异, 开发者需要注意用cJson解析出自己的rtmp 推流地址填入 url 变量用于建立链接

关键函数在
	RTMP264_Send()
由于此视屏文件是包含头帧视屏参数sps pps 所以自己解析了视屏的参数属性,并填如了sps pps 用于发送
如果开发者推送的视屏流是完整的h264 帧的数据格式,只需要在每次I帧的时候发送相应的更新数据 sps pps 即可
既可以直接调用Sendh264Packet() 发送视屏帧数据
推流数据第一帧必须为I帧.

致谢: 本demo 在Cylan hisi3518 平台正确运行.

https://github.com/latelee/H264BSAnalyzer	感谢开发者提供的win 下h264帧格式解析器
http://blog.csdn.net/leixiaohua1020		感谢作者推流工作做出的贡献