打开APP
userphoto
未登录

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

开通VIP
Introduction into Android Development

Introduction into Android Development?

This guide was designed to help you in learning Android development basics and seting up yourworking environment quickly. It was written with Windows 7 in mind, though it would work with Linux(Ubuntu), Mac OS X and any other OS supported by Android SDK.

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.

Preface?

Android is a Linux-based, open source mobile operating system developed by Open Handset Allianceled by Google. See the Android home site for general details.

Development for Android significantly differs from development for other platforms.So before starting programming for Android we recommend you make sure that you are familiar with thefollowing key topis:

  1. Java programming language that isthe primary development technology for Android OS. Also, you can findOracle docs on Java useful.
  2. Java Native Interface (JNI) that is atechnology of running native code in Java virtual machine. Also, you can findOracle docs on JNI useful.
  3. Android Activityand its lifecycle, that is an essential Android API class.
  4. OpenCV development will certainly require some knowlege of theAndroid Camera specifics.

Quick environment setup for Android development?

If you are making a clean environment install, then you can try Tegra Android Development Pack(TADP) released by NVIDIA.

Note

Starting the version 2.0 the TADP package includes OpenCV for Tegra SDK that is a regular OpenCV4Android SDK extended with Tegra-specific stuff.

When unpacked, TADP will cover all of the environment setup automatically and you can skip the rest of the guide.

If you are a beginner in Android development then we also recommend you to start with TADP.

Note

NVIDIA‘s Tegra Android Development Pack includes some special features forNVIDIA’s Tegra platform but its use is not limited to Tegra devices only.

  • You need at least 1.6 Gb free disk space for the install.

  • TADP will download Android SDK platforms and Android NDK from Google’s server, so Internetconnection is required for the installation.

  • TADP may ask you to flash your development kit at the end of installation process. Just skipthis step if you have no Tegra Development Kit.

  • (UNIX) TADP will ask you for root in the middle of installation, so you need to be amember of sudo group.

Manual environment setup for Android development?

Development in Java?

You need the following software to be installed in order to develop for Android in Java:

  1. Sun JDK 6 (Sun JDK 7 is also possible)

    Visit Java SE Downloads pageand download an installer for your OS.

    Here is a detailed JDKinstallation guidefor Ubuntu and Mac OS (only JDK sections are applicable for OpenCV)

    Note

    OpenJDK is not suitable for Android development, since Android SDK supports only Sun JDK.If you use Ubuntu, after installation of Sun JDK you should run the following command to setSun java environment:

    sudo update-java-alternatives --set java-6-sun
  2. Android SDK

    Get the latest Android SDK from http://developer.android.com/sdk/index.html

    Here is Google’s install guide for the SDK.

    Note

    You can choose downloading ADT Bundle package that in addition to Android SDK Tools includesEclipse + ADT + NDK/CDT plugins, Android Platform-tools, the latest Android platform and the latestAndroid system image for the emulator - this is the best choice for those who is setting up Androiddevelopment environment the first time!

    Note

    If you are running x64 version of Ubuntu Linux, then you need ia32 shared librariesfor use on amd64 and ia64 systems to be installed. You can install them with thefollowing command:

    sudo apt-get install ia32-libs

    For Red Hat based systems the following command might be helpful:

    sudo yum install libXtst.i386
  3. Android SDK components

    You need the following SDK components to be installed:

    • Android SDK Tools, revision 20 or newer.

      Older revisions should also work, but they are not recommended.

    • SDK Platform Android 3.0 (API 11).

      The minimal platform supported by OpenCV Java API is Android 2.2 (API 8). This is alsothe minimum API Level required for the provided samples to run.See the <uses-sdk android:minSdkVersion="8"/> tag in their AndroidManifest.xml files.But for successful compilation the target platform should be set to Android 3.0 (API 11) or higher. It will not prevent them from running on Android 2.2.

      See Adding Platforms and Packagesfor help with installing/updating SDK components.

  4. Eclipse IDE

    Check the Android SDK System Requirementsdocument for a list of Eclipse versions that are compatible with the Android SDK.For OpenCV 2.4.x we recommend Eclipse 3.7 (Indigo) or Eclipse 4.2 (Juno). They work well forOpenCV under both Windows and Linux.

    If you have no Eclipse installed, you can get it from the official site.

  5. ADT plugin for Eclipse

    These instructions are copied fromAndroid Developers site,check it out in case of any ADT-related problem.

    Assuming that you have Eclipse IDE installed, as described above, follow these steps to downloadand install the ADT plugin:

    1. Start Eclipse, then select Help ? Install New Software...

    2. Click Add (in the top-right corner).

    3. In the Add Repository dialog that appears, enter “ADT Plugin” for the Name and thefollowing URL for the Location:

      https://dl-ssl.google.com/android/eclipse/

    4. Click OK

      Note

      If you have trouble acquiring the plugin, try using “http” in the Location URL,instead of “https” (https is preferred for security reasons).

    5. In the Available Software dialog, select the checkbox next toDeveloper Tools and click Next.

    6. In the next window, you’ll see a list of the tools to be downloaded. Click Next.

      Note

      If you also plan to develop native C++ code with Android NDK don’t forget toenable NDK Plugins installations as well.

    7. Read and accept the license agreements, then click Finish.

      Note

      If you get a security warning saying that the authenticity or validity of the softwarecan’t be established, click OK.

    8. When the installation completes, restart Eclipse.

Native development in C++?

You need the following software to be installed in order to develop for Android in C++:

  1. Android NDK

    To compile C++ code for Android platform you need Android Native Development Kit (NDK).

    You can get the latest version of NDK from thedownload page.To install Android NDK just extract the archive to some folder on your computer. Here areinstallation instructions.

    Note

    Before start you can read official Android NDK documentation which is in the AndroidNDK archive, in the folder docs/.The main article about using Android NDK build system is in the ANDROID-MK.html file.Some additional information you can find inthe APPLICATION-MK.html, NDK-BUILD.html files,and CPU-ARM-NEON.html, CPLUSPLUS-SUPPORT.html, PREBUILTS.html.

  2. CDT plugin for Eclipse

    If you selected for installation the NDK plugins component of Eclipse ADT plugin (see the picture above) your Eclipse IDEshould already have CDT plugin (that means C/C++ Development Tooling).There are several possible ways to integrate compilation of C++ code by Android NDK into Eclipsecompilation process. We recommend the approach based on EclipseCDT Builder.

Android application structure?

Usually source code of an Android application has the following structure:

  • root folder of the project/
    • jni/
    • libs/
    • res/
    • src/
    • AndroidManifest.xml
    • project.properties
    • ... other files ...

Where:

  • the src folder contains Java code of the application,

  • the res folder contains resources of the application (images, xml files describing UIlayout, etc),

  • the libs folder will contain native libraries after a successful build,

  • and the jni folder contains C/C++ application source code and NDK’s build scriptsAndroid.mk and Application.mk producing the native libraries,

  • AndroidManifest.xml file presents essential information about application to the Androidsystem (name of the Application, name of main application’s package, components of theapplication, required permissions, etc).

    It can be created using Eclipse wizard or android tool from Android SDK.

  • project.properties is a text file containing information about target Android platformand other build details. This file is generated by Eclipse or can be created withandroid tool included in Android SDK.

Note

Both AndroidManifest.xml and project.properties files are required tocompile the C++ part of the application, since Android NDK build system relies on them.If any of these files does not exist, compile the Java part of the project before the C++ part.

Android.mk and Application.mk scripts?

The script Android.mk usually has the following structure:

 1 2 3 4 5 6 7 8 910
LOCAL_PATH := $(call my-dir)include $(CLEAR_VARS)LOCAL_MODULE    := <module_name>LOCAL_SRC_FILES := <list of .c and .cpp project files><some variable name> := <some variable value>...<some variable name> := <some variable value>include $(BUILD_SHARED_LIBRARY)

This is the minimal file Android.mk, which builds C++ source code of an Android application.Note that the first two lines and the last line are mandatory for any Android.mk.

Usually the file Application.mk is optional, but in case of project using OpenCV, when STLand exceptions are used in C++, it also should be created. Example of the file Application.mk:

123
APP_STL := gnustl_staticAPP_CPPFLAGS := -frtti -fexceptionsAPP_ABI := all

Note

We recommend setting APP_ABI := all for all targets. If you want to specify thetarget explicitly, use armeabi for ARMv5/ARMv6, armeabi-v7a for ARMv7, x86for Intel Atom or mips for MIPS.

Building application native part from command line?

Here is the standard way to compile C++ part of an Android application:

Warning

We strongly reccomend using cmd.exe (standard Windows console) instead of Cygwin onWindows. Use the latter if only you’re absolutely sure about, what you’re doing. Cygwinis not really supported and we are unlikely to help you in case you encounter someproblems with it. So, use it only if you’re capable of handling the consequences yourself.

  1. Open console and go to the root folder of an Android application

    cd <root folder of the project>/
  2. Run the following command

    <path_where_NDK_is_placed>/ndk-build

    Note

    On Windows we recommend to use ndk-build.cmd in standard Windows console (cmd.exe)rather than the similar bash script in Cygwin shell.

  3. After executing this command the C++ part of the source code is compiled.

After that the Java part of the application can be (re)compiled (using either Eclipse or Ant build tool).

Note

Some parameters can be set for the ndk-build:

Example 1: Verbose compilation

<path_where_NDK_is_placed>/ndk-build V=1

Example 2: Rebuild all

<path_where_NDK_is_placed>/ndk-build -B

Building application native part from Eclipse (CDT Builder)?

There are several possible ways to integrate compilation of native C++ code by Android NDK intoEclipse build process. We recommend the approach based on EclipseCDT Builder.

Important

OpenCV for Android package since version 2.4.2 contains sample projectspre-configured CDT Builders. For your own projects follow the steps below.

  1. Define the NDKROOT environment variable containing the path to Android NDK in your system(e.g. "X:\\Apps\\android-ndk-r8" or "/opt/android-ndk-r8").

    On Windows an environment variable can be set viaMy Computer -> Properties -> Advanced -> Environment variables.On Windows 7 it’s also possible to use setx command in a console session.

    On Linux and MacOS an environment variable can be set via appending a"export VAR_NAME=VAR_VALUE" line to the "~/.bashrc" file and logging off and then on.

    Note

    It’s also possible to define the NDKROOT environment variable within Eclipse IDE,but it should be done for every new workspace you create. If you prefer this option better than setting systemenvironment variable, open Eclipse menu Window -> Preferences -> C/C++ -> Build -> Environment,press the Add... button and set variable name to NDKROOT and value to local Android NDK path.

  2. After that you need to restart Eclipse to apply the changes.

  3. Open Eclipse and load the Android app project to configure.

  4. Add C/C++ Nature to the project via Eclipse menu New -> Other -> C/C++ -> Convert to a C/C++ Project.

    And:

  5. Select the project(s) to convert. Specify “Project type” = Makefile project,“Toolchains” = Other Toolchain.

  6. Open Project Properties -> C/C++ Build, uncheck Use default build command,replace “Build command” text from "make" to

    "${NDKROOT}/ndk-build.cmd" on Windows,

    "${NDKROOT}/ndk-build" on Linux and MacOS.

  7. Go to Behaviour tab and change “Workbench build type” section like shown below:

  8. Press OK and make sure the ndk-build is successfully invoked when building the project.

  9. If you open your C++ source file in Eclipse editor, you’ll see syntax error notifications.They are not real errors, but additional CDT configuring is required.

  10. Open Project Properties -> C/C++ General -> Paths and Symbols and add the followingInclude paths for C++:

    # for NDK r8 and prior:${NDKROOT}/platforms/android-9/arch-arm/usr/include${NDKROOT}/sources/cxx-stl/gnu-libstdc++/include${NDKROOT}/sources/cxx-stl/gnu-libstdc++/libs/armeabi-v7a/include${ProjDirPath}/../../sdk/native/jni/include
    # for NDK r8b and later:${NDKROOT}/platforms/android-9/arch-arm/usr/include${NDKROOT}/sources/cxx-stl/gnu-libstdc++/4.6/include${NDKROOT}/sources/cxx-stl/gnu-libstdc++/4.6/libs/armeabi-v7a/include${ProjDirPath}/../../sdk/native/jni/include

    The last path should be changed to the correct absolute or relative path to OpenCV4Android SDK location.

    This should clear the syntax error notifications in Eclipse C++ editor.

Debugging and Testing?

In this section we will give you some easy-to-follow instructions on how to set up an emulator orhardware device for testing and debugging an Android project.

AVD?

AVD (Android Virtual Device) is not probably the most convenient way to test an OpenCV-dependentapplication, but sure the most uncomplicated one to configure.

  1. Assuming you already have Android SDK and Eclipse IDE installed, in Eclipse goWindow -> AVD Manager.

  2. Press the New button in AVD Manager window.

  3. Create new Android Virtual Device window will let you select some properties for yournew device, like target API level, size of SD-card and other.

  4. When you click the Create AVD button, your new AVD will be availible in AVD Manager.

  5. Press Start to launch the device. Be aware that any AVD (a.k.a. Emulator) is usuallymuch slower than a hardware Android device, so it may take up to several minutes to start.

  6. Go Run -> Run/Debug in Eclipse IDE to run your application in regular or debuggingmode. Device Chooser will let you choose among the running devices or to start a new one.

Hardware Device?

If you have an Android device, you can use it to test and debug your applications. This way is moreauthentic, though a little bit harder to set up. You need to make some actions for Windows and Linuxoperating systems to be able to work with Android devices. No extra actions are required for Mac OS.See detailed information on configuring hardware devices in subsections below.

You may also consult the officialAndroid Developers site instructionsfor more information.

Windows host computer?

  1. Enable USB debugging on the Android device (via Settings menu).

  2. Attach the Android device to your PC with a USB cable.

  3. Go to Start Menu and right-click on Computer.Select Manage in the context menu. You may be asked for Administrative permissions.

  4. Select Device Manager in the left pane and find an unknown device in the list.You may try unplugging it and then plugging back in order to check whether it’s your exactequipment appears in the list.

  5. Try your luck installing Google USB drivers without any modifications: right-click on theunknown device, select Properties menu item –> Details tab –>Update Driver button.

  6. Select Browse computer for driver software.

  7. Specify the path to <Android SDK folder>/extras/google/usb_driver/ folder.

  8. If you get the prompt to install unverified drivers and report about success - you’ve finishedwith USB driver installation.

    ` `
  9. Otherwise (getting the failure like shown below) follow the next steps.

  10. Again right-click on the unknown device, select Properties –> Details –> Hardware Idsand copy the line like USB\VID_XXXX&PID_XXXX&MI_XX.

  11. Now open file <Android SDK folder>/extras/google/usb_driver/android_winusb.inf. Selecteither Google.NTx86 or Google.NTamd64 section depending on your host system architecture.

  12. There should be a record like existing ones for your device and you need to add one manually.

  13. Save the android_winusb.inf file and try to install the USB driver again.

    ` `

    ` `

  14. This time installation should go successfully.

    ` `

  15. And an unknown device is now recognized as an Android phone.

  16. Successful device USB connection can be verified in console via adb devices command.

  17. Now, in Eclipse go Run -> Run/Debug to run your application in regular or debuggingmode. Device Chooser will let you choose among the devices.

Linux host computer?

By default Linux doesn’t recognize Android devices, but it’s easy to fix this issue. On Ubuntu Linuxyou have to create a new /etc/udev/rules.d/51-android.rules configuration file that containsinformation about your Android device. You may find some Vendor ID’shere or execute lsusbcommand to view VendorID of plugged Android device. Here is an example of such file for LG device:

SUBSYSTEM=="usb", ATTR{idVendor}=="1004",  MODE="0666", GROUP="plugdev"

Then restart your adb server (even better to restart the system), plug in your Android device andexecute adb devices command. You will see the list of attached devices:

Mac OS host computer?

No actions are required, just connect your device via USB and run adb devices to check connection.

What’s next?

Now, when you have your development environment set up and configured, you may want to proceed toinstalling OpenCV4Android SDK. You can learn how to do that in a separate OpenCV4Android SDK tutorial.

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
Android SDK 开发环境配置及运行
An Introduction to Virtualization
Android Security Overview | Android Open Sour...
linux下java开发环境安装
安装Android sdk jdk Eclipse Adt开发工具
RIM's BlackBerry
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服