随着人工智能技术的不断发展,阿里体育等IT大厂,推出的“乐动力”、“天天跳绳”AI运动APP,让云上运动会、线上运动会、健身打卡、AI体育指导等概念空前火热。那么,能否将这些在APP成功应用的场景搬上小程序,分享这些概念的红利呢?本系列文章就带您一步一步从零开始开发一个AI运动小程序,本系列文章将使用“云智AI运动识别小程序插件”,请先行在微信服务市场官网了解详情。

一、初始化人体识别功能

人体识别能力调用前需要初始化(可多次初始化),插件的具有双人体识别引擎,默认不指定引擎将自动选择最优引擎,也可指定引擎,识别引擎的差别请参考集成文档。

const that = this;
humanDetection.initialize({
//ve: 2,
callback(err) {
uni.hideLoading(); if (!err) {
console.log('人体检测能力初始化成功。', humanDetection.getVe());
return;
} uni.showModal({
content: `初始化失败,详细信息:${err.message}`,
showCancel: false
});
}
});

二、调用人体识别功能

//接上篇抽帧
const context = wx.createCameraContext();
const listener = context.onCameraFrame((frame) => {
//frame.data图像数组将用于后续的人体识别
const image = {
width: Number(frame.width),
height: Number(frame.height),
data: new Uint8Array(frame.data)
};
humanDetection.detectionAsync(image).then(human=>{
console.log(human);
});
});
listener.start();

三、人体识别结果

{
"score": 0.7251838252824896,
"width": 480,
"height": 640,
"timestamp": 1684325583506,
"keypoints": [
{
"y": 103.56424502483996,
"x": 256.0109768927012,
"score": 0.4570312798023224,
"name": "nose"
},
{
"y": 90.71574411931093,
"x": 270.50707531981544,
"score": 0.58251953125,
"name": "left_eye"
},
{
"y": 90.09307140499885,
"x": 244.60145098668588,
"score": 0.552734375,
"name": "right_eye"
},
{
"y": 95.37442872749463,
"x": 286.88540601464354,
"score": 0.75244140625,
"name": "left_ear"
},
{
"y": 93.90985185987653,
"x": 231.85045311881774,
"score": 0.7392578125,
"name": "right_ear"
},
{
"y": 162.78484030178413,
"x": 311.0556351088547,
"score": 0.919921875,
"name": "left_shoulder"
},
{
"y": 161.2381417518693,
"x": 203.38841526521654,
"score": 0.77197265625,
"name": "right_shoulder"
},
{
"y": 240.78316880186404,
"x": 310.24842737472574,
"score": 0.84912109375,
"name": "left_elbow"
},
{
"y": 242.12329664294745,
"x": 201.77353663841666,
"score": 0.833984375,
"name": "right_elbow"
},
{
"y": 281.9979693520591,
"x": 352.673287407275,
"score": 0.59765625,
"name": "left_wrist"
},
{
"y": 286.2878520237733,
"x": 173.8384814716242,
"score": 0.63427734375,
"name": "right_wrist"
},
{
"y": 307.2371714929637,
"x": 273.4654390815558,
"score": 0.82177734375,
"name": "left_hip"
},
{
"y": 305.7596342955926,
"x": 222.0470940485152,
"score": 0.84912109375,
"name": "right_hip"
},
{
"y": 417.72422545441424,
"x": 267.0201893540119,
"score": 0.6103515625,
"name": "left_knee"
},
{
"y": 414.7774591985668,
"x": 204.46947287192143,
"score": 0.8701171875,
"name": "right_knee"
},
{
"y": 481.8868752974563,
"x": 280.1792094531294,
"score": 0.74072265625,
"name": "left_ankle"
},
{
"y": 467.38751675509405,
"x": 247.29222232381437,
"score": 0.7451171875,
"name": "right_ankle"
}
],
"bodyRange": {
"x": 173.8384814716242,
"y": 90.09307140499885,
"width": 178.8348059356508,
"height": 391.79380389245745
}
}

四、识别结果旋转矫正

获得人体识别结果后,可以调用rotate()进行整体旋转,也可以调用rotateToUpright()自动旋转直立图,进行横、竖屏适配。

下一篇将为您介绍人体骨骼图绘制...

【一步步开发AI运动小程序】五、帧图像人体识别的更多相关文章

  1. Java可视化日历(Date类、DATe Format类、Calendar类综合运用),开发可视化日历小程序

    Java时间日期类综合运用,开发可视化日历小程序 由键盘输入指定格式的日期,打印这个月的日历 1.代码 import java.text.DateFormat; import java.text.Pa ...

  2. 开发一个微信小程序教程

    一.注册小程序账号 1.进入微信公众平台(https://mp.weixin.qq.com/),注册小程序账号,根据提示填写对应的信息即可. 2.注册成功后进入首页,在 小程序发布流程->小程序 ...

  3. 开发一个微信小程序项目教程

    一.注册小程序账号 1.进入微信公众平台(https://mp.weixin.qq.com/),注册小程序账号,根据提示填写对应的信息即可.2.注册成功后进入首页,在 小程序发布流程->小程序开 ...

  4. 如何快速地开发一个微信小程序

    如何快速地开发一个微信小程序呢?我觉得作为初学者,最好能有一个模板,然后改这个模板. 同样作为初学者,刚开始的时候我有下面的几个问题,后来通过问同学,我弄清楚了. 微信小程序可以连接MySQL或者Sq ...

  5. 全栈开发工程师微信小程序-中(下)

    全栈开发工程师微信小程序-中(下) 微信小程序视图层 wxml用于描述页面的结构,wxss用于描述页面的样式,组件用于视图的基本组成单元. // 绑定数据 index.wxml <view> ...

  6. 全栈开发工程师微信小程序-中(中)

    全栈开发工程师微信小程序-中(中) 开放能力 open-data 用于展示微信开放的数据 type 开放数据类型 open-gid 当 type="groupName" 时生效, ...

  7. 全栈开发工程师微信小程序-中

    全栈开发工程师微信小程序-中 多媒体及其他的组件 navigator 页面链接 target 在哪个目标上发生跳转,默认当前小程序,可选值self/miniProgram url 当前小程序内的跳转链 ...

  8. 全栈开发工程师微信小程序-上(下)

    全栈开发工程师微信小程序-上(下) icon 图标 success, success_no_circle, info, warn, waiting, cancel, download, search, ...

  9. 全栈开发工程师微信小程序-上(中)

    全栈开发工程师微信小程序-上(中) width: 750rpx; 750rpx代表与屏幕等宽,rpx的缩写responsive pixel,这个单位是可以根据屏幕大小进行自适应调整的像素单位. 小程序 ...

  10. 全栈开发工程师微信小程序 - 上

    全栈开发工程师微信小程序-上 实现swiper组件 swiper 滑块视图容器. indicator-dots 是否显示面板指示点 false indicator-color 指示点颜色 indica ...

随机推荐

  1. DDD是软件工程的第一性原理?

    本文书接上回<DDD建模后写代码的正确姿势>,关注公众号(老肖想当外语大佬)获取信息: 最新文章更新: DDD框架源码(.NET.Java双平台): 加群畅聊,建模分析.技术实现交流: 视 ...

  2. 异源数据同步 → DataX 为什么要支持 kafka?

    开心一刻 昨天发了一条朋友圈:酒吧有什么好去的,上个月在酒吧当服务员兼职,一位大姐看上了我,说一个月给我 10 万,要我陪她去上海,我没同意 朋友评论道:你没同意,为什么在上海? 我回复到:上个月没同 ...

  3. Mac安装Adobe PS_AE_PR等系列软件提示错误代码146怎么办?

    在安装Mac版Adobe系列软件的时候,不管PS.AE.PR.AI等,如果出现错误代码146,下面两个方法能够轻松解决. 解决方法一:需要我们打开「系统设置」-「隐私与安全」-「App管理」,打开「i ...

  4. redis 基准性能测试与变慢优化

    redis 参考目录: 生产级Redis 高并发分布式锁实战1:高并发分布式锁如何实现 https://www.cnblogs.com/yizhiamumu/p/16556153.html 生产级Re ...

  5. C#自定义控件—旋转按钮

    C#用户控件之旋转按钮 按钮功能:手自动旋转,标签文本显示.点击二次弹框确认(源码在最后边): [制作方法] 用方法找到控件的中心坐标,画背景外环.内圆:再绘制矩形开关,进行角度旋转即可获得: [关键 ...

  6. c程序设计语言 by K&R(四)输入与输出

    一.标准输入.输出 1. 简单的输入\输出机制 从标准输入中一次读取一个字符:int getchar(void) 将字符c送到标准输出中: int putchar(int) 2. 输入重定向 如果程序 ...

  7. Python将表格文件中某些列的数据整体向上移动一行

      本文介绍基于Python语言,针对一个文件夹下大量的Excel表格文件,对其中的每一个文件加以操作--将其中指定的若干列的数据部分都向上移动一行,并将所有操作完毕的Excel表格文件中的数据加以合 ...

  8. CSS – rem, em, px

    参考: 掘金 – 如何更愉快地使用em -- 别说你懂CSS相对单位 绝对值 vs 相对值 px, cm, mm 这些是绝对值. rem, em 是相对值. 绝对值就是最终的尺寸. 相对值的意思是它不 ...

  9. 【赵渝强】使用二进制包部署Kubernetes集群

    在一些企业的私有环境中可能无法连接外部的网络.如果要在这样的环境中部署Kubernetes集群,可以采集Kubernetes离线安装的方式进行部署.即:使用二进制安装包部署Kubernetes集群,采 ...

  10. 【赵渝强老师】使用kubeadmin部署K8s集群

    首先,我们来看一下整体的架构. K8s的部署方式: yum方式部署 二进制包:手动使用tar包来部署 minikube:单机版,用于开发测试. kubeadm:可以把kubeadmin看成一个部署工具 ...