Skip to content

This is an example of an Android app that uses OpenCV DNN module to load a Caffe model and predict an image. It implements the tutorial from http://docs.opencv.org/master/d5/de7/tutorial_dnn_googlenet.html#gsc.tab=0

Notifications You must be signed in to change notification settings

alexkarargyris/Caffe_OpenCV_Android_App

Repository files navigation

Caffe OpenCV Android App

This is an example of an Android app that uses OpenCV DNN module to load a Caffe model and predict an image. It is basically the OpenCV tutorial for DNN: http://docs.opencv.org/master/d5/de7/tutorial_dnn_googlenet.html#gsc.tab=0

NOTE: Jump to the end of this tutorial (https://github.com/alexkarargyris/Caffe_OpenCV_Android_App#c-alternative-fast-way-to-run-this-project) to kick off quickly!

##A. Prerequisites

OpenCV

Android Studio

This will install Android SDK.

##Requirements

###1. Install NDK Bundle

  • Open Android Studio and navigate Tools->Android->SDK Manager. Choose "SDK Tools" then tick "Android NDK". Finally "Apply" and hit "OK" to close. You may need to restart Android Studio. Alt text

###2. Install Android NDK

IMPORTANT: MAKE SURE THAT YOUR "Android NDK" IS ON YOUR $PATH SO THAT YOU CAN USE IT FROM ANYWHERE (e.g. bash_profile on Mac: https://github.com/9miao/CrossApp/wiki/Android-Development-Environment-Configuration-in-Mac-OS-X#2bash_profile-file-configuration)

###3. Build Android OpenCV SDK with extra modules for Android Unfortunately the Deep Neural Network (DNN) module for OpenCV is not part of the main OpenCV distribution yet.

It resides in the extra modules. So we have to build OpenCV along with extra modules. For this we need to build them together.

Here is how:

  • Open your file explorer (e.g. Finder on Mac) and navigate to /Users/alexandroskarargyris/Downloads/opencv/platforms/scripts. Replace with your own path.
  • Open cmake_android_arm.sh with a text editor (i.e. Textedit on Mac)
  • Edit it to look like this:
#!/bin/sh
cd `dirname $0`/..

mkdir -p build_android_arm
cd build_android_arm

cmake -DOPENCV_EXTRA_MODULES_PATH=/Users/alexandroskarargyris/Downloads/opencv_contrib/modules -DCMAKE_BUILD_WITH_INSTALL_RPATH=ON -DCMAKE_TOOLCHAIN_FILE=../android/android.toolchain.cmake $@ ../..

where -DOPENCV_EXTRA_MODULES_PATH= points to where the OpenCV external modules reside. So replace it with your own path. Save and exit your text editor.

  • Open terminal:
$ cd /Users/alexandroskarargyris/Downloads/opencv/platforms/
$ sh ./scripts/cmake_android_arm.sh
  • After making is finished then run:
$ cd build_android_arm
$ make install

This process will install the Android OpenCV SDK under /Users/alexandroskarargyris/Downloads/opencv/platforms/build_android_arm/install folder. That concludes the most important part: building the Android OpenCV SDK with extra modules (e.g. DNN) from source code.

##B. App Development

For this part I used the wonderful instructions from https://github.com/quanhua92/NDK_OpenCV_AndroidStudio

###1. Create OpenCV Gradle Project

  • Open Android Studio

  • Import a Project

  • Navigate to your OpenCV Android SDK location (see A.3 step above). My SDK's location is at /Users/alexandroskarargyris/Downloads/opencv/platforms/build_android_arm/install. Find SDK/java and import it

Alt text

  • Select the name (e.g. OpenCV-Java)where you want to save the new project and don't forget to build it

  • That's it. Close Project.

###2. Create our app (at last!)

  • Open Android Studio

  • Create a new project (i.e MyApplication)

  • Let's import OpenCV and its libraries: Go File->New->Import Module. Click ... in the new window and navigate to the location of your OpenCV Java project from step B.1 above.

Alt text

Then type in module name: opencv_java:

Alt text

This will import OpenCV Java to our project. Finally go to opencv-java->build.gradle to configure the file to look like below:

Alt text

  • Add the OpenCV libraries by draggin & dropping the libs folder (i.e. /Users/alexandroskarargyris/Downloads/opencv/platforms/build_android_arm/install/sdk/native/) to your project. Don't forget to rename to jniLibs. See figure below:

Alt text

  • In the project structure navigate to app->src->main->java->myapplication and add a new class (e.g. NativeClass) with the following method:
 public class NativeClass {
    public native static String getStringFromNative();
 }

Alt text

  • Open a terminal, change to app/src/main and run the following command:

javah -d jni -classpath ../../build/intermediates/classes/debug/ com.example.alexandroskarargyris.myapplication.NativeClass

This command basically creates the header file for native C/C++ to allow access to C/C++ OpenCV calls.

  • Back to Android Studio you will find a new folder jni as well as the the header: com_example_alexandroskarargyris_myapplication_NativeClass.h. Open it and you will see the following method:
JNIEXPORT jstring JNICALL Java_com_example_alexandroskarargyris_myapplication_NativeClass_getStringFromNative
        (JNIEnv * env, jobject obj);

Alt text

This is the C/C++ method that getStringFromNative() in NativeClass is going to call. So let's create a .cpp to have our C++ code for this method. For simplicity please go ahead and copy the code from the repository: https://github.com/alexkarargyris/Caffe_OpenCV_Android_App/blob/master/app/src/main/jni/com_example_alexandroskarargyris_myapplication_NativeClass.cpp This is the main code for runnning the DNN using OpenCV. You will notice that I have left many C++ calls (e.g. std::cerr <<) from the original tutorial code. The reason is to show how easy it is to migrate it to your Android project.

  • Add Android.mk file under jni folder and modify it to look like the figure below:

Alt text

It basically tells the app where to look for OpenCV, the name of the module (i.e. MyLib)

Alt text

  • Add Application.mk file under jni folder and modify it to look like the figure below:

  • Modify the app's build.gradle to look like this:

Alt text

This tells the app where to look for NDK, the JNI files, the configuration files (i.e. Android.mk) etc. It is very important.

  • Now let's go to MainActivity.java tell it load the OpenCV library and our JNI library (e.g. MyLib) by adding the following:
    static {
        System.loadLibrary("MyLib");
        System.loadLibrary("opencv_java3");
    }

Also in the figure below you can see how I call the tv.setText(NativeClass.getStringFromNative()); which in return runs NativeClass which in return runs Java_com_example_alexandroskarargyris_myapplication_NativeClass_getStringFromNative from com_example_alexandroskarargyris_myapplication_NativeClass.cpp

This will print the classifier's predicted class name in a text view I setup in activity_main.xml. But I suppose you know how to do this.

##C. Alternative (fast) way to run this project

If you reach so far and played with the above code then you learned quite a lot things. Regardless if your efforts were unsuccessful. The way to cheat this tutorial is to import it directly form Github to your Android Studio. To run it you need to have:

  1. Build OpenCV with extra modules as described in Requirements
  2. Install NDK as described in Requirements
  3. Modify Android.mk , Application.mk, build.gradle with your own file paths (see B.2)

About

This is an example of an Android app that uses OpenCV DNN module to load a Caffe model and predict an image. It implements the tutorial from http://docs.opencv.org/master/d5/de7/tutorial_dnn_googlenet.html#gsc.tab=0

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages