Author: Ethan Rublee
email: ethan.rublee@gmail.com
########################################################
Prerequisites:
########################################################
   android-ndk-r5b http://developer.android.com/sdk/ndk/index.html
      the official ndk with standalone toolchain
   android-cmake http://code.google.com/p/android-cmake/
      this is for the cmake toolchain for android
   mercurial
    sudo apt-get install mercurial
   cmake
   opencv (you should have this if you're reading this file :)

########################################################   
Quick NDK Setup(ubuntu and bash):
########################################################
create some working directory:
  WORK=$HOME/android_dev
  cd $WORK

now get the android-cmake project with mercurial
  hg clone https://android-cmake.googlecode.com/hg/ android-cmake

there is a convenience script in there for pulling down and setting up the
android ndk as a standalone toolchain
  cd android-cmake/scripts
  ./get_ndk_toolchain_linux.sh $WORK

add the cmake toolchain location to your bashrc or otherwise export it to your env
  echo export ANDTOOLCHAIN=$WORK/android-cmake/toolchain/android.toolchain.cmake >> $HOME/.bashrc

########################################################
Quick opencv build(ubuntu and bash):
########################################################
Make sure you either source your bashrc or otherwise export the ANDTOOLCHAIN variable.

There is a script in the android folder for running cmake with the proper cache
variables set.  It is recommended that you use this to setup a smake build directory.
  cd opencv/android
  sh ./cmake_android.sh

You should now see a build directory, that is ready to be made.
  cd build
  make -j8

That will build most of the opencv modules, except for those that don't make sense
on android - gpu, etc..

To install to the toolchain:
  make install
########################################################
Using opencv in you're cmake own projects.
########################################################
Use the cmake find script for opencv:
  find_package(OpenCV REQUIRED)
  
Then when you run cmake, use:
  cmake -DCMAKE_TOOLCHAIN_FILE=$ANDTOOLCHAIN ..

And direct your cmake cache for OpenCV_Dir to the path that you build opencv for android.
  something like : opencv/android/build

To avoid setting the cmake cache for OpenCV_Dir, you can just "install" opencv to your
android toolchain. Run the following from the opencv/android/build path:
  make install

########################################################
android targets
########################################################
You may wish to build android for multiple hardware targets.

Just change the cmake cache ARM_TARGETS to either:
 "armeabi" "armeab-v7a" "armeab-v7a with NEON"
 
You may install each of these to the toolchain, and they should be linked against
properly via way of the android-cmake toolchain.