Android Application Programming with OpenCV Part-1
Setting Up OpenCV
This chapter is a quick guide
for setting up a development environment for Android and OpenCV. We will also
look at the OpenCV sample applications, documentation, and community.
By the end of this chapter,
our development environment will include the following components:
Java
Development Kit (JDK) 6: It includes
tools for Java programming.
Cygwin 1.7 or
greater (Windows only): It is a
compatibility layer that provides Unix-like programming tools on Windows.
Android
Software Development Kit (Android SDK) r21.0.1 or greater: It includes tools for programming Android apps in
Java.
Android Native
Development Kit (Android NDK) r8d or greater: It includes tools for programming Android apps in C++. Although this
book deals with Java programming, OpenCV also includes Android-compatible C++
samples that you may want to compile and run.
Eclipse 4.2.1
(Juno) or greater: It is an integrated
development environment (IDE).
Java
Development Tools (JDT): It is an
Eclipse plugin for Java programming (already included in most Eclipse
distributions).
C/C++
Development Tooling (CDT) 8.1.1 or greater: It is an Eclipse plugin for C/C++ programming.
Android
Development Tools (ADT) 21.0.1 or greater: It is an Eclipse plugin for Android programming.
OpenCV4Android
2.4.3.2 or greater: It includes
OpenCV's Android version, including Java and C++ libraries.
Setting
Up OpenCV
…………………………………………………………………………………..
There are many possible ways to install and configure these
components. We will cover several common setup scenarios, but if you are
interested in even more options, see OpenCV's official documentation at http://docs.opencv.org/doc/
tutorials/introduction/android_binary_package/O4A_SDK.html.
System requirements
All of the development tools
for Android and OpenCV are cross platform. The following operating systems are
supported with almost identical setup procedures:
Windows XP, Windows Vista,
Windows 7, or Windows 8
Mac OS 10.6 (Snow Leopard) or
greater
Ubuntu 10.10 (Maverick) or
greater
Many other Unix-like systems
(though not specifically covered in this book)
To run the OpenCV samples and,
later, our own application, we should have an Android device with the following
specifications:
Android 2.2 (Froyo) or greater
(required)
Camera (required); front and
rear cameras (recommended)
Autofocus (recommended)
Google Play Store
(recommended)
Android Virtual Devices (AVDs) are not recommended. Some parts of OpenCV rely on
low-level camera access and may fail with virtualized cameras.
Setting up a development environment
Basically, we have a choice
among the following approaches:
1.
Install a prepackaged,
preconfigured development environment that contains all the components we need.
Install various components
separately and configure them to work together. Within this approach, we may do
either of the following: Use a prepackaged, preconfigured version of OpenCV
Configure and build OpenCV
from source
Let's look at each of these alternatives in detail.
Getting a ready-made development environment –
Tegra Android Development Pack (TAPD)
Tegra Android Development Pack (TADP) contains
a complete, preconfigured development environment for Android, OpenCV, and some
other libraries. TADP builds apps that are optimized for NVIDIA's Tegra
processors. Despite being optimized for Tegra, the apps are compatible with
other hardware too.
If you are setting up an Android development environment from
scratch, I recommend TADP. It contains recent versions of all our required
software and its setup process is simple.
TADP also contains some
extras that we do not require for this book. For a complete list of TADP's
contents, see the official description at https://developer.nvidia.com/tegra-android-development-pack. To
set up TADP, we just need to download and install it from a secure section of
NVIDIA's website. Here are the required steps:
1.
Join
the NVIDIA Registered Developer Program at https://developer. nvidia.com/user/register. (It is free.)
2.
Log
in at https://developer.nvidia.com/user/login.
3.
Complete
your user profile at https://developer.nvidia.com/user/me/
profile/rdp_profile.
4.
Apply
to join the Tegra Registered Developer Program at https://
developer.nvidia.com/rdp/applications/tegra-registered-developer-program. (It is free, too!) Wait for NVIDIA to send you
an acceptance email. Normally, you might receive it a few minutes after
applying.
5.
Go to
https://developer.nvidia.com/tegra-resources
and find the download link
for TADP's latest version. At the time of writing, the latest version is
2.0r2. There are installers for Windows (32-bit or 64-bit), Mac, and Ubuntu
(32-bit or 64-bit). Download and run the appropriate installer.
6.
When
the installer presents the Installation Directory step, we can enter
any destination, which we will refer to as <tadp>. By
default, <tadp> is C:\NVPACK (Windows) or ~/NVPACK (Mac and Ubuntu).
1.
When
the installer presents the Installation Options step, we may select
any option: Complete, Express, or Custom. Compared to an
Express installation, a Complete or Custom installation
may include additional versions of Android SDK and binary images of Tegra
Android OS, which is NVIDIA's customization of Android. If in doubt, choose Express.
2.
When
the installer presents the Proxy Configuration step, we may leave all
fields blank unless we are using a proxy server.
3.
After
finishing all of the installer's configuration steps, wait for TADP's content
to be downloaded and installed.
That's all! Before
proceeding, let's just take a note of the locations where TADP has installed
certain components. For TADP 2.0r2 (the latest version at the time of
writing), the locations are as follows:
.
Android
SDK is located at <tadp>/android-sdk-macosx. We will refer to this location as <android_sdk>.
.
Android
NDK is located at <tadp>/android-ndk-r8d. We will refer to this location as <android_ndk>.
.
OpenCV4Android
is located at <tadp>/OpenCV-2.4.3.2-android-sdk-tadp. We will refer to this location as <opencv>.
.
Eclipse
is located at <tadp>/eclipse. We will refer to this location as <eclipse>.
Assembling a
development environment piece-by-piece
Instead of using TADP as a
ready-made solution, we may assemble our own development environment.
Broadly, this task has two stages:
Set
up a general-purpose Android development environment
Set
up OpenCV for use in this environment
Let's start by looking at the setup steps for a
general-purpose Android development environment. We will not delve into very
much detail here, because good instructions are available at the given links
and, because you, as an Android developer, have probably been through similar
steps before.
1.
If we
did not get the ADT Bundle, we now need to set up Android SDK and the ADT
plugin for Eclipse. Go to http://developer.android.com/sdk/
index.html and get the download named
Android SDK Tools. Install or unzip it to any destination, which we will
refer to as <android_sdk>. Open Eclipse and install the ADT plugin
according to the official instructions at http://developer.android.com/sdk/installing/installing-adt. html. Restart Eclipse. A window, Welcome to
Android Development, should appear. Click on Use Existing SDKs,
browse to <android_sdk>, and click on Next. Close Eclipse.
2.
If we
are using Windows, download and install Cygwin from http:// cygwin.com/install.html.
3.
Download
Android NDK from http://developer.android.com/tools/
sdk/ndk/index.html. Unzip it to any
destination, which we will refer to as <android_ndk>.
4.
Edit
your system's PATH to include <android_sdk>/platform-tools and <android_sdk>/tools. Also, create an environment variable named NDKROOT with the value as <android_ndk>. (If you are unsure how to edit PATH and other environment
variables, see Appendix A: Editing environment variables.)
Editing environment variables on Windows
The system's Path variable
and other environment variables can be edited in the Environment Variables
window of Control Panel.
On Windows Vista/7/8, open the Start menu and launch Control
Panel. Now, go to System and Security | System | Advanced
system settings. Click on the Environment Variables button.
On Windows XP, open the Start menu and go to Control Panel |
System. Click on the Advanced tab. Click on the Environment
Variables button.
Now, under System variables, select an existing
environment variable, such as Path, and
click on the Edit button. Alternatively, make a new environment
variable by clicking on the New button. Edit the variable's name and
value as needed. For example, if we want to add C:\android-sdk\platform-tools and C:\android-sdk\tools to Path, we should append ;C:\android-sdk\platform-tools;C:\android-sdk\tools
to the existing value of Path. Note the use of semicolons as separators.
To apply the changes, click on all the OK buttons until
we are back in the main window of Control Panel. Now, log out and again log
in.
Editing environment variables on Mac
Edit ~/.profile.
To append to an existing environment variable, add a line such
as export
PATH=$PATH:~/android-sdk/platform-tools:~/ android-sdk/tools.
This example appends ~/android-sdk/ platform-tools
and ~/android-sdk/tools to PATH. Note the use of colons as
separators.
To create a new environment variable, add a line such as export NDKROOT=~/android-ndk.
Save your changes, log out, and again log in.
Editing environment variables on Ubuntu
Edit ~/.pam_environment.
To append to an existing environment variable, add a line such
as PATH
DEFAULT=${PATH}:~/android-sdk/platform-tools:~/ android-sdk/tools.
This example appends ~/android-sdk/ platform-tools
and ~/android-sdk/tools to PATH.
Note the use of colons as separators.
To create a new environment variable, add a line such as NDKROOT DEFAULT=~/android-ndk.
Save your changes, log out,
and again log in.
Now, we have an Android development environment
but we still need OpenCV. We may choose to download a prebuilt version of
OpenCV or we may build it from source. These options are discussed in the
following two subsections.
Getting the
prebuilt OpenCV4Android
The prebuilt versions of
OpenCV4Android can be downloaded from http:// sourceforge.net/projects/opencvlibrary/files/opencv-android/. Look for files that have opencv-android in the name, such as OpenCV-2.4.5-android-sdk. zip (the latest version at the time of writing). Download the latest
version and unzip it to any destination, which we will refer to as <opencv>.
Building
OpenCV4Android from source
Alternatively, the process for building
OpenCV4Android from trunk (the latest, unstable source code) is
documented at http://code.opencv.org/projects/
opencv/wiki/Building_OpenCV4Android_from_trunk. For a summary of the process for building from trunk, continue
reading this section. Otherwise, skip ahead to Building the OpenCV samples
with Eclipse, later in this chapter.
CMake: It is a set of build tools. On Windows or Mac,
download and install CMake from http://www.cmake.org/cmake/resources/software.html. On Linux, install it using your package
manager. For example, on Ubuntu, open Terminal and run $ sudo apt-get install cmake.
Apache
Ant 1.8.0 or greater: It
is a set of build tools for Java. On Linux, just install Ant using your
package manager. For example, on Ubuntu, open Terminal and run $ sudo apt-get install ant. On Windows or Mac, download Ant from http://ant.apache.org/bindownload.cgi and unzip it to any destination, which we will
refer to as <ant>. Make the following changes to your environment
variables: Add <ant>/bin to PATH.
Create
a variable, ANT_HOME, with the value <ant>.
Python
2.6 or greater (but not 3.0 or greater): It is a scripting language that is used by some of the OpenCV
build scripts. An appropriate version of Python comes preinstalled on Mac and
most Linux systems, including Ubuntu. On Windows, download and install Python
from http://www.python.org/ getit/. If you have installed multiple versions of
Python on your system, ensure that an installation of Python 2.6 or greater
(but not 3.0 or greater) is the only one in Path (Windows) or PATH (Mac, Linux, or other Unix-like systems). The OpenCV build
scripts do not run properly with Python 3.0 or greater.
Once we have these
prerequisites, we may download the OpenCV source code to any location, which
we will refer to as <opencv_source>. Then, we may build it using an included script.
The steps are platform-specific, and are described as follows:
On Windows, copy <opencv>\android\scripts\wincfg.cmd.tmpl to <opencv>\ android\scripts\wincfg.cmd. Edit <opencv>\android\scripts\wincfg.cmd. The locations of several of the prerequisites
are declared in this file. Modify them so that they are correct for your
system. Save your changes. Then, open Git Bash (Git's command prompt) and run
the following commands:
$ git clone
git://code.opencv.org/opencv.git <opencv_source>
$ cd
<opencv_source>/android
$ scripts/cmake_android.cmd
$ cd build
$ make -j8
On Mac, Ubuntu, or other
Unix-like systems, open Terminal (or another command line shell) and run the
following commands:
$ git clone
git://code.opencv.org/opencv.git <opencv_source>
$ cd
<opencv_source>/android
$ sh
./scripts/cmake_android.sh
$ cd build
$ make -j8
If all goes well, we should
get a build of OpenCV4Android in <opencv_source>/
android/build. We may move it elsewhere
if we wish. We will refer to its final location as <opencv>.
Building the
OpenCV samples with Eclipse
Building and running a few
sample applications is a good way to test that OpenCV is correctly set up. At
the same time, we can practice using Eclipse.
Let's start by launching
Eclipse. The Eclipse launcher should be located at <eclipse>/eclipse.exe (Windows), <eclipse>/Eclipse.app (Mac), or <eclipse>/eclipse
(Linux). Run it.
|
It was first published,www.allitebooks.com,and theit-mela.blogspot.com
No comments:
Post a Comment