更新记录

1.0.2(2023-04-09)

  1. Android增加设为默认接听电话应用功能

1.0.0(2023-03-01)

监听拨打/接听电话/挂断电话,获取来电/去电电话号码,主动接听/挂断电话


平台兼容性

Android Android CPU类型 iOS
适用版本区间:4.4 - 12.0 armeabi-v7a:未测试,arm64-v8a:未测试,x86:未测试 适用版本区间:9 - 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原生插件配置”->”云端插件“列表中删除该插件重新选择


监听拨打/接听电话/挂断电话,接听/挂断电话,设为默认接听电话应用

插件声明


var listentel = uni.requireNativePlugin("wrs-listentel");
  • 监听拨打/接听电话/挂断电话

                listentel.setCallback((resp) => {
                    this.showMsg(JSON.stringify(resp));
                    switch (uni.getSystemInfoSync().platform) {
                        case 'android': {
                            var callState = resp.callState;
                            var msg = "";
                            if (callState) {
                                switch (callState) {
                                    // CALL_STATE_IDLE
                                    case 0:
                                        msg = "监测到挂断电话或空闲状态"
                                        break;
                                    // CALL_STATE_RINGING:监测到电话呼入,来电响铃
                                    case 1:
                                        msg = "监测到电话呼入,来电响铃"
                                        break;
                                        // CALL_STATE_OFFHOOK
                                    case 2:
                                        msg = "监测到接听电话"
                                        break;

                                    default:
                                        break;
                                }
                            }
                            // android.intent.action.NEW_OUTGOING_CALL、android.intent.action.PHONE_STATE
                            var action = resp.action;
                            // 以下这几个号码不一定能获取到
                            // 手机号码
                            var phoneNumber = resp.phoneNumber;
                            // 来电号码
                            var incomingNumber = resp.incomingNumber;
                            // 去电号码
                            var outNumber = resp.outNumber;

                            this.showMsg(msg);
                        }
                        break;
                    case 'ios': {
                        var callState = resp.callState;
                        var callID = resp.callID;
                        if (callState == "CTCallStateDisconnected") {
                            this.showMsg("电话结束或挂断电话");
                        } else if (callState == "CTCallStateConnected") {
                            this.showMsg("电话接通");
                        } else if (callState == "CTCallStateIncoming") {
                            this.showMsg("来电");
                        } else if (callState == "CTCallStateDialing") {
                            this.showMsg("拨号打电话(在应用内调用打电话功能)");
                        }

                    }
                    break;
                    default:
                        break;
                    }
                });
  • 取消监听

listentel.cancelCallback();
  • 获取当前电话状态

                listentel.getCallState((resp) => {
                    this.showMsg(JSON.stringify(resp));
                    switch (uni.getSystemInfoSync().platform) {
                        case 'android': {
                            var callState = resp.callState;
                            var msg = "";
                            switch (callState) {
                                // CALL_STATE_IDLE
                                case 0:
                                    msg = "监测到挂断电话或空闲状态"
                                    break;
                                // CALL_STATE_RINGING:监测到电话呼入,来电响铃
                                case 1:
                                    msg = "监测到电话呼入,来电响铃"
                                    break;
                                    // CALL_STATE_OFFHOOK
                                case 2:
                                    msg = "接听电话"
                                    break;
                                default:
                                    break;
                            }
                            this.showMsg("当前电话状态:" + msg);
                        }
                        break;
                    case 'ios': {
                        var currentCalls = resp.currentCalls;
                        if (currentCalls) {
                            this.showMsg("当前电话状态:当前正在进行" + currentCalls.length + "个通话");
                        } else {
                            this.showMsg("当前电话状态:当前没有通话");
                        }
                    }
                    break;
                    default:
                        break;
                    }
                });
  • 获取当前电话状态

listentel.getCallState((resp) => {
                    this.showMsg(JSON.stringify(resp));
                    switch (uni.getSystemInfoSync().platform) {
                        case 'android': {
                            var callState = resp.callState;
                            var msg = "";
                            switch (callState) {
                                // CALL_STATE_IDLE
                                case 0:
                                    msg = "监测到挂断电话或空闲状态"
                                    break;
                                // CALL_STATE_RINGING:监测到电话呼入,来电响铃
                                case 1:
                                    msg = "监测到电话呼入,来电响铃"
                                    break;
                                    // CALL_STATE_OFFHOOK
                                case 2:
                                    msg = "接听电话"
                                    break;
                                default:
                                    break;
                            }
                            this.showMsg("当前电话状态:" + msg);
                        }
                        break;
                    case 'ios': {
                        var currentCalls = resp.currentCalls;
                        if (currentCalls) {
                            this.showMsg("当前电话状态:当前正在进行" + currentCalls.length + "个通话");
                        } else {
                            this.showMsg("当前电话状态:当前没有通话");
                        }
                    }
                    break;
                    default:
                        break;
                    }
                });
  • 接听电话,仅支持Android

listentel.answerCall()

或

listentel.answerRingingCall();
  • 挂断电话,仅支持Android

listentel.endCall();

或

listentel.endRingingCall();
  • 设为默认接听电话应用(仅支持Android),常用来自定义通话界面功能

                listentel.setAppDefaultDialert((resp) => {
                    var code = resp.code;
                    if (code == 0) {
                        var resultCode = resp.resultCode;
                        if (resultCode == -1) {
                            this.showMsg("已设为默认电话应用");
                        } else {
                            this.showMsg("设为默认电话应用失败");
                        }
                    } else if (code == 1) {
                        this.showMsg("跳到电话设置界面去设置");
                    } else if (code == 2) {
                        this.showMsg("Android 6.0以上才支持修改默认电话应用!");
                    }
                });
  • 监听电话通信状态(仅支持Android)

listentel.setInCallServiceCallBack((resp) => {
                    this.showMsg(JSON.stringify(resp));
                    var opt = resp.opt;
                    var call = resp.call;
                    if (opt == "onCallAdded") {
                        var state = call.state;
                        var details = call.details;
                        var phoneNumber = details.phoneNumber;
                        if (state == 2) { // STATE_RINGING 有来电
                            this.showMsg("来电:" + phoneNumber);
                        } else if (state == 9) { //STATE_CONNECTING 拨打电话
                            this.showMsg("去电:" + phoneNumber);
                        }
                    } else if (opt == "onStateChanged") {
                        var state = resp.state;
                        if (state == 4) { // STATE_ACTIVE
                            this.showMsg("通话中");
                        } else if (state == 7) { //STATE_DISCONNECTED
                            this.showMsg("通话结束");
                        }
                    }
                });
  • 打开免提(仅支持Android)

// 貌似某些系统不生效
listentel.openSpeaker();
  • 关闭免提(仅支持Android)

// 貌似某些系统不生效
listentel.closeSpeaker();

支持定制,联系方式 QQ:252797991

如果觉得可以就点个👍吧,欢迎粉丝收藏,土豪打赏,您的关注就是我们创作的动力!

隐私、权限声明

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

android: <!-- 监听呼出电话 --> <uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS" /> <!-- 监听来电 --> <uses-permission android:name="android.permission.READ_PHONE_STATE" /> <!-- 拨打电话 --> <uses-permission android:name="android.permission.CALL_PHONE" /> <uses-permission android:name="android.permission.ANSWER_PHONE_CALLS" /> <uses-permission android:name="android.permission.CALL_PHONE" /> <uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" /> <uses-permission android:name="android.permission.READ_CALL_LOG" /> ios: 无

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

插件不采集任何数据

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

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