更新记录

1.0.0(2023-05-12)

新版首发


平台兼容性

Android iOS
× 适用版本区间:11 - 16

原生插件通用使用流程:

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


KJ-Interruption

监听中断、录音或播放音频、被系统占用而中断(ios)

使用

<template>
    <view class="content">
        <button type="primary" @click="onInterruption">监听录音或播放音频被中断</button>
        <view class="json">{{json}}</view>
        <button type="primary" @click="removeInterruption">移除监听</button>

        <view class="text">----以下是官方api----</view>
        <button type="primary" @click="playAudio">播放音频</button>
        <button type="primary" @click="startRecord">开始录音</button>
        <button type="primary" @click="endRecord">停止录音</button>
    </view>
</template>

<script>
    const KJInterruption = uni.requireNativePlugin('KJ-Interruption');
    const recorderManager = uni.getRecorderManager();
    export default {
        data() {
            return {
                json: ''
            }
        },
        onLoad() {
            this.onInterruption();
        },
        methods: {
            onInterruption() {
                //系统占用而被中断。以下场景会触发此事件:微信语音聊天、微信视频聊天、QQ语音聊天、QQ视频聊天、电话响铃、接听电话、其它应用播放音频等等
                KJInterruption.onInterruption((res) => {
                    console.log("onInterruption:" + JSON.stringify(res));
                    this.json = JSON.stringify(res);
                    /**
                     * 返回json说明:onInterruption:{"result":"begin"}
                     * result - 中断类型 begin(开始中断) end(中断结束)
                     * */
                })
            },
            removeInterruption() {
                KJInterruption.removeInterruption()
            },
            playAudio() {
                const bgAudioManager = uni.getBackgroundAudioManager();
                bgAudioManager.title = '致爱丽丝';
                bgAudioManager.singer = '暂无';
                bgAudioManager.coverImgUrl = 'https://web-assets.dcloud.net.cn/unidoc/zh/music-a.png';
                bgAudioManager.src =
                    'https://bjetxgzv.cdn.bspapp.com/VKCEYUGU-hello-uniapp/2cc220e0-c27a-11ea-9dfb-6da8e309e0d8.mp3';
            },
            startRecord() {
                recorderManager.onStop(function(res) {
                    console.log('recorder stop' + JSON.stringify(res));
                    const bgAudioManager = uni.getBackgroundAudioManager();
                    bgAudioManager.src = res.tempFilePath;
                });
                recorderManager.start();
            },
            endRecord() {
                recorderManager.stop();
            }
        }
    }
</script>
<style>
    .text {
        text-align: center;
    }
</style>

隐私、权限声明

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

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

插件不采集任何数据

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

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