Skip to content

Files

samples

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
Feb 27, 2025
Apr 21, 2023
Nov 12, 2024
Aug 17, 2023
Apr 21, 2023
Apr 21, 2023
Oct 2, 2023
Apr 21, 2023
Apr 21, 2023
Apr 21, 2023
Apr 21, 2023
Oct 2, 2023
Jul 10, 2023
Sep 12, 2023

Filament sample Android apps

This directory contains several sample Android applications that demonstrate how to use the Filament APIs:

hello-triangle

Demonstrates how to setup a rendering surface for Filament:

Hello Triangle

lit-cube

Demonstrates how to create a light and a mesh with the attributes required for lighting:

Lit Cube

live-wallpaper

Demonstrates how to use Filament as renderer for an Android Live Wallpaper.

Live Wallpaper

image-based-lighting

Demonstrates how to create image-based lights and load complex meshes:

Image-based Lighting

textured-object

Demonstrates how to load and use textures for complex materials:

Textured Object

transparent-rendering

Demonstrates how to render into a transparent SurfaceView:

Transparent Rendering

texture-view

Demonstrates how to render into a TextureView instead of a SurfaceView:

Texture View

material-builder

Demonstrates how to programmatically generate Filament materials, as opposed to compiling them on the host machine:

Material Builder

gltf-viewer

Demonstrates how to load glTF models and use the camera manipulator:

glTF Viewer

hello-camera

Demonstrates how to use Stream with Android's Camera2 API:

Hello Camera

page-curl

Pure Java app that demonstrates custom vertex shader animation and two-sided texturing. Applies the deformation described in "Deforming Pages of Electronic Books" by Hong et al. Users can drag horizontally to turn the page.

Page Curl

stream-test

Tests the various ways to interact with Stream by drawing into an external texture using Canvas. See the following screenshot; if the two sets of stripes are perfectly aligned, then the Filament frame and the external texture are perfectly synchronized.

Stream Test

Prerequisites

Before you start, make sure to read Filament's README. You need to be able to compile Filament's native library and Filament's AAR for this project. The easiest way to proceed is to install all the required dependencies and to run the following commands at the root of the source tree:

./build.sh -p desktop -i release
./build.sh -p android release

This will build all the native components and the AAR required by this sample application.

If you do not use the build script, you must set the filament_tools_dir property when invoking Gradle, either from the command line or from local.properties. This property must point to the distribution/install directory for desktop (produced by make/ninja install). This directory must contain bin/matc and bin/cmgen.

Example:

./gradlew -Pfilament_tools_dir=../../dist-release assembleDebug

Important: SDK location

Either ensure your ANDROID_HOME environment variable is set or make sure the root project contains a local.properties file with the sdk.dir property pointing to your installation of the Android SDK.

Compiling

Android Studio

You must use the latest stable release of Android Studio. To open the project, point Studio to the android folder. After opening the project and syncing to gradle, select the sample of your choice using the drop-down widget in the toolbar.

To compile and run each sample make sure you have selected the appropriate build variant (arm7, arm8, x86 or x86_64). If you are not sure you can simply select the "universal" variant which includes all the other ones.

Command Line

From the android directory in the project root:

./gradlew :samples:sample-hello-triangle:installDebug

Replace sample-hello-triangle with your preferred project.