如何将MediaPipe编译成Android中Chaquopy插件可用的 .whl 文件
环境准备
- 操作系统:建议使用 Ubuntu 20.04 或者 macOS(这篇博客会以 Ubuntu 为例)。
- Python 版本:Python 3.7 或以上版本。
- Android Studio:配置好 Android Studio 和 Android NDK(Native Development Kit)。
- Android 架构:通常需要编译 ARM 架构的库,比如
armeabi-v7a或arm64-v8a,这些架构是 Android 设备常用的。 - 依赖工具:
- Bazel:构建 MediaPipe 的工具。
- CMake:用于编译 C++ 代码。
- Python NDK:用于 Android 上的 Python 构建。
- Chaquopy 插件:用于在 Android Studio 中集成 Python 代码。
- Protobuf:用于处理 MediaPipe 数据结构。
步骤 1:安装构建依赖
安装 Bazel
Bazel 是 MediaPipe 官方推荐的构建工具。你可以通过以下步骤安装 Bazel:
sudo apt update
sudo apt install apt-transport-https curl gnupg
curl -fsSL https://bazel.build/bazel-release.pub.gpg | gpg --dearmor >bazel-archive-keyring.gpg
sudo mv bazel-archive-keyring.gpg /usr/share/keyrings
sudo apt update
sudo apt install bazel-5.0.0
sudo apt update && sudo apt full-upgrade
安装 CMake 和 NDK
sudo apt install cmake
确保你已安装 Android NDK,可以通过 Android Studio 的 SDK Manager 安装。
安装 Protobuf
sudo apt install protobuf-compiler
步骤 2:获取 MediaPipe 源代码
从 GitHub 克隆 MediaPipe 仓库:
git clone https://github.com/google-ai-edge/mediapipe.git
cd mediapipe
步骤 3:配置 Android 构建
MediaPipe 默认是为桌面平台编译的,我们需要为 Android 环境进行配置。你需要使用 bazel 构建工具和 Android NDK 配置文件来生成 Android 架构下的 .whl 文件。
- 创建一个针对 Android 的构建配置:
在 mediapipe 目录下创建 android_build 文件夹,用来存放 Android 配置和构建文件。
- 修改
WORKSPACE文件:
你需要在 mediapipe/WORKSPACE 文件中增加 Android 相关配置:
load("@bazel_tools//tools/python:rules.bzl", "py_binary", "py_library")
load("@bazel_tools//tools/ndk:ndk.bzl", "android_ndk_toolchain")# 配置 NDK 路径
android_ndk_toolchain(name = "android_ndk",ndk_dir = "/path/to/ndk", # 指定 NDK 路径
)
确保你已经设置好 NDK 的路径。
步骤 4:编译 MediaPipe 为 .whl 文件
- 在 Bazel 构建文件中配置 Python 支持:
在 mediapipe/mediapipe/python 目录下创建 BUILD 文件,定义如何编译 MediaPipe 代码并将其链接到 Python 包中:
load("@bazel_tools//tools/python:rules.bzl", "py_binary", "py_library")py_binary(name = "mediapipe",srcs = glob(["*.py"]),deps = ["//mediapipe/..." # 引用 MediaPipe 的相关模块],
)
- 编译 Android 特定的
.whl文件:
使用以下命令为 Android 编译 MediaPipe:
bazel build --config=android_arm64 //mediapipe/python:mediapipe_wheel
在这个命令中,--config=android_arm64 是为了指定 Android 平台的 ARM64 架构。如果需要编译其他架构(如 armeabi-v7a),可以根据需要修改配置。
注意:
//mediapipe/python:mediapipe_wheel是生成.whl文件的目标,你可以根据自己的需求修改构建目标。- 编译过程可能会遇到一些依赖问题,特别是涉及到 Android NDK 和 C++ 库时,需要根据错误信息调整配置。
步骤 5:安装 .whl 文件
构建完成后,你会在 bazel-bin/mediapipe/python 目录中看到生成的 .whl 文件。例如,mediapipe-<version>-cp38-cp38-android_16_armeabi_v7a.whl。
使用 pip 安装 .whl 文件:
pip install /path/to/mediapipe-<version>-cp38-cp38-android_16_armeabi_v7a.whl
确保安装时选择正确的 Python 版本和 Android 架构。
步骤 6:集成到 Android Studio 和 Chaquopy 插件中
- 配置 Chaquopy 插件:
在 Android Studio 的 build.gradle 文件中,添加 Chaquopy 插件和 Python 环境配置:
plugins {id 'com.android.application'id 'com.chaquo.python' version '12.0.0'
}android {compileSdk 30defaultConfig {applicationId "com.example.myapp"minSdk 21targetSdk 30versionCode 1versionName "1.0"python {pip {install "mediapipe" // 安装生成的 .whl 文件}}}buildTypes {release {minifyEnabled falseproguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'}}
}
- 调用 Python 代码:
在 Android 应用中,你可以通过 Chaquopy 插件调用 Python 代码,例如:
import mediapipe as mpmp_face_detection = mp.solutions.face_detection
mp_drawing = mp.solutions.drawing_utilswith mp_face_detection.FaceDetection(min_detection_confidence=0.2) as face_detection:# 进行图像处理pass
- 构建并运行 Android 应用:
构建并运行 Android 项目,确保 Python 代码在 Android 设备上能够正常运行。
步骤 7:调试和优化
- 性能优化:MediaPipe 在 Android 设备上可能会受到硬件性能的限制,特别是在较旧的设备上。你可能需要优化处理流程,例如减少帧率、优化图像处理算法等。
- 依赖问题:如果在构建过程中遇到任何依赖问题,检查 NDK 配置或尝试使用其他版本的 Android NDK。
- Python 环境:确保 Chaquopy 插件和 Python 环境配置正确,特别是在涉及到不同 Python 版本和 Android 架构时。
总结
通过上述步骤,你将成功地将 MediaPipe 编译成一个适用于 Android 平台的 .whl 文件,并通过 Chaquopy 插件集成到 Android Studio 项目中。这使得你能够在 Android 应用中使用 MediaPipe 进行实时的图像处理、手势识别等功能。
相关文章:
如何将MediaPipe编译成Android中Chaquopy插件可用的 .whl 文件
环境准备 操作系统:建议使用 Ubuntu 20.04 或者 macOS(这篇博客会以 Ubuntu 为例)。Python 版本:Python 3.7 或以上版本。Android Studio:配置好 Android Studio 和 Android NDK(Native Development Kit&a…...
华为OD机试-绘图机器-双指针(Java 2025 A卷 100分)
题目描述 绘图机器的绘图笔初始位置在原点 (0, 0)。机器启动后按照以下规则绘制直线: 尝试沿着横坐标正向绘制直线,直到给定的终点 E。期间可以通过指令在纵坐标轴方向进行偏移,offsetY 为正数表示正向偏移,为负数表示负向偏移。给定的横坐标终点值 E 以及若干条绘制指令,…...
【C++】动态规划从入门到精通
一、动态规划基础概念详解 什么是动态规划 动态规划(Dynamic Programming,DP)是一种通过将复杂问题分解为重叠子问题,并存储子问题解以避免重复计算的优化算法。它适用于具有以下两个关键性质的问题: 最优子结构&…...
OpenCV计算摄影学(23)艺术化风格化处理函数stylization()
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 风格化的目的是生成不以照片写实为目标的多种多样数字图像效果。边缘感知滤波器是风格化处理的理想选择,因为它们能够弱化低对比度区…...
S32K144外设实验(三):ADC单通道连续采样(中断)
这次的实验比较简单,主要目的就是验证一下ADC的中断功能,思路是使用软件触发ADC的连续单通道采样,将采样值通过串口发送到上位机观察数是否正确。 其实官方并不推荐使用中断的方式,这种方式会占用大量的CPU资源,笔者安…...
LeetCode 第19~21题
LeetCode 第19题:删除链表的倒数第N个结点 题目描述 给你一个链表,删除链表的倒数第n个结点,并且返回链表的头结点。 难度:中等 题目链接:19. 删除链表的倒数第 N 个结点 - 力扣(LeetCode) 示例…...
Web3 时代数据保护的关键挑战与应对策略
Web3 时代数据保护的关键挑战与应对策略 随着互联网技术的飞速发展,我们正步入 Web3 时代,这是一个以去中心化、用户主权和数据隐私为核心的新时代。在这个时代,数据保护成为了一个至关重要的议题。本文将探讨 Web3 时代数据保护面临的主要挑…...
为什么labelme框选图片后闪退
Labelme 软件框选图片后闪退的解决方案 Labelme 是一种常用的图像标注工具,但在实际使用过程中可能会遇到一些问题,比如框选图片后程序突然闪退。以下是针对该问题的具体分析和解决方法: 可能原因及对应解决措施 标签文件异常 如果某些图片…...
C# I/O 核心用法
在 C# 中,输入输出(I/O)操作是处理文件、目录、流等数据交互的核心功能。本文将从基础到高级,系统讲解 C# 中文件 I/O 的实现方式、最佳实践及常见场景解决方案。 一、核心类与命名空间 1、System.IO 命名空间,…...
SpringBoot之如何集成SpringDoc最详细文档
文章目录 一、概念解释1、OpenAPI2、Swagger3、Springfox4、Springdoc5. 关系与区别 二、SpringDoc基本使用1、导包2、正常编写代码,不需要任何注解3、运行后访问下面的链接即可 三、SpringDoc进阶使用1、配置文档信息2、配置文档分组3、springdoc的配置参数**1. 基…...
Oracle 数据迁移至 GaussDB 注意事项
将数据从 Oracle 迁移到 GaussDB(华为分布式数据库)时,需充分考虑架构差异、语法兼容性、数据一致性等核心问题。以下是关键注意事项及操作建议: 一、迁移前的准备工作 兼容性评估 语法差异:Oracle 使用 PL/SQL&#x…...
【智能体】| 知识库、RAG概念区分以及智能体是什么
文章目录 前言简介大模型“幻觉”问题如何解决“幻觉”问题? RAG、智能体、RAG智能体概念什么是检索增强型生成(RAG)模拟简单的RAG场景 AI系统中的智能体是什么什么是Agentic RAG?Agentic RAG如何工作?Agentic RAG架构…...
二分查找的应用
什么时候用二分查找? 数据具有二段性的时候 第一题: 题解代码: class Solution { public:int search(vector<int>& nums, int target) {int left 0,right nums.size()-1;while(left<right){int mid left (right-left)/2;//中…...
Android Compose 框架基础按钮模块深度剖析(四)
Android Compose 框架基础按钮模块深度剖析 一、引言 在现代 Android 应用开发中,Android Compose 框架以其声明式编程范式和简洁高效的开发体验,逐渐成为开发者构建用户界面的首选。而注解在 Android Compose 框架中扮演着至关重要的角色,…...
redis搭建一主一从+keepalived(虚拟IP)实现高可用
redis搭建一主一从keepalived(虚拟IP)实现高可用 前提 有两台机器:如 10.50.3.141 10.50.3.142,虚拟ip如:10.50.3.170 安装redis(两台机器执行): # 启用Remi仓库(CentOS 7) sudo yum install…...
【Function】Azure Function通过托管身份或访问令牌连接Azure SQL数据库
【Function】Azure Function通过托管身份或访问令牌连接Azure SQL数据库 推荐超级课程: 本地离线DeepSeek AI方案部署实战教程【完全版】Docker快速入门到精通Kubernetes入门到大师通关课AWS云服务快速入门实战目录 【Function】Azure Function通过托管身份或访问令牌连接Azu…...
MySQL日志全解析:类型、用途与运维实践
引言 MySQL作为最流行的关系型数据库之一,其日志系统是运维人员理解数据库状态、排查问题、保证数据安全的核心工具。不同类型的日志记录了数据库活动、错误信息、数据变更等关键内容。本文将深入解析MySQL各类日志的作用、配置参数及运维注意事项,帮助…...
《算法笔记》9.2小节——数据结构专题(2)->二叉树的遍历 问题 A: 复原二叉树(同问题 C: 二叉树遍历)
题目描述 小明在做数据结构的作业,其中一题是给你一棵二叉树的前序遍历和中序遍历结果,要求你写出这棵二叉树的后序遍历结果。 输入 输入包含多组测试数据。每组输入包含两个字符串,分别表示二叉树的前序遍历和中序遍历结果。每个字符串由…...
小程序开发中的用户反馈收集与分析
我们在开发小程序的过程中根据开发过程中的代码及业务场景,以下是针对需求管理系统的用户反馈收集与分析方案设计: 需求管理系统用户反馈收集与分析方案 一、反馈数据模型设计 // 新增Feedback模型(app/admin/model/Feedback.php) namespace app\admin\model; use think\…...
Flink 通过 Chunjun Oracle LogMiner 实时读取 Oracle 变更日志并写入 Doris 的方案
文章目录 一、 技术背景二、 关键技术1、 Oracle LogMiner2、 Chunjun 的 LogMiner 关键流程3、修复 Chunjun Oracle LogMiner 问题 一、 技术背景 在大数据实时同步场景中,需要将 Oracle 数据库的变更数据(CDC) 采集并写入 Apache Doris&am…...
WordPress系统获取webshell的攻略
一.后台修改模板拿WebShell 1.进入Vulhub靶场并执⾏以下命令开启靶场;在浏览器中访问并安装好 #执⾏命令 cd /vulhub/wordpress/pwnscriptum docker-compose up -d 2. 修改其WP的模板,登陆WP后点击 【外 观】 --》 【编辑】 --》 404.php 3.插入一句话木…...
JMeter基本介绍
Apache JMeter 工具详解 一、JMeter 简介 JMeter 是 Apache 基金会开源的 Java 应用程序,主要用于 性能测试、负载测试 和 功能测试。它通过对服务器或网络资源模拟多种负载条件(如并发用户、持续压力),帮助评估系统性能指标&am…...
npm 安装 pnpm 的详细步骤及注意事项
一、安装步骤 1.全局安装 pnpm npm install -g pnpm2.验证安装 pnpm -v输出版本号即表示安装成功。 二、升级 pnpm 若已安装旧版本,可通过以下命令升级: npm install -g pnpmlatest三、配置镜像加速 设置淘宝镜像 pnpm config set registry http…...
蓝桥杯2023年第十四届省赛真题-子矩阵
题目来自DOTCPP: 暴力思路(两个测试点超时): 题目要求我们求出子矩阵的最大值和最小值的乘积,我们可以枚举矩阵中的所有点,以这个点为其子矩阵的左上顶点,然后判断一下能不能构成子矩阵。如果可…...
如何在 Node.js 中使用 .env 文件管理环境变量 ?
Node.js 应用程序通常依赖于环境变量来管理敏感信息或配置设置。.env 文件已经成为一种流行的本地管理这些变量的方法,而无需在代码存储库中公开它们。本文将探讨 .env 文件为什么重要,以及如何在 Node.js 应用程序中有效的使用它。 为什么使用 .env 文…...
Redis BitMap 用户签到
Redis Bitmap Bitmap(位图)是 Redis 提供的一种用于处理二进制位(bit)的特殊数据结构,它基于 String 类型,每个 bit 代表一个布尔值(0 或 1),可以用于存储大规模的二值状…...
未来办公与生活的新范式——智慧园区
在信息化与智能化技术飞速发展的今天,智慧园区作为一种新兴的城市发展形态,正逐步成为推动产业升级、提升城市管理效率、改善居民生活质量的重要力量。智慧园区不仅融合了先进的信息技术,还深刻体现了可持续发展的理念,为园区内的…...
Hugging Face预训练GPT微调ChatGPT(微调入门!新手友好!)
Hugging Face预训练GPT微调ChatGPT(微调入门!新手友好!) 在实战中,⼤多数情况下都不需要从0开始训练模型,⽽是使⽤“⼤⼚”或者其他研究者开源的已经训练好的⼤模型。 在各种⼤模型开源库中,最…...
【CSS3】化神篇
目录 平面转换平移旋转改变旋转原点多重转换缩放倾斜 渐变线性渐变径向渐变 空间转换平移视距旋转立体呈现缩放 动画使现步骤animation 复合属性animation 属性拆分逐帧动画多组动画 平面转换 作用:为元素添加动态效果,一般与过渡配合使用 概念&#x…...
Unity音频混合器如何暴露参数
音频混合器是Unity推荐管理音效混音的工具,那么如何使用代码对它进行管理呢? 首先我在AudioMixer的Master组中创建了BGM和SFX的分组,你也可以直接用Master没有问题。 这里我以BGM为例,如果要在代码中进行使用就需要将参数暴露出去…...
