Camera Capture and Video Recorder

Demo to preview the plugin:

Introduction

This plugin lets you make screenshots and record videos on desktop and mobile devices. It supports front and back camera recording, mirroring, and custom output format selection.

Prerequisites

The device must be using a browser that supports media recorder. You can check if your browser is included here https://caniuse.com/mediarecorder
💡
To use this plugin for you and your app users and access your camera and microphone, please ensure that your browser settings allow access to these devices. You may need to check and adjust your browser's permissions for camera and microphone access. Once you've ensured the settings are configured correctly, the plugin will prompt you to grant access when needed.
‼️
MediaRecorder API used for recording videos with this plugin is not currently supported for Firefox version 124 and 125
Image without caption

How to setup

Taking Screenshots

  1. Add the CamCapture element to your page. It will show the camera preview. Resize the element to your desired size.
Image without caption
  1. Double-click the element and fill in its parameters
    1. Max file size (specifies what can be the max weight of the video you can upload to bubble)
    2. File uploads enabled (check it if you intend to upload the video to bubble after the recording is finished)
    3. Camera to use (front or back)
    4. Mirror (mirror the camera image horizontally)
    5. Turn on automatically (the browser will ask camera access permission automatically on load)
    6. Enable microphone
    7. Max video length (sec) (the recording will stop automatically when this number is reached)
    8. Preferred video extension (optional)
    9. Preferred MIME type (optional)
    10. File name (what your file will be called when you download it)
    11. Download on finish (yes / no)
  1. Add a “Take Photo” button to your page.
Image without caption
  1. Double-click the button you’ve added. And then click “Edit workflows”.
  1. In the event workflow page set the “Only when” field value to “CamCapture’s is paused is no”.
Image without caption
  1. Add the “Take picture with Cam Capture” action also from the Element Actions.
Image without caption
  1. Add a new image element to the page to display the result. Set the source of the image to “CamCapture’s Local image url”.
Image without caption
  1. Click preview and test the setup. You will be prompted to give the camera access permission. After granting the permission, click the “Take Photo” button and you should see your screenshot in the preview image element.

Recording And Saving Videos

  1. Add the Cam Capture element to your page. It will show the camera preview. Resize the element to your desired size.
Image without caption
  1. Add a “Record” and a “Stop” button to your page.
Image without caption
  1. Double-click the Record button. And then click “Edit workflows”.
  1. Set the value of the Only when field to “CamCapture’s is recording is no and CamCapture’s is saving s no”.
Image without caption
  1. Add the action “Start recording CamCapture”.
Image without caption
Image without caption
  1. Now double-click the Stop button. And then click “Edit workflows”.
  1. Set the value of the Only when field to “CamCapture is recording is yes and CamCapture is saving is no”.
Image without caption
  1. Then add a Stop recording CamCapture action to this event.
Image without caption
Image without caption
  1. Lastly, add a video player element to display the recorded video. The video player element is available as a separate plugin element inside CamCapture.
  1. Set its source to “CamCapture’s captured video”
Image without caption
  1. Test your setup. Click preview. Then hit the record button, and then the Stop button. Your recorded video should appear in the video element.

How to save videos?

Follow the instructions above to set up a video capture workflow.
Double click the CamCapture element and set the “File uploads enabled” to “yes”.
Image without caption
Now when you stop the recording the video will be saved to the Bubble data store.
If you want to track the progress of your video upload, you should display your own progress bar. One way to do this is by adding Bubble’s “Progress Bar” plugin to your page. You can then set the value of the progress bar to “Cam Capture’s upload percentage”.

Plugin Element Properties

Cam Capture

Image without caption
Fields:
Title
Description
Type
Specify max file size for videos above. To allow files > 50MB, you must set “File uploads enabled” to “yes”. Note that if you enable it, you will not see the standard progress indicator when files are uploading, and will need to display progress yourself using this element’s “upload percentage” value.
Camera to use
“front or back”. If user’s device only has one camera, it will be used regardless of this setting. You can use the “facing modes” property to access a list of supported facing modes for the current device. Available options: Front, Back
Text
Mirror
Choose whether to mirror the captured image or not
Checkbox (yes/no) (optional)
Crop
Check to crop the video according to the size of the element on the page. Use an action Zoom to change a zoom level
Checkbox (yes/no)
Turn on automatically
Request camera permission and start the camera automatically when the page loads?
Checkbox (yes/no) (optional)
Enable microphone
Enable microphone, for video recordings
Checkbox (yes/no) (optional)
Max video length (seconds)
If set, recording will stop automatically when recorded duration reaches this value in seconds.
Number (optional)
Advanced options
Preferred video file extension
The file extensions supported by the video recorder are dependent on the browser used. By default, the plugin attempts to find the best option, but if you have a preference you can set it here. It will only be used if the current browser supports it. Example format: “webm”, “mkv” (no quotes)
Text (optional)
Preferred video MIME type
The MIME types supported by the video recorder are dependent on the browser used. By default, the plugin attempts to find the best option, but if you have a preference you can set it here. It will only be used if the current browser supports it. Example formats: “video/webm”, “video/webm;codecs=vp9”, “video/x-matroska;codecs=h264” (no quotes)
Text (optional)
File name
The name of the file when downloaded / uploaded to storage
Text (optional)
Download on finish
Should the video be downloaded on stop?
Checkbox (yes/no) (optional)
Aspect ratio
Use “16:9” for a fixed aspect ratio, or “inherit” according to the plugin element’s width and height settings. Available options: inherit, 16:9
Dropdown

Element Actions

Take picture with

Turn on

Turn off

Pause

Resume

Start recording

Stop recording

Reset

EnumerateCameras

Serial shooting

Stop serial shooting

Zoom

Exposed states

Title
Description
Type
Image url
The url of the image uploaded to bubble
Image
Has camera
Returns yes if the user’s device has a camera
Checkbox (yes/no)
Is saving
Returns yes while the captured image is saving
Checkbox (yes/no)
Cam permission was denied
Returns yes if the user has denied permission to use their camera
Checkbox (yes/no)
Is paused
Returns yes while camera feed is paused
Checkbox (yes/no)
Facing modes
A list of available facing modes
Text
Started
Returns yes once the camera permission has been granted and the camera has been turned on
Checkbox (yes/no)
Recording is supported
Returns yes if the browser supports video recording
Checkbox (yes/no)
Is recording
Returns yes while recording
Checkbox (yes/no)
Upload percentage
The file upload progress percentage, if “File uploads” is enabled
Number
Element loaded
The plugin element has loaded. If the plugin is in a popup or other hidden group, it will not load until visible. Most plugin actions will not work before the element has loaded.
Checkbox (yes/no)
Image capture is supported
Returns yes if the browser supports image capture
Checkbox (yes/no)
Recorded duration (seconds)
The current duration of recorded video, in seconds
Number
Local video url
Local video url valid only in the browser
Text
VideoUrl
Url of the video saved to Bubble data store
Text
Local image url
Local image url valid only in the browser
Text
List of shots
Images from action Serial shooting
Text

Element Events

Title
Description
camera permission was denied
The user denied access to their camera
is clicked
The camera preview video was clicked
video saving started
The process of saving a video started
video saving ended
The process of saving a video ended
video can’t be uploaded
Video can’t be uploaded
video upload failed
Video upload failed due to some error
image saving started
The process of saving image started
image saving ended
The process of saving image ended
image is got (serial shooting)
Triggers after each shoot

Video Player

Image without caption
Fields:
Title
Description
Type
Video
Video file to play
File (optional)
Controls
Whether to show playback controls or not
Checkbox (yes/no)
Autoplay
Note: Autoplay is not respected by all browsers. In some browsers (e.g. Chrome 70.0) autoplay doesn’t work if the “muted” attribute is not also enabled.
Checkbox (yes/no)
Muted
Whether the video should play muted or not
Checkbox (yes/no)
Loop
Whether the video should loop or not
Checkbox (yes/no)

Additional Features

Pause / resume

Pause (freeze) the camera preview and resume it. You can take a picture while the camera is paused.

Start / stop

By default, the camera starts automatically on page load. You can disable this behaviour by unchecking the “Start automatically” box in the plugin properties and instead use the “start” action to control when to begin accessing the user’s camera. Use “stop” to stop accessing the camera, which turns off the webcam usage indicator light the device might have.

Mirror

Mirrors the camera feed and resulting image.

Front / back camera

Some devices feature both front and back cameras. You can retrieve a list of all cameras that can be used from the plugin and select which to use in the plugin properties. You can also change the camera in use dynamically using the plugin’s “Conditional” tab.

Changelogs

Update 15.10.24 - Version 1.33.0

  • Added Image format and quality fields for Take picture with and Serial shooting actions.

Update 07.10.24 - Version 1.32.0

  • Fixed video display when rotating mobile devices.

Update: 27.07.24 - Version 1.31.0

  • Added Crop checkbox
  • Added Zoom action
  • Fixed Enumerate Cameras action
  • Added recording video with mirror option

Update: 19/07/24 - Version 1.30.0

  • Fixed flickering on resize

Update: 20/06/24 - Version 1.29.0

  • Updated action ‘Reset’

Update: 19/06/24 - Version 1.28.0

  • Minor update

Update: 05/06/24 - Version 1.27.0

  • Added actions ‘Serial shooting’, ‘Stop serial shooting’

Update 05/07/2024 - Version 1.26.0

  • Fixed empty image upload in the database

Update 04/28/2024 - Version 1.25.0

  • Fixed recording size and length

Update 03/07/2024 - Version 1.24.0

  • Access camera for Firefox and event, fields fixes

Update 03/04/2024 - Version 1.23.0

  • Fixed mobile camera options, requested permissions on devices, and mirroring on the back camera

Update 12/7/2023 - Version 1.22.0

  • Updated display of content in the "Video Player" element

Update: 10/16/2023 - Version 1.16.0

  • improved - Updated description

Update: 09/18/2023 - Version 1.15.0

  • improved -Updated description

Update: 09/13/2023 - Version 1.14.0

  • improved - Updated description

Update: 09/13/2023 - Version 1.13.0

  • improved - Minor updates

Update: 06/29/2023 - Version 1.12.0

  • fixed - Added option to specify a preferred file extension and/or MIME type.

Update: 03/02/2023 - Version 1.11.1

  • fixed - Fixed an issue when starting a recording after having turned off camera could fail.

Update: 20/01/2023 - Version 1.11.0

  • fixed - Added an action to copy debug information to clipboard for error reporting.

Update: 07/09/2022 - Version 1.10.0

  • fixed - Added ability to set a custom video / audio bitrate for recordings.

Update: 07/03/2022 - Version 1.9.0

  • fixed - Added ability to get current recorded duration and set a max video length.

Update: 27/04/2022 - Version 1.8.0

  • fixed - Remove auto pausing on taking a picture. Use “pause” action along with “take a picture” instead.

Update: 27/04/2022 - Version 1.7.2

  • fixed - Fix file upload max size.

Update: 09/02/2022 - Version 1.7.1

  • fixed - Fix issue uploading files when “File uploads enabled” is on.

Update: 24/01/2022 - Version 1.7.0

  • fixed - Added video player element.

Update: 11/11/2021 - Version 1.6.3

  • fixed - Check supported constraints before constraining user media requests

Update: 11/11/2021 - Version 1.6.2

  • fixed - Handle corner case failing initialization.

Update: 11/11/2021 - Version 1.6.1

  • fixed - Fix duplicated logging

Update: 11/10/2021 - Version 1.6.0

  • fixed - Added debug feature. Fixed possible race condition when facing mode set dynamically.

Update: 11/09/2021 - Version 1.5.1

  • fixed - Fix “Started” value.

Update: 12/31/2020 - Version 1.5.0

  • fixed - Add check for image capture support.

Update: 11/16/2020 - Version 1.4.0

  • fixed - Add reset function. Minor bug fixes.

Update: 11/13/2020 - Version 1.3.0

  • fixed - Add file name option. Minor bug fixes.

Update: 10/30/2020 - Version 1.2.1

  • fixed - Fix inconsistent behavior on turning off the camera.

Update: 10/30/2020 - Version 1.2.0

  • fixed - Added video recording feature.

Update: 10/08/2020 - Version 1.1.2

  • fixed - Typo

Update: 10/06/2020 - Version 1.1.1

  • fixed - Fix enumerating facing modes on iphone.

Update: 10/06/2020 - Version 1.1.0

  • fixed - Added ability to start / stop camera.

Update: 01/12/2019 - Version 1.0.1

  • fixed - Plugin not working in groups and popups.

Update: 12/18/2018 - Version 1.0

  • Initial release
Share
Content