【一步步开发AI运动小程序】十三、自定义一个运动分析器,实现计时计数02

本文涉及的产品
视觉智能开放平台,视频通用资源包5000点
视觉智能开放平台,图像通用资源包5000点
视觉智能开放平台,分割抠图1万点
简介: 本文介绍如何利用“云智AI运动识别小程序插件”开发AI运动小程序,详细解析了俯卧撑动作的检测规则构建与执行流程,涵盖卧撑和撑卧两个姿态的识别规则,以及如何通过继承`sports.SportBase`类实现运动分析器,适用于小程序开发者。

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

一、运动分析

image.png

如图所示,俯卧撑有卧和撑两个动作姿态组成,从卧到撑或者撑到卧,为一个动作,即计数加1;因此我们分别构建这两个姿态的识别规则,查测到卧撑撑卧的组合计数加1,便可以完成俯卧撑的检测数。

二、检测规则构建

【撑】:
如上图所示的动作1“撑”姿态,我们看到整个身体躯干绷直,双手绷直撑起,手臂与腰部夹角大约80度左右,所以我们构建出以下几个检测规则进行检测:

{
   
    name: '撑状态检查',
    calc: '$and',
    rules: [{
   
        name: '手臂垂直撑起',
        calc: '$or',
        rules: [{
   
            name: '左手臂垂直',
            calc: 'vertical',
            upperKey: 'left_shoulder',
            centerKey: 'left_elbow',
            lowerKey: 'left_wrist',
            offset: 20
        }, {
   
            name: '右手臂垂直',
            calc: 'vertical',
            upperKey: 'right_shoulder',
            centerKey: 'right_elbow',
            lowerKey: 'right_wrist',
            offset: 20
        }]
    }, {
   
        name: '手臂与腰部垂直',
        calc: '$or',
        rules: [{
   
            name: '左手臂与腰齐垂直',
            calc: 'match-angle',
            angleKey: 'left_shoulder',
            secondKey: 'left_elbow',
            thirdKey: 'left_hip',
            angle: 90,
            offset: 25
        }, {
   
            name: '右手臂与腰齐垂直',
            calc: 'match-angle',
            angleKey: 'right_shoulder',
            secondKey: 'right_elbow',
            thirdKey: 'right_hip',
            angle: 90,
            offset: 25
        }]
    }, {
   
        name: '腿部绷直',
        calc: '$or',
        rules: [{
   
            name: '左腿绷直',
            calc: 'match-angle',
            angleKey: 'left_knee',
            secondKey: 'left_ankle',
            thirdKey: 'left_hip',
            angle: 160,
            offset: 20
        }, {
   
            name: '右腿绷直',
            calc: 'match-angle',
            angleKey: 'right_knee',
            secondKey: 'right_ankle',
            thirdKey: 'rgight_hip',
            angle: 160,
            offset: 20
        }]
    }]
};

【卧】:
接下来我们继续看第二个分解动作卧,如上图所示的动作2“卧”姿态,我们看到整个身体躯干也是绷直的,手臂弯曲成约90度,胳膊与腰部齐平,所以我们构建出以下检测规则进行识别:

{
   
    name: '卧动作检查',
    calc: '$and',
    rules: [{
   
        name: '躯干卧倒状态',
        calc: 'lie',
        offset: 30
    }, {
   
        name: '手臂弯曲检查',
        calc: '$or',
        rules: [{
   
            name: '左手臂弯曲状态',
            calc: 'match-angle',
            angleKey: 'left_elbow',
            secondKey: 'left_shoulder',
            thirdKey: 'left_wrist',
            angle: 115,
            offset: 15
        }, {
   
            name: '右手臂弯曲状态',
            calc: 'match-angle',
            angleKey: 'right_elbow',
            secondKey: 'right_shoulder',
            thirdKey: 'right_wrist',
            angle: 115,
            offset: 15
        }]
    }, {
   
        name: '手臂与腰齐平查',
        calc: '$or',
        rules: [{
   
            name: '左手臂与腰齐平查',
            calc: 'match-angle',
            angleKey: 'left_shoulder',
            secondKey: 'left_elbow',
            thirdKey: 'left_hip',
            angle: 35,
            offset: 15
        }, {
   
            name: '右手臂与腰齐平查',
            calc: 'match-angle',
            angleKey: 'right_shoulder',
            secondKey: 'right_elbow',
            thirdKey: 'right_hip',
            angle: 35,
            offset: 15
        }]
    }]
}

到这,我们就把运动检测规则编写好了,规则同时考虑了左、右侧入镜的问题。

三、执行检测

实现运动分析器,我们需要继承扩展sports.SportBase抽象类,该类已经为您实现了基本的计时、计数能力,您只要重写pushing方法,在此方法调用calc.Calculator计算器进行规则计算,通过则调用计时计数即可,代码如下:

    pushing(body) {
   

        if (utils.isNone(body))
            return;

        //卧
        if (this._calculator.calculating(body, this.rules.liePose)) {
   
            this.stateTran = 1;
            return;
        }

        //撑
        if (!this._calculator.calculating(body, this.rules.upPose) || this.stateTran !== 1)
            return;

        this.stateTran = -1;
        this.countTimes();
        this.emitTick();  //触发计数 

    }

四、后计

以上便是俯卧撑运动的分析器的适配过程,当然还可以使用姿态相似度能力进行动作识别,效率相对会更高些,详情请参考前面的相似度使用章节及API文档。

相关文章
|
29天前
|
人工智能 安全 API
20 万奖金池就位!Higress AI 网关开发挑战赛参赛指南
本次赛事共设三大赛题方向,参赛者可以任选一个方向参赛。本文是对每个赛题方向的参赛指南。
218 10
|
28天前
|
人工智能 运维 安全
加速智能体开发:从 Serverless 运行时到 Serverless AI 运行时
在云计算与人工智能深度融合的背景下,Serverless 技术作为云原生架构的集大成者,正加速向 AI 原生架构演进。阿里云函数计算(FC)率先提出并实践“Serverless AI 运行时”概念,通过技术创新与生态联动,为智能体(Agent)开发提供高效、安全、低成本的基础设施支持。本文从技术演进路径、核心能力及未来展望三方面解析 Serverless AI 的突破性价值。
|
30天前
|
人工智能 运维 Java
Spring AI Alibaba Admin 开源!以数据为中心的 Agent 开发平台
Spring AI Alibaba Admin 正式发布!一站式实现 Prompt 管理、动态热更新、评测集构建、自动化评估与全链路可观测,助力企业高效构建可信赖的 AI Agent 应用。开源共建,现已上线!
2597 40
|
人工智能 自然语言处理 前端开发
产品经理也能“开发”需求?淘宝信息流从需求到上线的AI端到端实践
淘宝推荐信息流业务,常年被“需求多、技术栈杂、协作慢”困扰,需求上线周期动辄一周。WaterFlow——一套 AI 驱动的端到端开发新实践,让部分需求两天内上线,甚至产品经理也能“自产自销”需求。短短数月,已落地 30+ 需求、自动生成 5.4 万行代码,大幅提升研发效率。接下来,我们将揭秘它是如何落地并改变协作模式的。
327 37
产品经理也能“开发”需求?淘宝信息流从需求到上线的AI端到端实践
|
7月前
|
监控 前端开发 小程序
陪练,代练,护航,代打小程序源码/前端UNIAPP-VUE2.0开发 后端Thinkphp6管理/具备家政服务的综合型平台
这款APP通过技术创新,将代练、家政、娱乐社交等场景融合,打造“全能型生活服务生态圈”。以代练为切入点,提供模块化代码支持快速搭建平台,结合智能匹配与技能审核机制,拓展家政服务和商业管理功能。技术架构具备高安全性和扩展性,支持多业务复用,如押金冻结、录屏监控等功能跨领域应用。商业模式多元,包括交易抽成、增值服务及广告联名,同时设计跨领域积分体系提升用户粘性,实现生态共生与B端赋能。
698 12
|
10月前
|
移动开发 小程序
thinkphp+uniapp开发的多端商城系统源码/H5/小程序/APP支持DIY模板直播分销
thinkphp+uniapp开发的多端商城系统源码/H5/小程序/APP支持DIY模板直播分销
454 0
|
12月前
|
小程序 前端开发 JavaScript
在线课堂+工具组件小程序uniapp移动端源码
在线课堂+工具组件小程序uniapp移动端源码
258 0
在线课堂+工具组件小程序uniapp移动端源码
|
移动开发 小程序 数据可视化
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
2310 3
|
小程序 前端开发 Java
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
JavaDog Chat v1.0.0 是一款基于 SpringBoot、MybatisPlus 和 uniapp 的简易聊天软件,兼容 H5、小程序和 APP,提供丰富的注释和简洁代码,适合初学者。主要功能包括登录注册、消息发送、好友管理及群组交流。
335 0
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
|
小程序 API
微信小程序更新提醒uniapp
在小程序开发中,版本更新至关重要。本方案利用 `uni-app` 的 `uni.getUpdateManager()` API 在启动时检测版本更新,提示用户并提供立即更新选项,自动下载更新内容,并在更新完成后重启小程序以应用新版本。适用于微信小程序,确保用户始终使用最新版本。以下是实现步骤: ### 实现步骤 1. **创建更新方法**:在 `App.vue` 中创建 `updateApp` 方法用于检查小程序是否有新版本。 2. **测试**:添加编译模式并选择成功状态进行模拟测试。
398 0
微信小程序更新提醒uniapp

热门文章

最新文章