Android Studio 接入OpenCV最简单的例子 : 实现灰度图效果
1. 前言
上文 我们在Windows电脑上实现了人脸功能,接下来我们要把人脸识别的功能移植到Android上。
那么首先第一步,就是要创建一个Native的Android项目,并且配置好OpenGL,并能够调用成功。
这里我们使用的是openCV-4.8.0,官网下载地址 : https://opencv.org/releases/
也可以直接下载我上传的资源 : Android和Windows下,使用OpenCV实现人脸识别 示例 Demo
2. 创建Native Android项目
首选我们先来创建一个Native Android项目,这里选择 Native C++

输入项目名,这里我命名为MyOpenCVTest

C++ Stardard这里选择c++11,然后点击Finish,项目就创建成功了。

3. 配置OpenCV
接着,我们需要在项目中配置好OpenCV。
3.1 配置build.config
在app下的build.config的cmake闭包中,指定abiFilters 为arm64-v8a和armeabi-v7a,注意这里arguments需要配置-DANDROID_STL=c++_shared,cppFlags为-std=c++11。
defaultConfig//省略了代码...externalNativeBuild {cmake {cppFlags "-std=c++11"abiFilters 'arm64-v8a','armeabi-v7a'arguments "-DANDROID_STL=c++_shared"}}}
将jniLibs目录指定为libs
android {//...省略了代码sourceSets {main {jniLibs.srcDirs = ['libs']}}
}
3.2 解压 opencv-4.8.0-android-sdk.zip
解压opencv-4.8.0-android-sdk.zip,在opencv-4.8.0-android-sdk\OpenCV-android-sdk\sdk\native\libs中可以看到arm64-v8a和armeabi-v7a

将arm64-v8a和armeabi-v7a复制到我们Android项目的app/lib目录下

3.3 解压 opencv-4.8.0-windows.exe
打开并安装opencv-4.8.0-windows.exe(其实是解压了该文件到指定目录),在解压后的目录中,比如我这里是D:\Developer\opencv4.8.0\opencv\build,可以看到include文件夹

3.4 复制include头文件
将include文件夹复制到Android项目中的app\src\main\cpp文件夹

3.5 配置 CMakeLists.txt
修改app\src\main\cpp\CMakeLists.txt,将头文件和库文件导入,注意这里target_link_libraries不仅要导入opencv_java4,还要导入android这个库 (系统自带) ,后面会用到。
#导入头文件
include_directories(include)#导入库文件
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -L${CMAKE_SOURCE_DIR}/../../../libs/${ANDROID_ABI}")target_link_libraries(myopencvtestopencv_java4${log-lib}android)
这里
CMAKE_CXX_FLAGS用来设置特定的编译选项给C++编译器
-L参数在CMAKE_CXX_FLAGS中用于指定链接器在链接时搜索库文件的路径。也就是说,如果你的项目中使用了一些库文件,并且这些库文件不在系统默认的库文件搜索路径下,你就需要使用-L参数来告诉链接器去哪里找这些库文件。
${CMAKE_SOURCE_DIR}路径为E:/WorkSpace/Demo/OpenCV/Android/MyOpenCVTest/app/src/main/cpp,所以我们需要使用../../../定位到app下,然后再通过libs/${ANDROID_ABI}进入到libs目录下的具体ANDROID_ABI下。
CMakeLists.txt完整代码如下所示
cmake_minimum_required(VERSION 3.22.1)project("myopencvtest")add_library(myopencvtestSHAREDnative-lib.cpp)#导入头文件
include_directories(include)#导入库文件
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -L${CMAKE_SOURCE_DIR}/../../../libs/${ANDROID_ABI}")find_library( # Sets the name of the path variable.log-liblog)target_link_libraries(myopencvtestopencv_java4${log-lib}android)
3.6 cpp中声明opencv引用
接着,在native-lib.cpp中引入opencv2/opencv.hpp
#include "opencv2/opencv.hpp"
运行项目,项目正常运行,说明OpenCV配置成功了。
4. 使用OpenCV将图片转化为灰度图
在我的Visual Studio 2022 cmake配置opencv开发环境这篇博客里,最后通过调用OpenCV的cvtColor方法,显示出了灰白色的图片,我们现在把这个功能移植到android中。
实现的功能 : 从sd卡中读取一张图片,然后将其转变为灰度图,并保存在sd中
4.1 创建指定文件夹
首先我们在MainActivity里添加这样几行代码,然后app跑起来运行一次,这会创建sdcard/Android/data/包名/files这个文件夹
val dir = getExternalFilesDir("")
if (!dir!!.exists()) {dir!!.mkdirs()
}
4.2 将图片复制到该文件夹下
我们要把一张图片复制到sdcard/Android/data/包名/files目录下,重命名为img1.jpg
4.3 实现cpp代码
然后修改stringFromJNI这个JNI方法,修改为如下所示的代码。
- 注意这里的路径,需要改成你项目中的实际路径
- 注意这里的
com_heiko_myopencvtest_MainActivity需要和你实际的包名和类名相匹配
#include <jni.h>
#include <string>
#include "opencv2/opencv.hpp"using namespace cv;
using namespace std;extern "C" JNIEXPORT jstring JNICALL
Java_com_heiko_myopencvtest_MainActivity_stringFromJNI(JNIEnv* env,jobject /* this */) {string hello = "文件已经保存至";char *result = new char[100];string opencvOutPath = "/sdcard/Android/data/com.heiko.myopencvtest/files/img_gray.jpg";Mat mat = imread("/sdcard/Android/data/com.heiko.myopencvtest/files/img1.jpg");Mat grayMat;cvtColor(mat, grayMat, COLOR_BGR2GRAY);imwrite(opencvOutPath, grayMat);strcat(result, hello.c_str());strcat(result, opencvOutPath.c_str());jstring return_str = env->NewStringUTF(result);delete result;return return_str;
}
4.4 运行项目
运行项目,提示文件已经保存至/sdcard/Android/data/com.heiko.myopencvtest/files/img_gray.jpg

然后我们到这个文件夹下查看下,可以看到多了一张灰色的图片img_gray.jpg

至此,我们就在Android上完成OpenCV的接入了,下一篇文章我们来看一下怎么在Android中使用OpenCV实现人脸识别。
5. OpenCV系列文章
Visual Studio 2022 cmake配置opencv开发环境_opencv visualstudio配置_氦客的博客-CSDN博客
在Visual Studio上,使用OpenCV实现人脸识别_氦客的博客-CSDN博客
Android Studio 接入OpenCV,并实现灰度图效果_氦客的博客-CSDN博客
Android 使用OpenCV实现人脸识别_氦客的博客-CSDN博客 (待更新)
相关文章:
Android Studio 接入OpenCV最简单的例子 : 实现灰度图效果
1. 前言 上文 我们在Windows电脑上实现了人脸功能,接下来我们要把人脸识别的功能移植到Android上。 那么首先第一步,就是要创建一个Native的Android项目,并且配置好OpenGL,并能够调用成功。 这里我们使用的是openCV-4.8.0&#x…...
(1)、扩展SpringCache一站式解决缓存击穿,穿透,雪崩
1、问题描述 我们在使用SpringCache的@Cacheable注解时,发现并没有设置过期时间这个功能。 @Target({ElementType.TYPE, ElementType.METHOD}) @Retention(RetentionPolicy.RUNTIME) @I...
Rancher使用cert-manager安装报错解决
报错: rancher-rke-01:~/rke/rancher-helm/rancher # helm install rancher rancher-stable/rancher --namespace cattle-system --set hostnamewww.rancher.local Error: INSTALLATION FAILED: Internal error occurred: failed calling webhook "webhook…...
Harvard transformer NLP 模型 openNMT 简介入门
项目网址: OpenNMT - Open-Source Neural Machine Translation logo: 一,从应用的层面先跑通 Harvard transformer GitHub - harvardnlp/annotated-transformer: An annotated implementation of the Transformer paper. git clone https…...
【数据结构OJ题】用栈实现队列
原题链接:https://leetcode.cn/problems/implement-queue-using-stacks/ 目录 1. 题目描述 2. 思路分析 3. 代码实现 1. 题目描述 2. 思路分析 用两个栈实现,一个栈进行入队操作,另一个栈进行出队操作。 出队操作: 当出队的栈…...
通达信指标公式15:除权除息数据统计分析
#1.关于除权除息指标的介绍:本指标是小红牛原创指标之一,觉得有必要研究一下这个问题,所以就花时间整理一下这个指标相关内容,大家可以在本源码基础上,进一步优化自己的思路。本指标为通达信幅图指标,可以做…...
day-27 代码随想录算法训练营(19)回溯part03
39.组合总和 分析:同一个数可以选多次,但是不能有重复的答案; 思路:横向遍历,纵向递归(不同的是递归的时候不需要跳到下一个位置,因为同一个数可以选多次) class Solution { publ…...
CSDN编程题-每日一练(2023-08-22)
CSDN编程题-每日一练(2023-08-22) 一、题目名称:最长递增区间二、题目名称:K树三、题目名称:小Q的价值无向图一、题目名称:最长递增区间 时间限制:1000ms内存限制:256M 题目描述: 给一个无序数组,求最长递增的区间长度。如:[5,2,3,8,1,9] 最长区间 2,3,8 长度为 3。…...
使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务
原文链接:https://forum.laf.run/d/994 大家好!今天这篇文章主要向大家介绍 Sealos 的数据库服务。在 Sealos 上数据库后端服务由 KubeBlocks 提供,为用户的数据库应用保驾护航。无论你是在公有云还是本地环境中使用,Sealos 都能为…...
SFL212B-10-21-15、SFL212B-20-21-40喷嘴挡板伺服阀
SFL212B-05-21-10、SFL212B-10-21-15、SFL212B-20-21-40、SFL212-05-32-10、SFL212-10-32-15、SFL212-20-32-40、SFL212A-05-21-10、SFL212A-10-21-15、SFL212A-20-21-40喷嘴挡板力反馈伺服阀,外置伺服放大器,四通,带阀芯阀套的两级伺服阀&am…...
阿里云100元预算可选的云服务器配置2核2G3M带宽
阿里云服务器100元可以买到哪些配置?如果是一年时长,轻量应用服务器2核2G3M带宽一年108元,系统盘为50GB高效云盘。以前阿里云服务器ECS卖过35元一年、69元、88元、89元和99元的都有过,但是现在整体费用上涨,入门级云服…...
Linux问题--docker启动mysql时提示3306端口被占用
问题描述: 解决方法: 1.如果需要kill掉mysqld服务可以先通过 lsof -i :3306 2. 查询到占用3306的PID,随后使用 kill -15 PID 来kill掉mysqld服务。 最后结果...
2023年中秋月饼市场趋势分析(月饼京东销售数据分析)
中秋将至,月饼作为节令食品将再次掀起消费热潮。今年月饼市场的需求如何呢,是更受欢迎还是热度有所降低,结合数据我们一起来看今年月饼市场的销售表现。 在这里,我们分别选取了2022年第31周-32周和2023年第31周-32周(…...
A Survey on Model Compression for Large Language Models
本文是LLM系列文章,关于模型压缩相关综述,针对《A Survey on Model Compression for Large Language Models》的翻译。 大模型的模型压缩综述 摘要1 引言2 方法3 度量和基准3.1 度量3.2 基准 4 挑战和未来方向5 结论 摘要 大型语言模型(LLM…...
读取/加载 properties/yml 配置文件
大家好 , 我是苏麟 , 今天带来一个简单好用的东西 . 读取/加载 properties/yml配置文件 基于PropertiesConfiguration读取配置文件 引入依赖 <!--加载yml资源--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-b…...
UG\NX二次开发 创建中心线
文章作者:里海 来源网站:王牌飞行员_里海_里海NX二次开发3000例,C\C++,Qt-CSDN博客 简介: 下面是在制图模块创建中心线的例子,用的是ufun函数。 效果: 代码: #include "me.hpp"#include <stdio.h> #include <string.h> #include <uf.h>…...
用java语言写一个网页爬虫 用于获取图片
以下是一个简单的Java程序,用于爬取网站上的图片并下载到本地文件夹: import java.io.*; import java.net.*;public class ImageSpider {public static void main(String[] args) {// 确定要爬取的网站URL和本地保存目录String url "https://www.…...
三数之和-LeetCode
给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k ,同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复的三元组。 注意:答案中不可以包含重复的三元组。 示例 1&a…...
ubuntu 对多CPU统一设置高性能模式
一、问题描述 之前在网上找到的CPU设置高性能模式,只能设置CPU0单个CPU,下述是对多核CPU统一设置工作模式。 二、软件安装与设置 执行下述命令sudo apt-get install indicator-cpufreq,然后重启电脑。此时,界面右上角会出现如下图标…...
志凌海纳 SmartX 携手灵雀云推出全栈云原生联合解决方案
近日,北京志凌海纳科技有限公司(以下简称“SmartX”)与北京凌云雀科技有限公司(以下简称“灵雀云”)联合推出全栈云原生联合解决方案,为客户提供从基础设施到容器云平台的一站式服务,加速客户云…...
如何轻松实现Cursor Pro破解:5步完整方案让AI编程助手永久免费使用
如何轻松实现Cursor Pro破解:5步完整方案让AI编程助手永久免费使用 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reac…...
Ubuntu服务器性能检测工具NetData安装
1. NetData安装 打开Ubuntu终端并输入以下指令: $ bash <(curl -Ss https://my-netdata.io/kickstart-static64.sh)中途会提示安装文件将为占用磁盘空间,是否继续(Y/N),输入Y即可,安装完成后的截图如下…...
Lindy AI Agent工作流编排进阶:从单Step到多Agent协同的6种拓扑模式(附拓扑决策树)
更多请点击: https://intelliparadigm.com 第一章:Lindy AI Agent工作流编排进阶:从单Step到多Agent协同的6种拓扑模式(附拓扑决策树) 在 Lindy 框架中,AI Agent 的工作流编排已超越传统线性 Step 链式调用…...
开源网络过滤工具librefang:DNS与代理混合部署实战指南
1. 项目概述:一个开源网络过滤与内容管理工具最近在折腾家庭网络和自建服务时,经常遇到一个核心需求:如何在不依赖商业方案或复杂硬件的前提下,对网络流量进行透明、高效且可定制的内容过滤与管理。无论是想给孩子一个更纯净的上网…...
苹果将在培训应用中采用AI生成主播,解决传统培训规模化与个性化难题
苹果培训应用引入AI生成主播据9to5mac报道,Aaron Perris在X平台披露,苹果公司将很快在其内部培训应用“Apple Sales Coach”中采用AI生成主播,用于制作销售培训视频。该应用由苹果此前的“SEED”应用更新而来,旨在向全球苹果销售合…...
STM32L4 RTC唤醒中断实战:用CubeIDE配置30秒低功耗定时,实测两种模式差异
STM32L4 RTC唤醒中断实战:用CubeIDE配置30秒低功耗定时,实测两种模式差异 在电池供电的嵌入式设备开发中,精准的周期性任务调度与极致的功耗控制往往是一对需要权衡的技术矛盾。STM32L4系列凭借其出色的低功耗特性与灵活的RTC模块,…...
极域电子教室破解终极指南:5步重获电脑控制权
极域电子教室破解终极指南:5步重获电脑控制权 【免费下载链接】JiYuTrainer 极域电子教室防控制软件, StudenMain.exe 破解 项目地址: https://gitcode.com/gh_mirrors/ji/JiYuTrainer 你是否曾在上机课时被极域电子教室的全屏广播困住,想要操作电…...
【实战指南】Ubuntu SSH服务配置与XShell/Xftp高效连接全解析
1. 为什么需要SSH远程连接Ubuntu? 作为开发者或运维人员,我们经常需要管理远程服务器。想象一下,你正在咖啡馆用Windows笔记本,突然需要紧急修改线上Ubuntu服务器的配置——这时候SSH就是你的救命稻草。它就像一把安全钥匙&#x…...
网络虚拟化如何应对100G性能挑战:从SDN/NFV到DPDK与智能网卡的演进
1. 网络虚拟化与100G浪潮:一场正在发生的架构革命如果你在2015年前后从事网络或云计算相关的工作,大概会对一个词印象深刻:100G。当时,行业媒体和厂商都在热烈讨论一个预测——到2018年,100G将成为网络设备,…...
