This developer guide takes you through the steps to enable your app to record
SceneViews to a local video file. It uses functionality
available in the
VideoRecorder class, which is available as part of the
sample starting with version 1.6.0 of the Sceneform SDK for Android.
Build and run the sample app
To build and run the VideoRecording Sample app:
- Make sure you have a Sceneform project in Android Studio, and that your Android device is connected to the development machine via USB. See the quickstart for detailed steps.
- Import the VideoRecording Sample into your project.
- In Android Studio, click Run . Then, choose your device as the deployment target and click OK to launch the sample app on your device.
- As you move your device and place 3D objects in the space around you, click the Record button to begin recording, and the Stop button to stop recording.
The recorded video will be accessible via the camera roll on the device, in a
photo album named
Sceneform or at the path:
Overview of enabling an app to support Sceneform video recording
Enabling your app to record Sceneform scenes requires:
- Requesting app permissions
- Initializing the video recorder
- Starting and stopping video recording
1. Request app permissions
In order to be able to write the video file to local storage, you app must
WRITE_EXTERNAL_STORAGE permission by adding the following line to
<application> … </application> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
2. Initialize the video recorder
The VideoRecording Sample includes a class named
encapsulates all the settings logic needed to use the
capture frames from a
SceneView object to create a video.
To use the video recorder, initialize the
class in your activity, for example in
// Create a new video recorder instance. videoRecorder = new VideoRecorder(); // Specify the AR scene view to be recorded. videoRecorder.setSceneView(arFragment.getArSceneView()); // Set video quality and recording orientation to match that of the device. int orientation = getResources().getConfiguration().orientation; videoRecorder.setVideoQuality(CamcorderProfile.QUALITY_2160P, orientation);
3. Create a video recording
To begin recording, call
// Returns true if recording has started. boolean recording = videoRecorder.onToggleRecord();
To stop recording, call
onToggleRecord()a second time:
// Returns false if recording has stopped. boolean recording = videoRecorder.onToggleRecord();
To retrieve the file path of the video recording, use
// Determine absolute file path of video recording. String videoPath = videoRecorder.getVideoPath().getAbsolutePath();
Optionally, copy the recorded file to your development machine using adb:
adb pull /sdcard/…/path/to/recorded/video.mp4 .
To determine the correct location for images and video so that they properly
show up on the camera roll, the
VideoRecord class utilizes