0026869: Documentation - simplify "Building with CMake and ADT on Android" article
ADT using removed. GNU make using added Small corrections of title and image in documentation.
@ -1,19 +1,21 @@
|
|||||||
Building with CMake and ADT for Android {#occt_dev_guides__building_android}
|
Building with CMake for Android {#occt_dev_guides__building_android}
|
||||||
===================
|
===================
|
||||||
|
|
||||||
@tableofcontents
|
@tableofcontents
|
||||||
|
|
||||||
This file describes the steps to build OCCT libraries from a complete source package
|
This article describes the steps to build OCCT libraries for Android from a complete source package
|
||||||
with following tools:
|
with GNU make (makefiles) on Windows 7 and Ubuntu 15.10.
|
||||||
- Generation of eclipse project files
|
|
||||||
- CMake v3.0+ http://www.cmake.org/cmake/resources/software.html
|
|
||||||
- Cross-compilation toolchain for CMake https://github.com/taka-no-me/android-cmake
|
|
||||||
- Android NDK rev.10+ https://developer.android.com/tools/sdk/ndk/index.html
|
|
||||||
- Make: MinGW v4.82+ for Windows, GNU Make vXX for Linux. http://sourceforge.net/projects/mingw/files/
|
|
||||||
- Building eclipse project files of OCCT
|
|
||||||
- Android Developer Tools (ADT) v22+ https://developer.android.com/sdk/index.html
|
|
||||||
|
|
||||||
## Generation of eclipse project files
|
The steps on Windows and Ubuntu are similar. There is the only one difference: makefiles are built with mingw32-make
|
||||||
|
on Windows and native GNU make on Ubuntu.
|
||||||
|
|
||||||
|
Required tools (download and install if it is required):
|
||||||
|
- CMake v3.0+ http://www.cmake.org/cmake/resources/software.html
|
||||||
|
- Cross-compilation toolchain for CMake https://github.com/taka-no-me/android-cmake
|
||||||
|
- Android NDK rev.10+ https://developer.android.com/tools/sdk/ndk/index.html
|
||||||
|
- GNU Make: MinGW v4.82+ for Windows (http://sourceforge.net/projects/mingw/files/), GNU Make 4.0 for Ubuntu.
|
||||||
|
|
||||||
|
## Generation of makefiles
|
||||||
Run GUI tool provided by CMake: cmake-gui
|
Run GUI tool provided by CMake: cmake-gui
|
||||||
|
|
||||||
### Tools configuration
|
### Tools configuration
|
||||||
@ -22,21 +24,23 @@ Run GUI tool provided by CMake: cmake-gui
|
|||||||
|
|
||||||
@figure{/dev_guides/building/android/images/android_image001.png}
|
@figure{/dev_guides/building/android/images/android_image001.png}
|
||||||
|
|
||||||
Click **Configure** button. It opens the window with a drop-down list of generators supported by CMake project. -
|
Click **Configure** button. It opens the window with a drop-down list of generators supported by CMake project.
|
||||||
|
|
||||||
Select "Eclipse CDT4 - MinGW MakeFiles" item from the list
|
Select "MinGW MakeFiles" item from the list
|
||||||
- Choose "Specify toolchain file for cross-compiling"
|
- Choose "Specify toolchain file for cross-compiling"
|
||||||
- Click "Next"
|
- Click "Next"
|
||||||
@figure{/dev_guides/building/android/images/android_image002.png}
|
@figure{/dev_guides/building/android/images/android_image002.png}
|
||||||
- Specify the Toolchain file at next dialog by android.toolchain.cmake is contained by cross-compilation toolchain for CMake
|
|
||||||
|
- Specify a toolchain file at the next dialog by android.toolchain.cmake . It is contained by cross-compilation toolchain for CMake
|
||||||
- Click "Finish"
|
- Click "Finish"
|
||||||
@figure{/dev_guides/building/android/images/android_image003.png}
|
@figure{/dev_guides/building/android/images/android_image003.png}
|
||||||
|
|
||||||
Add cache entry ANDROID_NDK - path (entry type is PATH) to the NDK folder ("Add Entry" button)
|
If ANDROID_NDK environment variable is not defined in current OS, add cache entry ANDROID_NDK (entry type is PATH) - path to the NDK folder ("Add Entry" button)
|
||||||
@figure{/dev_guides/building/android/images/android_image004.png}
|
@figure{/dev_guides/building/android/images/android_image004.png}
|
||||||
|
|
||||||
if there is message "CMake Error: CMake was unable to find a build program corresponding to "MinGW Makefiles". CMAKE_MAKE_PROGRAM is not set. You probably need to select a different build tool."
|
If on Windows the message is appeared: "CMake Error: CMake was unable to find a build program corresponding to "MinGW Makefiles"
|
||||||
Define CMAKE_MAKE_PROGRAM variable with the file path to mingw32-make executable.
|
CMAKE_MAKE_PROGRAM is not set. You probably need to select a different build tool.",
|
||||||
|
specify **CMAKE_MAKE_PROGRAM** to mingw32-make executable.
|
||||||
@figure{/dev_guides/building/android/images/android_image005.png}
|
@figure{/dev_guides/building/android/images/android_image005.png}
|
||||||
|
|
||||||
### OCCT Configuration
|
### OCCT Configuration
|
||||||
@ -45,27 +49,36 @@ How to configure OCCT, see "OCCT Configuration" section of @ref occt_dev_guides_
|
|||||||
taking into account the specific configuration variables for android:
|
taking into account the specific configuration variables for android:
|
||||||
- ANDROID_ABI = armeabi-v7a
|
- ANDROID_ABI = armeabi-v7a
|
||||||
- ANDROID_NATIVE_API_LEVEL = 15
|
- ANDROID_NATIVE_API_LEVEL = 15
|
||||||
- ANDROID_NDK_LAYOUT is equal to BUILD_CONFIGURATION variable
|
- ANDROID_NDK_LAYOUT is equal to CMAKE_BUILD_TYPE variable
|
||||||
- CMAKE_ECLIPSE_VERSION is equal to installed eclipse version (e.g., 4.2)
|
- **BUILD_MODULE_Draw = OFF**
|
||||||
|
|
||||||
Configure parallel building:
|
|
||||||
- CMAKE_ECLIPSE_MAKE_ARGUMENTS = -jN where N = your numbers of CPU cores (threads)
|
|
||||||
|
|
||||||
@figure{/dev_guides/building/android/images/android_image006.png}
|
@figure{/dev_guides/building/android/images/android_image006.png}
|
||||||
|
|
||||||
### Generation of eclipse projects files
|
### Generation of makefiles
|
||||||
|
|
||||||
Click **Generate** button and wait until the generation process is finished.
|
Click **Generate** button and wait until the generation process is finished.
|
||||||
Then the eclipse project files will appear in the build folder (e.g. <i> D:/android-build-eclipse-api-15 </i>).
|
Then makefiles will appear in the build folder (e.g. <i> D:/tmp/occt-android </i>).
|
||||||
|
|
||||||
## Building eclipse project files of OCCT
|
## Building makefiles of OCCT
|
||||||
|
|
||||||
- Open eclipse (downloaded ADT bundle contains it)
|
Open console and go to the build folder. Type "mingw32-make" (Windows) or "make" (Ubuntu) to start build process.
|
||||||
@figure{/dev_guides/building/android/images/android_image007.png}
|
|
||||||
- Import "Existing project into Workspace"
|
> mingw32-make
|
||||||
@figure{/dev_guides/building/android/images/android_image008.png}
|
or
|
||||||
@figure{/dev_guides/building/android/images/android_image009.png}
|
> make
|
||||||
- Build ALL
|
|
||||||
@figure{/dev_guides/building/android/images/android_image010.png}
|
|
||||||
|
Parallel building can be started with using **"-jN"** argument of "mingw32-make/make", where N is the number of building threads.
|
||||||
When the building process has finished, libraries are located in \<build folder\>/out (e.g. <i> D:/android-build-eclipse-api-15/out </i>).
|
|
||||||
|
> mingw32-make -j4
|
||||||
|
or
|
||||||
|
> make -j4
|
||||||
|
|
||||||
|
## Install built OCCT libraries
|
||||||
|
|
||||||
|
Type "mingw32-make/make" with argument "install" to place the libraries
|
||||||
|
to the install folder (see "OCCT Configuration" section of @ref occt_dev_guides__building_cmake "Building with CMake")
|
||||||
|
|
||||||
|
> mingw32-make install
|
||||||
|
or
|
||||||
|
> make install
|
||||||
|
Before Width: | Height: | Size: 49 KiB After Width: | Height: | Size: 57 KiB |
Before Width: | Height: | Size: 50 KiB After Width: | Height: | Size: 32 KiB |
Before Width: | Height: | Size: 62 KiB After Width: | Height: | Size: 66 KiB |
Before Width: | Height: | Size: 70 KiB After Width: | Height: | Size: 80 KiB |
Before Width: | Height: | Size: 29 KiB |
Before Width: | Height: | Size: 54 KiB |
Before Width: | Height: | Size: 56 KiB |
Before Width: | Height: | Size: 46 KiB |
@ -17,7 +17,7 @@ you need to:
|
|||||||
2. Build using your preferred build tool.
|
2. Build using your preferred build tool.
|
||||||
- \subpage occt_dev_guides__building_automake "Building on Linux with Autotools"
|
- \subpage occt_dev_guides__building_automake "Building on Linux with Autotools"
|
||||||
- \subpage occt_dev_guides__building_cmake "Building with CMake (cross-platform)"
|
- \subpage occt_dev_guides__building_cmake "Building with CMake (cross-platform)"
|
||||||
- \subpage occt_dev_guides__building_android "Building with CMake and ADT for Android (cross-platform)"
|
- \subpage occt_dev_guides__building_android "Building with CMake for Android (cross-platform)"
|
||||||
- \subpage occt_dev_guides__building_code_blocks "Building on Mac OS X with Code::Blocks"
|
- \subpage occt_dev_guides__building_code_blocks "Building on Mac OS X with Code::Blocks"
|
||||||
- \subpage occt_dev_guides__building_msvc "Building on Windows with MS Visual Studio"
|
- \subpage occt_dev_guides__building_msvc "Building on Windows with MS Visual Studio"
|
||||||
- \subpage occt_dev_guides__building_xcode "Building on Mac OS X with Xcode"
|
- \subpage occt_dev_guides__building_xcode "Building on Mac OS X with Xcode"
|
||||||
|