更新记录

0.0.3(2024-06-24)

优化插件对RTSP流视频的支持

0.0.2(2024-05-31)

插件信息更新


平台兼容性

Android iOS
× 适用版本区间:13 - 17

原生插件通用使用流程:

  1. 购买插件,选择该插件绑定的项目。
  2. 在HBuilderX里找到项目,在manifest的app原生插件配置中勾选模块,如需要填写参数则参考插件作者的文档添加。
  3. 根据插件作者的提供的文档开发代码,在代码中引用插件,调用插件功能。
  4. 打包自定义基座,选择插件,得到自定义基座,然后运行时选择自定义基座,进行log输出测试。
  5. 开发完毕后正式云打包

付费原生插件目前不支持离线打包。
Android 离线打包原生插件另见文档 https://nativesupport.dcloud.net.cn/NativePlugin/offline_package/android
iOS 离线打包原生插件另见文档 https://nativesupport.dcloud.net.cn/NativePlugin/offline_package/ios

注意事项:使用HBuilderX2.7.14以下版本,如果同一插件且同一appid下购买并绑定了多个包名,提交云打包界面提示包名绑定不一致时,需要在HBuilderX项目中manifest.json->“App原生插件配置”->”云端插件“列表中删除该插件重新选择


插件使用注意事项

1、由于基于IJKMediaFramework实现,引用插件务必先 试用再付费,特此说明!
2、插件已封装了EasyPlayer所依赖的视频框架IJKMediaFramework基础功能,目前支持HTTP/RTSP/RTMP/HLS等多种流媒体协议;http://xxx、rtsp://xxx、rtmp://xxx、hls://xxx
3、插件中用到IJKMediaFramework框架,使用该插件请避免重复导入IJKMediaFramework以防冲突无法编译成功!
4、目前视频插件只支持iOS系统13.0以上
5、使用过程如有需要增加接口、特殊版本兼容等问题,请联系我WX:YoungLNN,或者留言
6、接口使用说明见最下面 “API列表说明”

代码示例

{ console.log('处理后----\n' + res + '\n-------'); this.playButtonTitle = "播放"; }); this.$refs.DYNativeToolsEasyPlayerPlugin.startObserverPlaybackCompleteStateCallBack(res => { console.log('处理后----\n' + res + '\n-------'); this.playButtonTitle = "播放"; }); }, playAction() { if (this.playButtonTitle == "播放") { this.playButtonTitle = "暂停"; this.$refs.DYNativeToolsEasyPlayerPlugin.playAction(); } else { this.playButtonTitle = "播放"; this.$refs.DYNativeToolsEasyPlayerPlugin.pauseAction(); } }, nextAction() { this.$refs.DYNativeToolsEasyPlayerPlugin.thumbnailImageAtCurrentTimeCallback(res => { this.imageBase64 = 'data:image/jpeg;base64,' + res; console.log('处理后----\n' + this.imageBase64 + '\n-------'); }); }, forwardAction() { this.$refs.DYNativeToolsEasyPlayerPlugin.setForwardValue(5); }, videoScalingMode() { this.scalingMode = this.scalingMode + 1; if (this.scalingMode > 3) { this.scalingMode = 0; } switch (this.scalingMode) { case 0: this.scalingModeStr = "None"; break; case 1: this.scalingModeStr = "AspectFit"; break; case 2: this.scalingModeStr = "AspectFill"; break; case 3: this.scalingModeStr = "Fill"; break; default: break; } this.$refs.DYNativeToolsEasyPlayerPlugin.setScalingMode(this.scalingMode); } } }

API列表说明

1、播放指定连接视频
//参数1:视频地址URL 支持HTTP/RTSP/RTMP/HLS等多种流媒体协议;http://xxx、rtsp://xxx、rtmp://xxx、hls://xxx
//参数2:设置rtsp_transport类型 TCP/UDP;默认或者不填写时为"TCP"、"UDP"
//参数3:设置是否自动播放; 0 不自动播放 1自动播放
prepareToPlayWithVideoUrl()
代码示例:
this.$refs.DYNativeToolsEasyPlayerPlugin.prepareToPlayWithVideoUrl("rtmp://xxx", "tcp", 0);

2、视频播放
playAction()

3、视频暂停
pauseAction()

4、停止播放
stopAction()

5、是否正在播放
isPlayingCallback:(ret=>{})

6、获取当前播放帧图片,返回值为base64图片,无需转换可直接作为资源赋值给<img />
thumbnailImageAtCurrentTimeCallback:(ret=>{})

7、指定播放位置
setCurrentPlaybackTime(5)

8、设置显示模式
setScalingMode(0)

9、快退 参数可任意指定:1~max
setForwardValue(5)

10、快进 参数可任意指定:1~max
setNextValue(5)

11、监听视频加载状态 
************************************************************************************************************************************
列举:
IJKMPMovieLoadStateUnknown        = 0,
IJKMPMovieLoadStatePlayable       = 1 << 0,
IJKMPMovieLoadStatePlaythroughOK  = 1 << 1, // Playback will be automatically started in this state when shouldAutoplay is YES
IJKMPMovieLoadStateStalled        = 1 << 2, // Playback will be automatically paused in this state, if started
************************************************************************************************************************************
startObserverLoadStateCallBack(ret=>{})

12、监听视频结束状态
************************************************************************************************************************************
列举:
IJKMPMovieFinishReasonPlaybackEnded,
IJKMPMovieFinishReasonPlaybackError,
IJKMPMovieFinishReasonUserExited
************************************************************************************************************************************
startObserverPlaybackCompleteStateCallBack(ret=>{})

隐私、权限声明

1. 本插件需要申请的系统权限列表:

2. 本插件采集的数据、发送的服务器地址、以及数据用途说明:

插件不采集任何数据

3. 本插件是否包含广告,如包含需详细说明广告表达方式、展示频率:

暂无用户评论。

使用中有什么不明白的地方,就向插件作者提问吧~ 我要提问