php七牛云rtmp直播推流,GitHub - jangocheng/FlutterQiniucloudLivePlugin: Flutter 七牛云直播云 推流/播放 SDK集成...
flutter_qiniucloud_live_plugin
Flutter 七牛云直播云插件,支持IOS、Android客户端
Getting Started
集成七牛云直播云推流、观看等功能
功能清单
推流端
[x]推流
[x]推流时初始化自定义系统参数、预览参数等内容
[x]美颜设置
[x]自动对焦
[ ]手动对焦
[x]回调监听器
[x]动态水印
[ ]背景音乐
播放端
[x]播放
[x]监听器
连麦SDK
[x]连麦
[x]远端画面播放
集成
Flutter
flutter_qiniucloud_live_plugin:
git:
url: https://github.com/JiangJuHong/FlutterQiniucloudLivePlugin.git
ref: master
Android
不需要额外集成,已内部打入混淆
IOS
配置权限信息,在Info.plist中增加
io.flutter.embedded_views_preview
NSAppTransportSecurity
NSAllowsArbitraryLoads
NSCameraUsageDescription
App需要您的同意,才能访问相机
NSMicrophoneUsageDescription
App需要您的同意,才能访问麦克风
NSPhotoLibraryUsageDescription
App需要您的同意,才能访问相册
UIBackgroundModes
audio
注意事项
由于Android、IOS底层兼容不一致,导致以下内容会受影响:
QiniucloudPlayerView 监听器
Error 回调参数:Android:int 错误码 or IOS:String 错误描述
Info 状态码: IOS or Android 不一致
Android
状态码
描述
1
未知消息
3
第一帧视频已成功渲染
200
连接成功
340
读取到 metadata 信息
701
开始缓冲
702
停止缓冲
802
硬解失败,自动切换软解
901
预加载完成
8088
loop 中的一次播放完成
10001
获取到视频的播放角度
10002
第一帧音频已成功播放
10003
获取视频的I帧间隔
20001
视频的码率统计结果
20002
视频的帧率统计结果
20003
音频的帧率统计结果
20004
音频的帧率统计结果
10004
视频帧的时间戳
10005
音频帧的时间戳
1345
离线缓存的部分播放完成
565
上一次 seekTo 操作尚未完成
IOS
状态码
描述
0
未知状态,只会作为 init 后的初始状态,开始播放之后任何情况下都不会再回到此状态。
1
正在准备播放所需组件,在调用 -play 方法时出现。
2
播放组件准备完成,准备开始播放,在调用 -play 方法时出现。
3
播放组件准备完成,准备开始连接
4
缓存数据为空状态。(特别需要注意的是当推流端停止推流之后,PLPlayer 将出现 caching 状态直到 timeout 后抛出 timeout 的 error 而不是出现 PLPlayerStatusStopped 状态,因此在直播场景中,当流停止之后一般做法是使用 IM 服务告知播放器停止播放,以达到即时响应主播断流的目的。)
5
正在播放状态。
6
暂停状态。
7
停止状态 (该状态仅会在回放时播放结束出现,RTMP 直播结束并不会出现此状态)
8
错误状态,播放出现错误时会出现此状态。
9
自动重连的状态
10
播放完成(该状态只针对点播有效)
VideoSizeChanged 回调:仅支持Android
QiniucloudPushView 监听器
StateChanged 状态码: IOS or Android 不一致
状态码
描述
Android
Ios
PREPARING
-
√
√
READY
相机准备就绪
√
√
CONNECTING
连接中
√
√
STREAMING
推流中
√
√
SHUTDOWN
直播中断
√
IOERROR
网络连接失败(连接rtmp推流失败)
√
√
OPEN_CAMERA_FAIL
摄像头打开失败
√
AUDIO_RECORDING_FAIL
麦克风打开失败
√
DISCONNECTED
已经断开连接(直播断开)
√
√
TORCH_INFO
开启闪光灯
√
StreamStatusChanged 状态
IOS 仅包含 audioFps、videoFps、totalAVBitrate 属性
ConferenceStateChanged IOS暂不支持(计划内)
UserJoinConference IOS暂不支持(计划内)
UserLeaveConference IOS暂不支持(计划内)
RecordAudioFailedHandled IOS暂不支持
RestartStreamingHandled IOS暂不支持
PreviewSizeSelected IOS暂不支持
PreviewFpsSelected IOS暂不支持
AudioSourceAvailable IOS暂不支持
使用
使用Demo时请主动更改推流地址和播放地址
组件列表
QiniucloudPushView: 推流组件,通过该窗口Controller实现推流以及回显功能
QiniucloudPlayerView: 播放器组件,通过Controller控制播放等内容
QiniucloudConnectPlayerView:连麦推流预览组件
功能清单
连麦推流视图组件(QiniucloudPushView)
例子
QiniucloudPushView(
cameraStreamingSetting: CameraStreamingSettingEntity(
faceBeauty: faceBeautySettingEntity,
),
streamingProfile: StreamingProfileEntity(
publishUrl: "rtmp://pili-publish.tianshitaiyuan.com/zuqulive/1576400046230A?e=1581756846&token=v740N_w0pHblR7KZMSPHhfdqjxrHEv5e_yBaiq0e:nlza8l7AsBDNkp47AD09ItfZSKA=",
),
onViewCreated: (QiniucloudPushViewController controller) {
controller.resume();
},
)
相关接口:(QiniucloudPushViewController调用方法)
接口
说明
参数
Android
IOS
resume
打开摄像头和麦克风采集
-
√
√
pause
关闭摄像头和麦克风采集
-
√
√
startConference
开始连麦
-
√
stopConference
停止连麦
-
√
√
startStreaming
开始推流
{publishUrl:'推流地址'}
√
√
stopStreaming
停止推流
-
√
√
destroy
销毁
-
√
√
isZoomSupported
查询是否支持缩放(IOS始终返回true)
-
√
√
setZoomValue
设置缩放比例
{value:'比例值'}
√
√
getMaxZoom
获得最大缩放比例
-
√
√
getZoom
获得缩放比例
-
√
√
turnLightOn
开启闪光灯
-
√
√
turnLightOff
关闭闪光灯
-
√
√
switchCamera
切换摄像头
-
√
√
mute
切换静音
{mute:'是否静音',audioSource:'音频源'}
√
√
kickoutUser
根据用户ID踢人
-
√
setConferenceOptions
设置连麦参数
-
√
setStreamingProfile
更新推流参数
-
√
getParticipantsCount
获取参与连麦的人数,不包括自己
-
√
getParticipants
获取参与连麦的用户ID列表,不包括自己
-
√
setPreviewMirror
设置预览镜像
-
√
setEncodingMirror
设置推流镜像
-
√
startPlayback
开启耳返
-
√
stopPlayback
关闭耳返
-
√
updateWatermarkSetting
更新动态水印
-
√
updateFaceBeautySetting
更新美颜设置
-
√
addRemoteWindow
添加远程视图
-
√
getVideoEncodingSize
获取编码器输出的画面的高宽
-
√
setLocalWindowPosition
自定义视频窗口位置(连麦推流模式下有效)
-
√
播放视图组件(QiniucloudPlayerView)
例子
QiniucloudPlayerView(
url: "rtmp://pili-live-rtmp.tianshitaiyuan.com/zuqulive/test",
onViewCreated: (QiniucloudPlayerViewController controller){
controller.setVideoPath(url:"rtmp://pili-live-rtmp.tianshitaiyuan.com/zuqulive/1576400046230A")
},
),
相关接口:(QiniucloudPlayerViewController调用方法)
接口
说明
参数
Android
IOS
setDisplayAspectRatio
设置画面预览模式
{mode:'模式,枚举'}
√
√
start
开始播放
{url:"播放的URL,通过该参数可以做到切换视频",sameSource:"是否是同种格式播放,同格式切换打开更快 @waring 当sameSource 为 YES 时,视频格式与切换前视频格式不同时,会导致视频打开失败【该属性仅IOS有效】"}
√
√
pause
暂停播放
-
√
√
stopPlayback
停止播放
-
√
√
getRtmpVideoTimestamp
在RTMP消息中获取视频时间戳
-
√
√
getRtmpAudioTimestamp
在RTMP消息中获取音频时间戳
-
√
√
setBufferingEnabled
启用/关闭 播放器的预缓冲
{enabled:'是否启用'}
√
getHttpBufferSize
获取已经缓冲的长度
-
√
√
连麦推流预览组件(QiniucloudConnectPlayerView)
例子
QiniucloudConnectPlayerView(
onViewCreated: (viewId, playerController) {
this.playerController = playerController;
controller.addRemoteWindow(id: viewId);
},
)
相关接口:(QiniucloudPlayerViewController调用方法)
接口
说明
参数
Android
IOS
setAbsoluteMixOverlayRect
配置连麦合流的参数(仅主播才配置,连麦观众不用)使用绝对值来配置该窗口在合流画面中的位置和大小
-
√
setRelativeMixOverlayRect
配置连麦合流的参数(仅主播才配置,连麦观众不用)使用相对值来配置该窗口在合流画面中的位置和大小
-
√
php七牛云rtmp直播推流,GitHub - jangocheng/FlutterQiniucloudLivePlugin: Flutter 七牛云直播云 推流/播放 SDK集成...相关推荐
- flutter录音_Flutter直播SDK怎么使用?5步快速开发直播应用
原标题:Flutter直播SDK怎么使用?5步快速开发直播应用 Flutter是谷歌的移动UI框架,它能够在iOS和Android上构建高质量的原生用户界面,并且与现有的代码一起工作.现如今,越来越多 ...
- 【Android RTMP】RTMP 直播推流阶段总结 ( 服务器端搭建 | Android 手机端编码推流 | 电脑端观看直播 | 服务器状态查看 )
文章目录 安卓直播推流专栏博客总结 一. 服务器搭建 二. 手机端推流 三. 电脑端观看直播 四. RTMP 服务器端状态 安卓直播推流专栏博客总结 Android RTMP 直播推流技术专栏 : 0 ...
- 安卓rtmp推流app_直播-腾讯云推流-sdk 播放地址不正确的解决方案---蜻蜓系统-uniapp-flutter通用...
直播-腾讯云推流-sdk 播放地址不正确的解决方案---蜻蜓系统-uniapp-flutter通用 方法文件: /app/Services/LiveService.php 这个问题耽误了时间,有必要记 ...
- React+阿里云Aliplayer播放器实现rtmp直播(推流时间差,重启播放器,计时观看)
需求 前端框架为React 用阿里云播放器Aliplayer播放直播 使用的rtmp协议 资料 阿里云播放器 Web端文档:https://help.aliyun.com/document_detai ...
- github,源码,高仿 直播
仿花田:相亲网站 意中人 已在GitHub上开源 从头开始写一款开源app上线,相互学习 SlideMenuControllerSwift swift实现双侧边栏菜单 StepView github ...
- Android开发-在Android里接入阿里云推流SDK实现直播推流的功能
前 言 如今,在国内移动互联网发展了几年的时间,移动开发技术也相对的成熟,在咱们日常使用的手机App中也少不了直播的功能,不管是娱乐类.游戏类.体育类还是教育类等的App都会有直播的功能,可以说直播的 ...
- Android开发-在Android里接入腾讯云推流SDK实现直播推流的功能
前 言 如今,在国内移动互联网发展了几年的时间,移动开发技术也相对的成熟,在咱们日常使用的手机App中也少不了直播的功能,不管是娱乐类.游戏类.体育类还是教育类等的App都会有直播的功能,可以说直播的 ...
- 直播APP的应用(使用七牛直播平台SDK和环信IM低仿映客)
简介 这是一款低仿映客直播的Android直播聊天应用,本项目通过使用七牛的直播平台提供的sdk进行推流和拉流,使用环信IM来作为用户系统的管理直播聊天室中消息收发.发送礼物.弹幕.私信等功能.本项目 ...
- html5 video 直播流无声音,【报Bug】html5plus 使用 VideoPlayer 播放部分rtmp没有声音
详细问题描述 [内容] 使用 html5plus 使用 VideoPlayer 播放流媒体,播放m3u8格式正常,但rtmp格式部分有问题. 希望官方能确认是否是html5plus自身的缺陷呢,是否对 ...
最新文章
- 漫画:什么是字典序算法
- 小强同学,去当老师吧!
- python有趣小程序-你用python写过那些好玩的微信小程序?
- 从最大似然再看线性回归
- Guava的Optional的操作
- php null空值(转)
- 一篇很好的大牛面试经验
- 联想昭阳E42-80笔记本电脑重装系统记录
- Cholesky 分解,QR分解
- 西门子opc服务器注册,西门子OPC服务器怎么做
- 三方协议服务器不填,毕业生三方协议可以不填么
- Java SE(5)
- Zookeeper安装部署调试命令
- 关于STC单片机的远程升级
- 泛微为什么大量招人_OA市场增长乏力 泛微未来靠什么取胜?
- 升级mysql数据库版本时,对应配置文件的一些变化
- 如何排查CPU占用过高以及常见的几种情况
- java系统类的名称_获取准确的操作系统名称的Java工具类
- 计算机网络技术毕业生实习报告_计算机网络技术实习报告
- 北斗— RDSS RNSS 短报文