This directory contains sample apps that demonstrate how to use the Filament API in an iOS application.
iOS support for Filament is experimental. Currently, both the OpenGL ES 3.0 and Metal backends are supported. Building for the iOS simulator is also supported, but only for the OpenGL backend (Apple's simulator has no support for Metal).
Before attempting to build for iOS, read Filament's README. You must first cross-compile Filament for desktop and ARM64 on a macOS host before running the sample. The easiest way to do this is by running the following commands at the root of Filament's source tree:
$ ./build.sh -p desktop -i release # build required desktop tools (matc, resgen, etc)
$ ./build.sh -p ios -i debug # cross-compile Filament for iOS
This will automatically download Apple's iOS toolchain file for CMake and build Filament for iOS.
Afterwards, you should find all the Filament libraries inside of out/ios-debug/filament/lib/arm64
:
libfilabridge.a
libfilaflat.a
libfilament.a
libbackend.a
libutils.a
libsmol-v.a
libgeometry.a
The sample applications expect the libraries to be present here. Likewise, when building the sample
in Release mode, the linker looks for the libraries in out/ios-release/filament/lib/arm64
. To
build Filament in Release mode, replace debug
with release
in the above build.sh
command.
If you also want to be able to run on the iOS simulator, add the -s
flag to the build.sh
command. For example, the following command will build for both devices (ARM64) and the simulator
(x86_64) in Debug mode:
$ ./build.sh -s -p ios debug
When building for the simulator, the sample will then link against the libraries present in
out/ios-debug/filament/lib/x86_64
.
Open up one of the Xcode projects:
- hello-ar/hello-ar.xcodeproj
- hello-gltf/hello-gltf.xcodeproj
- hello-pbr/hello-pbr.xcodeproj
- hello-triangle/hello-triangle.xcodeproj
- transparent-rendering/transparent-rendering.xcodeproj
Each project contains two schemes, <sample> Metal
and <sample> OpenGL
, which use the Metal and
OpenGL backends respectively. Before building you will need to select one of the schemes, sign in to
your Apple developer account, select an appropriate development team in the project editor, and
change the bundle identifier to a unique name.
At this point you should be able to hit the "Run" icon to run the sample on your device. Alternatively, if you have also built Filament for the simulator, select an iPhone simulator.
Occasionally, changes in Filament's CMakeLists.txt
can require cleaning the CMake build
directories. This can be done by adding the -c
flag to the build.sh
script or by simply deleting
the out
directory.
Before reporting build errors, please try cleaning the CMake directories first and building again from scratch.
XcodeGen is used to generate the Xcode projects. While not
required to run the samples, XcodeGen makes modifying them easier. Each sample folder contains the
project.yml
file used for the sample, which includes a global app-template.yml
file. Simply run
$ xcodegen
within a sample folder to re-generate the Xcode project. You may need to close and re-open the project in Xcode to see changes take effect.