更新记录

1.0(2020-06-30)

1 原生乐橙云SDK 2 支持ios和android 两端 3 功能包括:直播播放/关闭 声音播放/关闭 语音对讲等功能


平台兼容性

Android iOS

原生插件通用使用流程:

  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原生插件配置”->”云端插件“列表中删除该插件重新选择


乐橙云SDK插件说明

插件支持范围

ios + android

插件如何使用

参考Dcloud官方说明

插件的能力说明
  1. 插件提供播放组件
  2. 插件不提供UI实现(可以根据自身情况,设计操作按钮,UI方案可参考乐橙云官方APP)
  3. 插件提供接口有:
    • [x] 直播播放/停止
    • [x] 声音播放/停止
    • [x] 语音对讲开启/结束
    • [x] 本地录像播放/停止
插件接口说明

请下载示例项目ZIP,参考nvue界面代码。

<template>
    <view>
        <lc_video_view ref="videoView" style="width:100%;height: 250px;"></lc_video_view>
        <button type="primary" @click="onClickPlay()">实时播放</button>
        <button type="primary" @click="onClickStop()">停止播放</button>
        <button type="primary" @click="onClickPlaySound()">开启声音</button>
        <button type="primary" @click="onClickStopSound()">关闭声音</button>
        <button type="primary" @click="onClickStartTalk()">开始对讲</button>
        <button type="primary" @click="onClickStopTalk()">停止对讲</button>
    </view>
</template>

<script>
    var sdkwx = uni.requireNativePlugin('LeChange-SdkWX');
    var talksdkwx = uni.requireNativePlugin('LeChange-Talk');

    export default {
        data() {
            return {
                deviceId: '',//设备ID
                channelId: '',//通道ID
                token:'',// 参考乐橙云官方文档(https://open.imoulife.com/developDoc/5#accessToken)
            }
        },
        onLoad(e) {
            //这里来设置设备ID,通道ID,以及token等参数
            console.log("【Method】: onLoad");
            //设置乐橙API地址
            sdkwx.setHost("openapi.lechange.cn", 443);
            //对讲事件回调
            let _this = this;
            talksdkwx.setListener(function(res){
                console.log(JSON.stringify(res));
            });
        },
        mounted(){
            console.log("【Method】: mounted");
            var videoView = this.$refs.videoView;
            //初始化窗口
            var index = 1;//窗口标示保持唯一
            videoView.initPlayWindow(index);
            //窗口监听事件
            videoView.setWindowListener(function(res){
                console.log(res);
            }); 
            //开启手势监听
            //videoView.openTouchListener();
        },
        methods: {
            onClickPlay() {
                console.log("onClickPlay");
                //实时播放
                var videoView = this.$refs.videoView;
                var encryptKey = this.deviceId; //加密key,这里设置为了deviceId
                var bateMode = 1;//0高清 1标清
                var isOpt = true;
                videoView.playRtspReal(this.token, this.deviceId, encryptKey, this.channelId, 1, isOpt);
            },
            onClickStop() {
                //停止实时播放
                var videoView = this.$refs.videoView;
                videoView.stopRtspReal();
            },
            onClickPlaySound() {
                console.log("【Method】:onClickPlaySound");
                //开启声音
                var videoView = this.$refs.videoView;
                videoView.playAudio();
            },
            onClickStopSound() {
                console.log("【Method】:onClickStopSound");
                //关闭声音
                var videoView = this.$refs.videoView;
                videoView.stopAudio();
            },
            onClickStartTalk(){
                //开始对讲(安卓手机需要申请麦克风权限,或者手动打开麦克风权限)
                console.log("【Method】:onClickStartTalk");
                talksdkwx.playTalk(this.token, this.deviceId);
            },
            onClickStopTalk() {
                console.log("【Method】:onClickStopTalk");
                //停止对讲
                talksdkwx.stopTalk();
                this.talkStatus = false;
            },
            DeiveRecord(){
                //播放历史记录
                console.log("【Method】:DeiveRecord");
                var videoView = this.$refs.videoView;
                var encryptKey = this.deviceId;
                videoView.playRtspPlayback(this.token,this.deviceId,this.channelId,encryptKey,"/mnt/sd/2020-06-05/001/dav/00/00.00.00-00.02.45[M][0@0][0].dav","1591286400","1591286565",0);
            },
            DeiveRecord(){
                //停止播放历史记录
                var videoView = this.$refs.videoView;
                videoView.stopRtspPlayback();
            },

        }
    }
</script>

<style>
</style>

隐私、权限声明

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

语音对讲 需要 麦克风 权限

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

插件不采集任何数据

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

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