diff --git a/doc/tutorials/introduction/android_binary_package/android_binary_package.rst b/doc/tutorials/introduction/android_binary_package/android_binary_package.rst index bf29004ab8..58687037be 100644 --- a/doc/tutorials/introduction/android_binary_package/android_binary_package.rst +++ b/doc/tutorials/introduction/android_binary_package/android_binary_package.rst @@ -1,38 +1,259 @@ -.. _Android_Binary_Package: - -Using Android binary package with Eclipse -***************************************** - -.. include:: - -This tutorial was tested using Ubuntu 10.04 and Windows 7 SP1 operating systems. Nevertheless, it should also work on any other **OS**\ es supported by Android SDK (including Mac OS X). If you encounter errors after following the steps described here feel free to contact us via *android-opencv* disscussion group https://groups.google.com/group/android-opencv/ and we will try to fix your problem. - -.. _Android_Environment_Setup_Lite: - -Setup environment to start Android Development -============================================== - -You need the following tools to be installed: - -1. **Sun JDK 6** - - Visit http://www.oracle.com/technetwork/java/javase/downloads/index.html and download installer for your OS. - - Here is detailed JDK installation guide for Ubuntu and Mac OS: http://source.android.com/source/initializing.html (only JDK sections are applicable for OpenCV) - - .. note:: OpenJDK is not usable for Android development because Android SDK supports only Sun JDK. - -#. **Android SDK** - - Get the latest Android SDK from http://developer.android.com/sdk/index.html - - Here is Google's install guide for SDK http://developer.android.com/sdk/installing.html - - .. note:: If you choose SDK packed into Windows installer then you should have installed 32-bit JRE. It does not needed for Android development but installer is x86 application and requires 32-bit Java runtime. - - .. note:: If you are running x64 version of Ubuntu Linux then you need ia32 shared libraries for use on amd64 and ia64 systems installed. You can install them with following command: - - .. code-block:: bash - - sudo apt-get install ia32-libs - +.. _Android_Binary_Package: + +Using Android binary package with Eclipse +***************************************** + +This tutorial was tested using Ubuntu 10.04 and Windows 7 SP1 operating systems. Nevertheless, it should also work on any other **OS**\ es supported by Android SDK (including Mac OS X). If you encounter errors after following the steps described here feel free to contact us via *android-opencv* disscussion group https://groups.google.com/group/android-opencv/ and we will try to fix your problem. + +.. _Android_Environment_Setup_Lite: + +Setup environment to start Android Development +============================================== + +You need the following tools to be installed: + +#. **Sun JDK 6** + + Visit http://www.oracle.com/technetwork/java/javase/downloads/index.html and download installer for your OS. + + Here is detailed JDK installation guide for Ubuntu and Mac OS: http://source.android.com/source/initializing.html (only JDK sections are applicable for OpenCV) + + .. note:: OpenJDK is not usable for Android development because Android SDK supports only Sun JDK. + +#. **Android SDK** + + Get the latest Android SDK from http://developer.android.com/sdk/index.html + + Here is Google's install guide for SDK http://developer.android.com/sdk/installing.html + + .. note:: If you choose SDK packed into Windows installer then you should have installed 32-bit JRE. It does not needed for Android development but installer is x86 application and requires 32-bit Java runtime. + + .. note:: If you are running x64 version of Ubuntu Linux then you need ia32 shared libraries for use on amd64 and ia64 systems installed. You can install them with following command: + + .. code-block:: bash + + sudo apt-get install ia32-libs + + For Red Hat based systems the following command might be helpful: + + .. code-block:: bash + + yum install libXtst.i386 + +#. **Android SDK components** + + You need the following SDK components to be installed: + + * *Android SDK Tools, revision12* or newer + + Older revisions should also work but they are not recommended. + + * *SDK Platform Android 2.2, API 8, revision 2* (also known as *android-8*) + + This is minimal platform supported by OpenCV Java API. And it is set as default for OpenCV distribution. It is possible to use platform having higher number with OpenCV package but it requires to edit OpenCV project settings. + + .. image:: images/android_sdk_and_avd_manager.png + :height: 400px + :alt: Android SDK and AVD manager + :align: center + + See `Adding SDK Components + `_ for help with installing/updating SDK components. + +#. **Eclipse IDE** + + Check the `Android SDK System Requirements + `_ document for a list of Eclipse versions that are compatible with the Android SDK. + For OpenCV 2.3.1 we recommend Eclipse 3.7 (Indigo) or Eclipse 3.6 (Helios). They work well for OpenCV both under Windows and Linux. + + If you have no Eclipse installed, you can download it from this location: + + http://www.eclipse.org/downloads/ + +#. **ADT plugin for Eclipse** + + Assuming that you have Eclipse IDE installed, as described above, follow these steps to download and install the ADT plugin: + + #. Start Eclipse, then select **Help** > **Install New Software...** + #. Click **Add**, in the top-right corner. + #. In the Add Repository dialog that appears, enter "ADT Plugin" for the Name and the following URL for the Location: + + https://dl-ssl.google.com/android/eclipse/ + + #. 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). + + #. In the Available Software dialog, select the checkbox next to Developer Tools and click **Next**. + #. In the next window, you'll see a list of the tools to be downloaded. Click **Next**. + #. Read and accept the license agreements, then click **Finish**. + + .. note:: If you get a security warning saying that the authenticity or validity of the software can't be established, click **OK**. + + #. When the installation completes, restart Eclipse. + + These steps are copied from http://developer.android.com/sdk/eclipse-adt.html#downloading + . Please, visit that page if you have any troubles with ADT plugin installation. + +Get the OpenCV package for Android development +============================================== + +#. Go to the http://sourceforge.net/projects/opencvlibrary/files/opencv-android/ and download the latest available version. Currently it is |opencv_android_bin_pack_url|_ + +#. Create new folder for Android+OpenCV development + +#. Unpack the OpenCV package into that dir. + + You can unpack it using any popular archiver (for example with |seven_zip|_): + + .. image:: images/android_package_7zip.png + :height: 314px + :alt: Exploring OpenCV package with 7-Zip + :align: center + + On Unix you also can unpack using the following command: + + .. code-block:: bash + + tar -jxvf ~/Downloads/OpenCV-2.3.1-beta1-android-bin.tar.bz2 + + For this tutorial I have unpacked OpenCV into the :file:`C:\\Work\\android-opencv\\` directory. + +.. |opencv_android_bin_pack| replace:: OpenCV-2.3.1-beta1-android-bin.tar.bz2 +.. _opencv_android_bin_pack_url: http://sourceforge.net/projects/opencvlibrary/files/opencv-android/2.3/OpenCV-2.3.1-beta1-android-bin.tar.bz2/download +.. |opencv_android_bin_pack_url| replace:: |opencv_android_bin_pack| +.. |seven_zip| replace:: 7-Zip +.. _seven_zip: http://www.7-zip.org/ + +Open OpenCV library and samples in Eclipse +========================================== + +#. Start the *Eclipse* and choose your workspace location. + + I recommend to start familiarising yourself with OpenCV for Android from new clean workspase. So I have choosen my OpenCV package directory for new workspace: + + .. image:: images/eclipse_1_choose_workspace.png + :height: 387px + :alt: Choosing C:\Work\android-opencv\ as workspace location + :align: center + +#. Configure your ADT plugin + + Once you have created new worksapce you have to point the ADT plugin to the Android SDK directory. This setting is stored in workspace metadata so this step is required each time when you are creating new workspace for Android development. See `Configuring the ADT Plugin + `_ document for the original instructions from *Google*. + + * Select **Window > Preferences...** to open the Preferences panel (Mac OS X: **Eclipse > Preferences**): + + .. image:: images/eclipse_2_window_preferences.png + :height: 400px + :alt: Select Window > Preferences... + :align: center + + * Select **Android** from the left panel. + + You may see a dialog asking whether you want to send usage statistics to Google. If so, make your choice and click **Proceed**. You cannot continue with this procedure until you click **Proceed**. + + .. image:: images/eclipse_3_preferences_android.png + :height: 396px + :alt: Select Android from the left panel + :align: center + + * For the SDK Location in the main panel, click **Browse...** and locate your Android SDK directory. + + * Click **Apply** button at the bottom right corner of main panel: + + .. image:: images/eclipse_4_locate_sdk.png + :alt: Locate Android SDK + :align: center + + * Click **OK** to close preferences dialog. + +#. Import OpenCV and samples into workspace. + + OpenCV library is packed as ready-for-use `Android Library Project + `_. You can simply reference it in your projects. + + Each sample included into |opencv_android_bin_pack| is a regular Android project that already reference OpenCV library. + Follow next steps to import OpenCV and samples into workspace: + + * Right click on the *Package Explorer* window and choose **Import...** option from context menu: + + .. image:: images/eclipse_5_import_command.png + :height: 400px + :alt: Select Import... from context menu + :align: center + + * In the main panel select **General** > **Existing Projects into Workspace** and press **Next** buton: + + .. image:: images/eclipse_6_import_existing_projects.png + :height: 450px + :alt: General > Existing Projects into Workspace + :align: center + + * For the *Select root directory* in the main panel locate your OpenCV package folder. (If you have created workspace in the package directory then just click **Browse...** button and instantly close directory choosing dialog with **OK** button!) Eclipse should automatically locate OpenCV library and samples: + + .. image:: images/eclipse_7_select_projects.png + :alt: Locate OpenCV library and samples + :align: center + + * Click **Finish** button to complete the import operation. + + After clicking **Finish** button Eclipse will load all selected projects into workspace. And... will indicate numerous errors: + + .. image:: images/eclipse_8_false_alarm.png + :alt: Confusing Eclipce screen with numerous errors + :align: center + + However **all these errors are only false-alarms**! + + To help Eclipse to understand that there are no any errors choose OpenCV library in *Package Explorer* (left mouse click) and press **F5** button on your keyboard. Then choose any sample (except first samples in *Tutorial Base* and *Tutorial Advanced*) and also press **F5**. + + After this manipulation Eclips will rebuild your workspace and error icons will disappear one by one: + + .. image:: images/eclipse_9_errors_dissapearing.png + :alt: After small help Eclipse removes error icons! + :align: center + + Once Eclipse completes build you will have clean workspace without any build error: + + .. image:: images/eclipse_10_crystal_clean.png + :alt: OpenCV package imported into Eclipse + :align: center + + .. note:: If you are importing only OpenCV library without samples then instead of second refresh command (**F5**) you might need to make **Android Tools** > **Fix Project Properties** from project context menu. + +Running OpenCV Samples +====================== + +At this point you should be able to build and run all samples except two from Advanced tutorial (these samples require NDK to build working applications). + +Also I want to note that only ``Tutorial 1 Basic - 0. Android Camera`` and ``Tutorial 1 Basic - 1. Add OpenCV`` samples are able to run on Emulator from Android SDK. Other samples are using OpenCV Native Camera which is supported only for ARM v7 CPUs. + +.. note:: Latest *Android SDK tools, revision 12* can run ARM v7 OS images but *Google* does not provide such images within SDK. + +Well, running samples from Eclipse is very simple: + +* Connect your device with ``adb`` tool from Android SDK or create Emulator with camera support. + + * See `Managing Virtual Devices + `_ document for help with Android Emulator. + * See `Using Hardware Devices + `_ for help with phisical devices. + + +* Select project you want to start in *Package Explorer* and just press **Ctrl + F11** or select option **Run** > **Run** from main menu, or click **Run** button on the toolbar. + +* On first run Eclips will ask you how to run your application: + + .. image:: images/eclipse_11_run_as.png + :alt: Run sample as Android Application + :align: center + +* Select the *Android Application* option and click **OK** button. Eclipse will install and run the sample. + + Here is sample ``Tutorial 1 Basic - 1. Add OpenCV`` detecting edges using Canny algorithm from OpenCV: + + .. image:: images/emulator_canny.png + :height: 600px + :alt: Tutorial 1 Basic - 1. Add OpenCV - running Canny + :align: center diff --git a/doc/tutorials/introduction/android_binary_package/images/android_package_7zip.png b/doc/tutorials/introduction/android_binary_package/images/android_package_7zip.png new file mode 100644 index 0000000000..4435cc0dbd Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/android_package_7zip.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/android_sdk_and_avd_manager.png b/doc/tutorials/introduction/android_binary_package/images/android_sdk_and_avd_manager.png new file mode 100644 index 0000000000..f2bab8e236 Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/android_sdk_and_avd_manager.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/eclipse_10_crystal_clean.png b/doc/tutorials/introduction/android_binary_package/images/eclipse_10_crystal_clean.png new file mode 100644 index 0000000000..4019d72245 Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/eclipse_10_crystal_clean.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/eclipse_11_run_as.png b/doc/tutorials/introduction/android_binary_package/images/eclipse_11_run_as.png new file mode 100644 index 0000000000..2df23a0276 Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/eclipse_11_run_as.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/eclipse_1_choose_workspace.png b/doc/tutorials/introduction/android_binary_package/images/eclipse_1_choose_workspace.png new file mode 100644 index 0000000000..9850fb83c7 Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/eclipse_1_choose_workspace.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/eclipse_2_window_preferences.png b/doc/tutorials/introduction/android_binary_package/images/eclipse_2_window_preferences.png new file mode 100644 index 0000000000..acbf20d696 Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/eclipse_2_window_preferences.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/eclipse_3_preferences_android.png b/doc/tutorials/introduction/android_binary_package/images/eclipse_3_preferences_android.png new file mode 100644 index 0000000000..da8a66d2d5 Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/eclipse_3_preferences_android.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/eclipse_4_locate_sdk.png b/doc/tutorials/introduction/android_binary_package/images/eclipse_4_locate_sdk.png new file mode 100644 index 0000000000..48ed39381c Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/eclipse_4_locate_sdk.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/eclipse_5_import_command.png b/doc/tutorials/introduction/android_binary_package/images/eclipse_5_import_command.png new file mode 100644 index 0000000000..0a59a7473e Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/eclipse_5_import_command.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/eclipse_6_import_existing_projects.png b/doc/tutorials/introduction/android_binary_package/images/eclipse_6_import_existing_projects.png new file mode 100644 index 0000000000..afc0429be6 Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/eclipse_6_import_existing_projects.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/eclipse_7_select_projects.png b/doc/tutorials/introduction/android_binary_package/images/eclipse_7_select_projects.png new file mode 100644 index 0000000000..f3b4e9c153 Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/eclipse_7_select_projects.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/eclipse_8_false_alarm.png b/doc/tutorials/introduction/android_binary_package/images/eclipse_8_false_alarm.png new file mode 100644 index 0000000000..5dd864e757 Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/eclipse_8_false_alarm.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/eclipse_9_errors_dissapearing.png b/doc/tutorials/introduction/android_binary_package/images/eclipse_9_errors_dissapearing.png new file mode 100644 index 0000000000..cde9689a31 Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/eclipse_9_errors_dissapearing.png differ diff --git a/doc/tutorials/introduction/android_binary_package/images/emulator_canny.png b/doc/tutorials/introduction/android_binary_package/images/emulator_canny.png new file mode 100644 index 0000000000..2dc9d7ce9d Binary files /dev/null and b/doc/tutorials/introduction/android_binary_package/images/emulator_canny.png differ