尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

【一步步开发AI运动APP】十二、自定义扩展新运动项目2

【一步步开发AI运动APP】十二、自定义扩展新运动项目2
📅 发布时间:2026/6/18 21:25:13

之前我们为您分享了【一步步开发AI运动小程序】开发系列博文,通过该系列博文,很多开发者开发出了很多精美的AI健身、线上运动赛事、AI学生体测、美体、康复锻炼等应用场景的AI运动小程序;为了帮助开发者继续深耕AI运动领域市场,今天开始我们将为您分享新系列【一步步开发AI运动APP】的博文,带您开发性能更强、体验更好的AI运动APP。

上一篇为您介绍了uni-app版运动识别插件的自定义扩展运动的基本架构、与小程序版运动识别插件的运动扩展差异,本篇我们就以双手并举为例带你来实现一个扩展运动。

一、动作姿态拆解

动作示意图

如上图所示,这个运动主要为手部摆动动,包含2个分动作姿态,起始动作姿态1为双手垂放于左右两侧站立,结束动作姿态2双手举过头顶撑直为结束动作,完成动作2时计数加一,如此反复运动。

二、定义运动检测规则

接下来我们为这两个拆解姿态分别构建检测规则,检测规则及自定义姿态的检测可以参考本系列博文的前面章节及插件的pose-calc指南文档。

  • 先构建动作姿态1手垂于两侧并站立的动作的检测规则:
 {name: '双手下垂',calc: '$and',rules: [{name: '站立姿态',calc: 'stand',offset: 25}, {name: '左腋夹角',calc: 'match-angle',angleKey: 'left_shoulder',secondKey: 'left_hip',thirdKey: 'left_wrist',angle: 30,offset: 30}, {name: '左手下垂',calc: 'vertical',upperKey: 'left_shoulder',centerKey: 'left_elbow',lowerKey: 'left_wrist',offset: 25}, {name: '右腋夹角',calc: 'match-angle',angleKey: 'right_shoulder',secondKey: 'right_hip',thirdKey: 'right_wrist',angle: 30,offset: 30}, {name: '右手下垂',calc: 'vertical',upperKey: 'right_shoulder',centerKey: 'right_elbow',lowerKey: 'right_wrist',offset: 25}]}
  • 再构建动作姿态2双手举过头顶伸直站立的检测规则:
{name: '双手上举',calc: '$and',rules: [{name: '左手上举',calc: 'position',referenceKey: 'left_eye',positionKey: 'left_wrist',position: 'top',relaxed: true}, {name: '右手上举',calc: 'position',referenceKey: 'right_eye',positionKey: 'right_wrist',position: 'top',relaxed: true}]
}

三、实现运动分析器

定义好动作姿态检测规则后,我们便可以实现此扩展运动的运动分析器了,完整代码如下:

/*** 双手并举运动分析器*/
export class BothHandsUpSport {context = null;calculator = null; //ICalculatorstateTran = -1;/*** 初始化运动分析器*/constructor() {this.calculator = createCalculator();this.buildRules();const that = this;this.context = createExtendSportContext({key: 'both-hands-up',name: '自定义-双手并举',tickMode: true,view: 'front_back',start: () => that.start(),// reset: this.reset,// stop: this.stop,pushing: human => that.pushing(human)});}buildRules() {this.rules = {};this.rules.ups = {name: '双手上举',calc: '$and',rules: [{name: '左手上举',calc: 'position',referenceKey: 'left_eye',positionKey: 'left_wrist',position: 'top',relaxed: true}, {name: '右手上举',calc: 'position',referenceKey: 'right_eye',positionKey: 'right_wrist',position: 'top',relaxed: true}]};this.rules.downs = {name: '双手下垂',calc: '$and',rules: [{name: '站立姿态',calc: 'stand',offset: 25}, {name: '左腋夹角',calc: 'match-angle',angleKey: 'left_shoulder',secondKey: 'left_hip',thirdKey: 'left_wrist',angle: 30,offset: 30}, {name: '左手下垂',calc: 'vertical',upperKey: 'left_shoulder',centerKey: 'left_elbow',lowerKey: 'left_wrist',offset: 25}, {name: '右腋夹角',calc: 'match-angle',angleKey: 'right_shoulder',secondKey: 'right_hip',thirdKey: 'right_wrist',angle: 30,offset: 30}, {name: '右手下垂',calc: 'vertical',upperKey: 'right_shoulder',centerKey: 'right_elbow',lowerKey: 'right_wrist',offset: 25}]};}start() {this.stateTran = -1;console.log('运动启动', this);}pushing(fragment) {if (fragment.isNobody) {console.log('未识别到人体');return;}const human = fragment.human;if (this.stateTran != 1 && this.calculator.calculating(human, this.rules.downs)) {this.stateTran = 1;return;}if (this.stateTran == 1 && this.calculator.calculating(human, this.rules.ups)) {this.stateTran = 2;this.context.countTimes();this.context.emitTick(1);}}/*** 获取当前扩展运动的原生分析器实例* @returns 原生运动分析器实例*/getSportInstance() {return this.context.getSport();}/*** 获取当前扩展运动描述* * @returns  运动描述条目实例*/static getDescriptor() {let item = {key: 'both-hands-up',name: '自定义-双手并举'};return item;}
}

好了,本节就为您介绍到这,下一节我们将为您介绍将实现的自定义扩展运动列表的维护,敬请期待...

image

提供全景AI运动解决方案、各类应用定制开发服务

www.yztob.com

QQ:316455841

欢迎通过各种渠道咨询了解,免费提供技术咨询服务。

相关新闻

  • if 和 else 的用法
  • MySQL 高可用构建方案详解
  • VMware ESXi 9.0.1.0 macOS Unlocker OEM BIOS 2.7 标准版和厂商定制版

最新新闻

  • 靠谱的企业管理咨询公司推荐榜2026 - 资讯纵览
  • GEO 优化服务商哪家落地效果真实可查?2026 五家高口碑机构深度评测 - 小兔崽子cheng
  • Java 明明有 GC,为什么还会 OOM?生产事故引起了一下反思
  • 2026 年北京洋酒高价回收机构甄选:专业鉴定与高溢价变现行业参考 - 资讯纵览
  • Tortoise ORM:Python 异步世界的 Django 风格 ORM
  • 常州保时捷帕拉梅拉音响改装 音乐人生打造劲浪乌托邦打造移动音乐厅 - 音乐人生汽车音响

日新闻

  • 2026年不锈钢卷板厂家推荐排行榜:冷轧热轧/304/201不锈钢卷板,高颜值耐腐蚀源头厂家实力精选 - 企业推荐官【官方】
  • FLUX.1-dev FP8模型实战指南:24GB以下显卡高效部署方案
  • 2026佛山长途搬家价目表:跨省跨市搬家费用完整计算指南 - 从来都是英雄出少年

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号