自学记录鸿蒙API 13:实现人脸比对Core Vision Face Comparator

news2025/2/5 2:53:41

完成了文本识别和人脸检测的项目后,我发现人脸比对是一个更有趣的一个小技术玩意儿。我决定整一整,也就是对HarmonyOS Next最新版本API 13中的Core Vision Face Comparator API的学习,这项技术能够对人脸进行高精度比对,并给出相似度评分,判断是否为同一人。于是,我决定基于这个API开发一个简单的人脸比对小工具。


开始我的开发之旅

应用场景的思考

学习之前,我花了一些时间思考人脸比对技术的实际应用场景,例如:

  • 照片分类管理:基于相似度对图库中的照片进行智能分类,方便用户快速整理。
  • 身份认证:在人脸识别基础上,进一步验证是否为同一人。
  • 个性化服务:识别用户身份后,推荐个性化内容。
  • 社交互动:通过比对相似度寻找“脸型相近”的朋友,促进社交联系。
  • 家庭管理:比如家长在家庭监控中,快速识别视频中是否为家庭成员。

有了这些场景的启发,我更坚定了学习这项技术的决心。


第一步:理解Face Comparator API的核心功能

核心功能

Face Comparator API 提供了以下核心功能:

  • 高精度人脸比对:输入两张图片,分析其中的人脸,给出是否为同一人的判断。
  • 相似度评分:提供0到1的相似度评分,帮助开发者精确控制比对结果。
  • 高性能端侧计算:比对算法在设备端执行,无需上传到云端,确保用户隐私。
  • 便捷扩展性:支持与其他视觉服务如人脸检测、活体检测的无缝集成。

应用场景

人脸比对的应用场景非常广泛,包括但不限于:

  • 安全场景:如支付验证、门禁识别。
  • 社交平台:为用户推荐相似的照片或好友。
  • 相册管理:快速整理相似人像照片。
  • 证件核验:比如在远程认证场景中比对身份证照片与自拍照片。

第二步:项目初始化与配置

初始化与权限配置

在使用Face Comparator API前,我们需要确保项目的权限配置正确:

{
  "module": {
    "abilities": [
      {
        "name": "FaceComparatorAbility",
        "permissions": [
          "ohos.permission.INTERNET",
          "ohos.permission.READ_MEDIA",
          "ohos.permission.WRITE_MEDIA"
        ]
      }
    ]
  }
}

以上权限确保应用可以访问图库和网络资源。

在配置完成后,我会继续检查日志以确认权限被正确调用,确保服务能够初始化。


第三步:实现人脸比对功能

初始化Face Comparator服务

初始化服务是开发的第一步,以下代码展示了如何实现服务的初始化与释放:

import faceComparator from '@kit.CoreVisionKit';

async function initializeFaceComparator() {
    try {
        const isInitialized = await faceComparator.init();
        if (isInitialized) {
            console.info('人脸比对服务初始化成功');
        } else {
            console.error('人脸比对服务初始化失败');
        }
    } catch (error) {
        console.error('初始化过程中发生错误:', error);
    }
}

async function releaseFaceComparator() {
    try {
        await faceComparator.release();
        console.info('人脸比对服务已释放');
    } catch (error) {
        console.error('释放过程中发生错误:', error);
    }
}

initializeFaceComparator();

这一过程非常关键,因为初始化成功与否直接决定了后续比对操作的可靠性。服务的释放同样重要,可以避免资源浪费。

加载图片并比对人脸

人脸比对需要两张包含人脸的图片,以下代码展示了如何从图库加载图片并调用比对功能:

async function compareFaces(imageUri1: string, imageUri2: string) {
    try {
        const pixelMap1 = await loadPixelMap(imageUri1);
        const pixelMap2 = await loadPixelMap(imageUri2);

        const visionInfo1 = { pixelMap: pixelMap1 };
        const visionInfo2 = { pixelMap: pixelMap2 };

        const result = await faceComparator.compareFaces(visionInfo1, visionInfo2);
        console.info(`是否为同一人: ${result.isSamePerson}`);
        console.info(`相似度: ${(result.similarity * 100).toFixed(2)}%`);

        // 清理资源
        pixelMap1.release();
        pixelMap2.release();
    } catch (error) {
        console.error('人脸比对失败:', error);
    }
}

async function loadPixelMap(imageUri: string) {
    // 假设有工具库可以加载图像
    return await someImageLibrary.loadPixelMap(imageUri);
}

关于加载图像可以看我之前的文章~,或者查一下API,本身并不难。

错误处理

在开发过程中,遇到的常见错误包括:

  • 图片中缺少人脸
  • 图片格式不支持
  • 比对超时

这些问题可以通过增强日志和用户提示来解决。例如,提供清晰的错误信息并指导用户上传合适的图片。


第四步:构建用户界面

以下代码展示了一个简单的人脸比对应用界面,支持图片选择与结果展示:

import { View, Text, Button, Image } from '@ohos.arkui';

export default View.create({
    build() {
        return (
            {
                type: "flex",
                flexDirection: "column",
                children: [
                    {
                        type: Text,
                        content: "人脸比对应用",
                        style: { height: "50vp", fontSize: "20vp", textAlign: "center" },
                    },
                    {
                        type: Button,
                        content: "选择图片1",
                        style: { height: "50vp", marginTop: "20vp" },
                        onClick: this.onSelectImage1,
                    },
                    {
                        type: Button,
                        content: "选择图片2",
                        style: { height: "50vp", marginTop: "10vp" },
                        onClick: this.onSelectImage2,
                    },
                    {
                        type: Button,
                        content: "开始比对",
                        style: { height: "50vp", marginTop: "10vp" },
                        onClick: this.onCompareFaces,
                    },
                ],
            }
        );
    },

    onSelectImage1() {
        // 模拟选择图片1
        this.imageUri1 = '/data/media/sample_image1.jpg';
        console.info('图片1已选择:', this.imageUri1);
    },

    onSelectImage2() {
        // 模拟选择图片2
        this.imageUri2 = '/data/media/sample_image2.jpg';
        console.info('图片2已选择:', this.imageUri2);
    },

    async onCompareFaces() {
        try {
            const pixelMap1 = await loadPixelMap(this.imageUri1);
            const pixelMap2 = await loadPixelMap(this.imageUri2);

            const visionInfo1 = { pixelMap: pixelMap1 };
            const visionInfo2 = { pixelMap: pixelMap2 };

            const result = await faceComparator.compareFaces(visionInfo1, visionInfo2);
            console.info(`是否为同一人: ${result.isSamePerson}`);
            console.info(`相似度: ${(result.similarity * 100).toFixed(2)}%`);

            // 清理资源
            pixelMap1.release();
            pixelMap2.release();
        } catch (error) {
            console.error('人脸比对失败:', error);
        }
    },
});

第五步:性能优化与功能扩展

性能优化

通过调整参数可以优化比对性能,例如限制图片分辨率,减少不必要的计算。

const configuration = { enableHighPrecision: false };
const result = await faceComparator.compareFaces(visionInfo1, visionInfo2, configuration);

在实际应用中,我还建议对图片进行预处理,例如裁剪人脸区域或调整图片大小,以进一步提高比对效率。

功能扩展

  • 实时比对:结合相机模块,实时分析两张图片是否为同一人。
  • 结果可视化:在界面上展示比对结果和置信度。
  • 批量比对:支持一次比对多张照片,快速分类图库。
  • 增强互动性:结合语音助手实现语音指令触发比对功能。
  • 隐私保护:在比对结果中对敏感信息进行模糊处理,确保数据安全。

最后的小总结

整完了这个API,我发现还真是挺有意思的。毕竟目前这个算是比较新的AI API,可以去做很多新鲜的事,当然这不仅是一项技术创新,更是一种赋能开发者的方式,让我们能够轻松构建智能化、人性化的应用。

未来,我计划将这一技术融入更复杂的场景,如照片管理和个性化服务。此外,还可以探索如何将人脸比对与其他AI能力结合,开发更加智能的综合解决方案。如果你也对人脸比对感兴趣,不妨从简单的比对功能开始,逐步实现自己的创意!

当然如果你也在这一领域研究,不妨关注我,我们一起进步~!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2268028.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

代码解析:安卓VHAL的AIDL参考实现

以下内容基于安卓14的VHAL代码。 总体架构 参考实现采用双层架构。上层是 DefaultVehicleHal,实现了 VHAL AIDL 接口,并提供适用于所有硬件设备的通用 VHAL 逻辑。下层是 FakeVehicleHardware,实现了 IVehicleHardware 接口。此类可模拟与实…

通过 Ansys Electronics Desktop 中的高级仿真优化 IC 设计

半导体行业继续通过日益复杂的集成电路 (IC) 设计突破技术界限。随着工艺节点缩小和电路密度达到前所未有的水平,电磁效应对设备性能和可靠性变得越来越重要。现代 IC 设计面临着来自复杂的布局相关耦合机制、信号完整性问题和功率分布问题的挑战,这些问…

Kafka数据迁移全解析:同集群和跨集群

文章目录 一、同集群迁移二、跨集群迁移 Kafka两种迁移场景,分别是同集群数据迁移、跨集群数据迁移。 一、同集群迁移 应用场景: broker 迁移 主要使用的场景是broker 上线,下线,或者扩容等.基于同一套zookeeper的操作。 实践: 将需要新添加…

【OpenGL ES】GLSL基础语法

1 前言 本文将介绍 GLSL 中数据类型、数组、结构体、宏、运算符、向量运算、矩阵运算、函数、流程控制、精度限定符、变量限定符(in、out、inout)、函数参数限定符等内容,另外提供了一个 include 工具,方便多文件管理 glsl 代码&a…

ffmpeg之播放一个yuv视频

播放YUV视频的步骤 初始化SDL库: 目的:确保SDL库正确初始化,以便可以使用其窗口、渲染和事件处理功能。操作:调用 SDL_Init(SDL_INIT_VIDEO) 来初始化SDL的视频子系统。 创建窗口用于显示YUV视频: 目的:…

复习打卡大数据篇——Hadoop MapReduce

目录 1. MapReduce基本介绍 2. MapReduce原理 1. MapReduce基本介绍 什么是MapReduce MapReduce是一个分布式运算程序的编程框架,核心功能是将用户编写的业务逻辑代码和自带默认组件整合成一个完整的分布式运算程序,并发运行在Hadoop集群上。 MapRed…

小程序配置文件 —— 13 全局配置 - window配置

全局配置 - window配置 这里讲解根目录 app.json 中的 window 字段,window 字段用于设置小程序的状态栏、导航条、标题、窗口背景色; 状态栏:顶部位置,有网络信号、时间信息、电池信息等;导航条:有一个当…

el-pagination 为什么只能展示 10 条数据(element-ui@2.15.13)

好的&#xff0c;我来帮你分析前端为什么只能展示 10 条数据&#xff0c;以及如何解决这个问题。 问题分析&#xff1a; pageSize 的值&#xff1a; 你的 el-pagination 组件中&#xff0c;pageSize 的值被设置为 10&#xff1a;<el-pagination:current-page"current…

单片机与MQTT协议

MQTT 协议简述 MQTT&#xff08;Message Queuing Telemetry Transport&#xff0c;消息队列遥测传输协议&#xff09;&#xff0c;是一种基于发布 / 订阅&#xff08;publish/subscribe&#xff09;模式的 “轻量级” 通讯协议&#xff0c;该协议构建于 TCP/IP 协议上&#xf…

Debian-linux运维-docker安装和配置

腾讯云搭建docker官方文档&#xff1a;https://cloud.tencent.com/document/product/213/46000 阿里云安装Docker官方文档&#xff1a;https://help.aliyun.com/zh/ecs/use-cases/install-and-use-docker-on-a-linux-ecs-instance 天翼云常见docker源配置指导&#xff1a;htt…

使用Docker-compose部署SpringCloud项目

docker编写dockfile遇到的问题&#xff1a; 需要在docker-compose.yml文件下执行命令 docker-compose.yml文件格式的问题 1和2处空2格&#xff0c;3处空1格&#xff0c;4为本地配置文件目录&#xff0c;5为docker容器的目录&#xff0c;version为自己安装的docker-compose版本 …

KG4Diagnosis 分层多代理的医疗诊断框架,结合大模型与知识图谱构建,覆盖362种常见疾病

KG4Diagnosis 分层多代理的医疗诊断框架&#xff0c;结合大模型与知识图谱构建&#xff0c;覆盖362种常见疾病 论文大纲理解1. 提出背景是什么&#xff1f;2. 概念的性质是什么&#xff1f;是什么导致这个性质&#xff1f;3. 请举一个正例、一个反例&#xff0c;对比4. 请使用类…

【LLM综述】29种大模型Prompt Engineering技术

note 从零样本&#xff08;Zero-shot&#xff09;提示到最新进展的各种提示技术&#xff0c;包括推理和逻辑链&#xff08;Chain-of-Thought, CoT&#xff09;提示、自动链式思考&#xff08;Auto-CoT&#xff09;提示、自我一致性&#xff08;Self-Consistency&#xff09;提…

【黑马头条训练营】day02-黑马头条-App端文章展示

目录 描述app端首页从请求到数据显示的全部流程 描述文章微服务的组成及首页展示业务与实现 自己编写文章微服务关键逻辑 描述app端首页从请求到数据显示的全部流程 浏览器请求我们的app端 会通过nginx请求到我们app前端 app端输入手机号和密码 点击登录 请求 会到我们的…

DBeaver 咋手动配置sqlite 驱动

目录 1 问题2 下载 1 问题 离线安装了DBeaver 数据库软件&#xff0c;现在需要使用这个数据库打开sqlite 数据库&#xff0c;但是提示没有 驱动&#xff0c;那么我们就需要手动下载驱动&#xff0c;在这个软件里面导入 2 下载 https://repo1.maven.org/maven2/org/xerial/sql…

Linux 的历史与发展:从诞生到未来

Linux 的历史与发展&#xff1a;从诞生到未来 1. 起源之前&#xff1a;操作系统的历史背景 在 Linux 问世之前&#xff0c;操作系统的发展经历了多个重要阶段&#xff0c;这些阶段为 Linux 的诞生奠定了基础&#xff1a; 1940-1950 年代&#xff1a;计算机初期 早期计算机如 [[…

八爪鱼easyspider:

参考我的上一篇博客&#xff1a; scraper插件与软件&#xff0c; 主八爪鱼&#xff0c;easyspider 1&#xff0c;八爪鱼&#xff1a; 同时注意数据横向还是纵向&#xff0c;但是不好操作 二&#xff0c;easyspider&#xff1a; 其中1/2是不需要用户登入的&#xff0c;第3个…

算法基础一:冒泡排序

一、冒泡排序 1、定义 冒泡排序&#xff08;英语&#xff1a;Bubble Sort&#xff09;是一种简单的排序算法。它重复地走访过要排序的数列&#xff0c;一次比较两个元素&#xff0c;如果他们的顺序&#xff08;如从大到小、首字母从A到Z&#xff09;错误就把他们交换过来。 …

llamafactory报错:双卡4090GPU,训练qwen2.5:7B、14B时报错GPU显存不足(out of memory),轻松搞定~~~

实际问题场景&#xff1a; 使用llamafactory进行微调qwen2.5 7B和14B的大模型时&#xff0c;会出现out of memory的报错。尝试使用降低batch_size&#xff08;原本是2&#xff0c;现在降到1&#xff09;的方式&#xff0c;可以让qwen2.5:7B跑起来&#xff0c;但时不时会不稳定…

七牛云—对象云存储Kodo(详解,文件上传和下载)

文章目录 七牛—对象云存储Kodo1.1 介绍1.2 使用注册账号创建bucket空间查询accessKey/secretKey查看官网SDK1.3 SpringBoot中使用七牛云上传引入依赖(在官方SDK文档中有)引入工具类servie层controller层postman测试下载引入工具类域名查询controller层七牛—对象云存储Kodo 1…