We strongly suggest to use the precompiled SDK versions that can be found in the Releases section
Getting all the SDK dependencies resolved and waiting for the build to complete can be very time-consuming.
Use git submodule
to resolve all source-level dependencies
git submodule update --init --remote --recursive
Special swig version (swig-2.0.11-nutiteq branch) is needed for generating language-specific wrappers, this can be downloaded from https://github.com/CartoDB/swig. Clone it and compile it using usual ./autogen.sh; ./configure; make
routine. Make sure build script refers to this one.
Python 2.7.x or Python 3.x is used for build scripts
CMake 3.14 or later is required by build scripts
Android build requires Android SDK and Android NDK r21 or later.
iOS build requires XCode 12 or later.
Universal Windows Platform build requires Visual Studio 2019.
Be patient - full build will take 1+ hours. You can speed it up by limiting architectures and platforms where it is built.
Set up boost library:
cd libs-external/boost
./bootstrap.sh
./b2 headers
cd ../..
Go to 'scripts' library where the actual build scripts are located:
cd mobile-sdk/scripts
python swigpp-java.py --profile standard
python build-android.py --profile standard
python swigpp-objc.py --profile standard
python build-ios.py --profile standard
python swigpp-csharp.py --profile standard android
python build-xamarin.py --profile standard android
python swigpp-csharp.py --profile standard ios
python build-xamarin.py --profile standard ios
python swigpp-csharp.py --profile standard winphone
python build-winphone.py --profile standard
- Developer docs: https://carto.com/docs/carto-engine/mobile-sdk/
- Android sample app: https://github.com/CartoDB/mobile-android-samples
- iOS sample app: https://github.com/CartoDB/mobile-ios-samples
- .NET (Xamarin and UWP) sample app: https://github.com/CartoDB/mobile-dotnet-samples
- Scripts for preparing offline packages: https://github.com/nutiteq/mobile-sdk-scripts
- Post an issue to this project, submit a Pull Request
- Commercial support options: [email protected]