打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
OpenCV4Android SDK

OpenCV4Android SDK?

This tutorial was designed to help you with installation and configuration of OpenCV4Android SDK.

This guide was written with MS Windows 7 in mind, though it should work with GNU Linux and AppleMac OS as well.

This tutorial assumes you have the following software installed and configured:

  • JDK

  • Android SDK and NDK

  • Eclipse IDE

  • ADT and CDT plugins for Eclipse

If you need help with anything of the above, you may refer to our Introduction into Android Development guide.

If you encounter any error after thoroughly following these steps, feel free to contact us viaOpenCV4Android discussion group orOpenCV Q&A forum. We’ll do our best to help you out.

Tegra Android Development Pack users?

You may have used Tegra Android Development Pack(TADP) released by NVIDIA for Android development environment setup.

Beside Android development tools the TADP 2.0 includes OpenCV4Android SDK, so it can be alreadyinstalled in your system and you can skip to Running OpenCV Samples section of this tutorial.

More details regarding TADP can be found in the Introduction into Android Development guide.

General info?

OpenCV4Android SDK package enables development of Android applications with use of OpenCV library.

The structure of package contents looks as follows:

OpenCV-2.4.9-android-sdk|_ apk|   |_ OpenCV_2.4.9_binary_pack_armv7a.apk|   |_ OpenCV_2.4.9_Manager_2.18_XXX.apk||_ doc|_ samples|_ sdk|    |_ etc|    |_ java|    |_ native|          |_ 3rdparty|          |_ jni|          |_ libs|               |_ armeabi|               |_ armeabi-v7a|               |_ x86||_ LICENSE|_ README.android
  • sdk folder contains OpenCV API and libraries for Android:

  • sdk/java folder contains an Android library Eclipse project providing OpenCV Java API thatcan be imported into developer’s workspace;

  • sdk/native folder contains OpenCV C++ headers (for JNI code) and native Android libraries(*.so and *.a) for ARM-v5, ARM-v7a and x86 architectures;

  • sdk/etc folder contains Haar and LBP cascades distributed with OpenCV.

  • apk folder contains Android packages that should be installed on the target Android deviceto enable OpenCV library access via OpenCV Manager API (see details below).

    On production devices that have access to Google Play Market (and Internet) these packages will beinstalled from Market on the first start of an application using OpenCV Manager API.But devkits without Market or Internet connection require this packages to be installed manually.Install the Manager.apk and optional binary_pack.apk if it needed.See How to select the proper version of OpenCV Manager for details.

    Note

    Installation from Internet is the preferable way since OpenCV team may publish updatedversions of this packages on the Market.

  • samples folder contains sample applications projects and their prebuilt packages (APK).Import them into Eclipse workspace (like described below) and browse the code to learn possibleways of OpenCV use on Android.

  • doc folder contains various OpenCV documentation in PDF format.It’s also available online at http://docs.opencv.org.

    Note

    The most recent docs (nightly build) are at http://docs.opencv.org/2.4.Generally, it’s more up-to-date, but can refer to not-yet-released functionality.

Starting from version 2.4.3 OpenCV4Android SDK uses OpenCV Manager API for libraryinitialization. OpenCV Manager is an Android service based solution providing the followingbenefits for OpenCV applications developers:

  • Compact apk-size, since all applications use the same binaries from Manager and do not storenative libs within themselves;

  • Hardware specific optimizations are automatically enabled on all supported platforms;

  • Automatic updates and bug fixes;

  • Trusted OpenCV library source. All packages with OpenCV are published on Google Play;

For additional information on OpenCV Manager see the:

Manual OpenCV4Android SDK setup?

Get the OpenCV4Android SDK?

  1. Go to the OpenCV download page on SourceForgeand download the latest available version. Currently it’s OpenCV-2.4.9-android-sdk.zip.

  2. Create a new folder for Android with OpenCV development. For this tutorial we have unpackedOpenCV SDK to the C:\Work\OpenCV4Android\ directory.

    Note

    Better to use a path without spaces in it. Otherwise you may have problems with ndk-build.

  3. Unpack the SDK archive into the chosen directory.

    You can unpack it using any popular archiver (e.g with 7-Zip):

    On Unix you can use the following command:

    unzip ~/Downloads/OpenCV-2.4.9-android-sdk.zip

Import OpenCV library and samples to the Eclipse?

  1. Start Eclipse and choose your workspace location.

    We recommend to start working with OpenCV for Android from a new clean workspace. A new Eclipseworkspace can for example be created in the folder where you have unpacked OpenCV4Android SDK package:

  2. Import OpenCV library and samples into workspace.

    OpenCV library is packed as a ready-for-use Android Library Project.You can simply reference it in your projects.

    Each sample included into the OpenCV-2.4.9-android-sdk.zip is a regular Android project that alreadyreferences OpenCV library. Follow the steps below to import OpenCV and samples into the workspace:

    Note

    OpenCV samples are indeed dependent on OpenCV library project so don’t forget to import it to your workspace as well.

    • Right click on the Package Explorer window and choose Import... optionfrom the context menu:

    • In the main panel select General ? Existing Projects into Workspace andpress Next button:

    • In the Select root directory field locate your OpenCV package folder. Eclipseshould automatically locate OpenCV library and samples:

    • Click Finish button to complete the import operation.

    After clicking Finish button Eclipse will load all selected projects into workspace,and you have to wait some time while it is building OpenCV samples. Just give a minute toEclipse to complete initialization.

    Warning

    After the initial import, on a non-Windows (Linux and Mac OS) operating system Eclipsewill still show build errors for applications with native C++ code. To resolve theissues, please do the following:

    Open Project Properties -> C/C++ Build, and replace “Build command” textto "${NDKROOT}/ndk-build" (remove .cmd at the end).

    Note

    In some cases the build errors don’t disappear, then try the following actions:

    • right click on OpenCV Library project -> Android Tools -> Fix Project Properties,then menu Project -> Clean... -> Clean all
    • right click on the project with errors -> Properties -> Android, make sure theTarget is selected and is Android 3.0 or higher
    • check the build errors in the Problems view window and try to resolve them by yourselves

    Once Eclipse completes build you will have the clean workspace without any build errors:

Running OpenCV Samples?

At this point you should be able to build and run the samples. Keep in mind, thatface-detection and Tutorial 2 - Mixed Processing include some native code andrequire Android NDK and NDK/CDT plugin for Eclipse to build working applications. If you haven’tinstalled these tools, see the corresponding section of Introduction into Android Development.

Warning

Please consider that some samples use Android Java Camera API, which is accessiblewith an AVD. But most of samples use OpenCV Native Camera which may not work withan emulator.

Note

Recent Android SDK tools, revision 19+ can run ARM v7a OS images but they available notfor all Android versions.

Well, running samples from Eclipse is very simple:

  • Connect your device with adb tool from Android SDK or create an emulator with camera support.

  • Select project you want to start in Package Explorer and just press Ctrl + F11or select option Run ? Run from the main menu, or click Run button on the toolbar.

    Note

    Android Emulator can take several minutes to start. So, please, be patient.

  • On the first run Eclipse will ask you about the running mode for your application:

  • Select the Android Application option and click OK button. Eclipse will install and run the sample.

    Chances are that on the first launch you will not have the OpenCV Manager package installed.In this case you will see the following message:

    To get rid of the message you will need to install OpenCV Manager and the appropriate OpenCV binary pack.Simply tap Yes if you have Google Play Market installed on your device/emulator. It will redirect you to the corresponding page on Google Play Market.

    If you have no access to the Market, which is often the case with emulators - you will need to install the packages from OpenCV4Android SDK folder manually. See How to select the proper version of OpenCV Manager for details.

    1
    <Android SDK path>/platform-tools/adb install <OpenCV4Android SDK path>/apk/OpenCV_2.4.9_Manager_2.18_armv7a-neon.apk

    Note

    armeabi, armv7a-neon, arm7a-neon-android8, mips and x86 stand forplatform targets:

    • armeabi is for ARM v5 and ARM v6 architectures with Android API 8+,
    • armv7a-neon is for NEON-optimized ARM v7 with Android API 9+,
    • arm7a-neon-android8 is for NEON-optimized ARM v7 with Android API 8,
    • mips is for MIPS architecture with Android API 9+,
    • x86 is for Intel x86 CPUs with Android API 9+.

    If using hardware device for testing/debugging, run the following command to learnits CPU architecture:

    adb shell getprop ro.product.cpu.abi

    If you’re using an AVD emulator, go Window > AVD Manager to see thelist of availible devices. Click Edit in the context menu of theselected device. In the window, which then pop-ups, find the CPU field.

    You may also see section How to select the proper version of OpenCV Manager for details.

    When done, you will be able to run OpenCV samples on your device/emulator seamlessly.

  • Here is Sample - image-manipulations sample, running on top of stock camera-preview of the emulator.

What’s next?

Now, when you have your instance of OpenCV4Adroid SDK set up and configured,you may want to proceed to using OpenCV in your own application.You can learn how to do that in a separate Android Development with OpenCV tutorial.

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Using Android binary package with Eclipse
ADT Plugin for Eclipse
Summer of Code Scala Projects
Embedded software development using Eclipse and FreeRTOS.org
Eclipse开发Android手机定位
Android SDK 开发环境配置及运行
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服