更新记录

1.0.6(2022-02-14) 下载此版本

1、可通过接口输入授权码激活 2、增加设置人脸识别速度参数

1.0.5(2022-01-14) 下载此版本

修改特定场景下识别超时bug

1.0.4(2022-01-12) 下载此版本

增加静默检测人脸接口

查看更多

平台兼容性

Android Android CPU类型 iOS
适用版本区间:7.0 - 11.0 armeabi-v7a:支持,arm64-v8a:未测试,x86:未测试 ×

原生插件通用使用流程:

  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

1、插件说明 此插件基于百度官方提供的离线人脸识别demo改造。

2、使用步骤

1)购买百度人脸识别SDK授权码

2)首次启动插件时需要填写授权进行注册

3、代码示例

<template>
    <view>
        <view class="uni-padding-wrap uni-common-mt">
            <button type="primary" @click="testMethod">交互测试</button>
            <button type="primary" @click="baiduSDKAppPage">人脸SDK原始页面</button>
            <button type="primary" @click="initSDKConfig">初始化SDK配置</button>             
            <button type="primary" @click="faceDetectPage">人脸识别页面</button>
            <button type="primary" @click="faceCollectPage">人脸采集页面</button>
            <button type="primary" @click="relativeManagerPage">本地人脸库页面</button>    
            <image :src="`data:image/jpeg;base64,${detectBase64Image}`" mode="aspectFit" style="width: 400rpx;height: 400rpx;"></image>
            <image :src="`data:image/jpeg;base64,${userBase64Image}`" mode="aspectFit" style="width: 400rpx;height: 400rpx;"></image>
        </view>

    </view>

</template>
<script>
// 获取 module
const faceDetectSdk = uni.requireNativePlugin('baidu-face-detect-plugin');
const modal = uni.requireNativePlugin('modal');
export default {

    data() {
        return {
            detectBase64Image:'',
            userBase64Image:''
        }
    },
    onLoad() {
        //监听数据更新进度信息
        var globalEvent = uni.requireNativePlugin('globalEvent');
        globalEvent.addEventListener('faceApiEvent', function(result) {
            modal.toast({
                message: result.status,
                duration: 3
            });
        });
    },
    onShow() {

    },
    methods: {

        //测试方法
        testMethod(){
            faceDetectSdk.testMethod({
                    'mac': '1111111',
                    'template': 'bbbbbbbbb'
                },
                (ret) => {
                    modal.toast({
                        message: ret,
                        duration: 3
                    });
                })
        },
        //进入百度sdk原生页面
        baiduSDKAppPage(){
            faceDetectSdk.baiduSDKAppPage({"test":0})
        },
        //人脸检测页面,timeoutSeconds 参数表示30秒检测不到人脸信息就自动退出
        faceDetectPage(){
            faceDetectSdk.faceDetectPage({"timeoutSeconds":30},
                (ret) => {
                    /**
                     * ret 结果说明
                     * success true  正常返回
                     * status     failed 人脸识别识别。识别到人了,但是未识别到人员信息    success 识别到人员信息   timout 识别超时
                     * detectBase64Image  当前检测的图片
                     * userBase64Image    识别到的人员头像   (status 为success时会返回)
                     * userId             识别到的人员ID    (status 为success时会返回)
                     * userName           识别到的人员名称   (status 为success时会返回)
                     * 
                     * 
                     */

                    if(ret.success){
                        if(ret.status === "success"){
                            this.detectBase64Image = ret.detectBase64Image;
                            this.userBase64Image = ret.userBase64Image;
                        }else if(ret.status === "failed"){
                            this.userBase64Image = '';
                            this.detectBase64Image = ret.detectBase64Image;
                        }else{
                            this.userBase64Image = '';
                            this.detectBase64Image = '';
                        }

                        modal.toast({
                            message: ret.status + " " + ret.msg + " " + ret.userName,
                            duration: 3
                        });
                    }else{
                        modal.toast({
                            message: ret.msg,
                            duration: 3
                        });
                    }

                })
        },      
        //人脸采集页面
        faceCollectPage(){
            faceDetectSdk.faceCollectPage({"test":"1"},
                (ret) => {
                    if(ret.success){

                        /**
                         * ret 结果说明
                         * success true  正常返回
                         * status     failed 未采集到人脸    success 采集到人脸
                         * detectBase64Image  当前检测的图片
                         * userBase64Image    人脸抠图
                         * 
                         * 
                         */
                        if(ret.status === "success"){
                            this.detectBase64Image = ret.detectBase64Image;
                            this.userBase64Image = ret.userBase64Image;
                        }else if(ret.status === "failed"){
                            this.userBase64Image = '';
                            this.detectBase64Image = '';
                        }

                        modal.toast({
                            message: ret.status + " " + ret.msg,
                            duration: 3
                        });
                    }else{
                        modal.toast({
                            message: ret.msg,
                            duration: 3
                        });
                    }
                })
        },  
        //进入本地人脸库
        relativeManagerPage(){
            faceDetectSdk.relativeManagerPage({"test":0},
                (ret) => {
                    modal.toast({
                        message: ret.msg,
                        duration: 3
                    });
                })
        },      
        //初始化SDK
        initSDKConfig(){
            faceDetectSdk.initSDKConfig({"test":0},
                (ret) => {
                    modal.toast({
                        message: ret.msg,
                        duration: 3
                    });
                })
        },              
        //查询本地库的人脸信息
        queryUser(){
            faceDetectSdk.queryUser({"userId":"1234567812345678"},
                (ret) => {
                    //ret信息  success true/false   当为true时 返回userId, userName, userBase64Image
                    modal.toast({
                        message: ret.msg,
                        duration: 3
                    });
                })
        },              
        //删除本地库的人脸信息
        deleteUser(){
            faceDetectSdk.deleteUser({"userIds":"1234567812345678,23456789345678"},
                (ret) => {
                    //ret信息  success true/false
                    modal.toast({
                        message: ret.msg,
                        duration: 3
                    });
                })
        },      
        //注册本地库的人脸信息
        registerUser(){
            faceDetectSdk.registerUser({"userId":"1234567812345678","userName": "张三", "featuresStr": "这里填人脸采集返回的人脸特征值", "userBase64Image": "这里填人脸采集返回的人脸抠图"},
                (ret) => {
                    //ret信息  success true/false
                    modal.toast({
                        message: ret.msg,
                        duration: 3
                    });
                })
        },      
    }
};
</script>
<style>
.label-r{
    display: flex;
    flex-direction: row;
}   

.v-group{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
}   
.empty-30{
    width: 30rpx;
}
</style>

隐私、权限声明

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

1、相机权限 2、网络权限

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

插件使用的百度人脸识别SDK采集数据,详情可参考:https://ai.baidu.com/ai-doc/FACE/pk37c1mqu

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

许可协议

作者未提供license.md

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