MPMoCap is an open-source tool that gives you the power to do facial motion capture right in your browser, using the webcam on any mobile device or computer. You can then send the blendshape data, either locally or remotely, to another browser or popular game engines; you even have the option to broadcast the blendshape data through OSC protocol using MPMoCap's cross-platform app.
MPMoCap is under development with frequent updates. If you encounter issues, ensure you're using the latest version.
-
Facial Motion Capture... in Your Browser
MPMoCap's motion capture system was built using Mocap4face and Google mediapipe's machine learning model. No iPhone LiDAR or RGBD camera needed! The underlying ML code is not fixed and will be updated whenever there is a better model.
-
Streaming Data: Unreal and Unity Support
MPMoCap includes custom plugins that fire up WebSocket servers within Unreal Engine and Unity, which are used to receive live data from your browser. The plugins also include convenient presets that you can easily use with popular 3D avatars, such as Metahumans and ReadyPlayerMe characters.
-
Streaming Data: Browser to Browser & Browser to OSC App
MPMoCap uses WebRTC (the protocol used in video calling) to send data from one browser to another or from a browser to the app. However, no image or video is sent at all. WebRTC also allows for peer-to-peer secure connection and low latency.
-
ARKit Support
MPMoCap uses the same blendshapes as ARKit. Check out the Blendshapes page for more information about the blendshape names and orders.
Disclaimer: Ensure the browser page remains active during recording.
-
Visit the capture page and allow the website to access your camera.
-
Select the correct camera, choose the desired frame smoothing, and decide whether to use sensitive motion capture or not.
-
Select one of the two methods to send the captured data:
-
Local:
- Use MPMoCap's custom plugin to send data directly to Unreal engine or Unity using your defined URL and port.
- Check the documentation for more information.
-
Remote:
-
Click on the 8-character code starting with "p-" (e.g., p-AwCodE) to copy it.
-
To send data to another device (e.g., recording on phone and controlling avatar in Unreal on PC):
- Open the receive page on another device.
- Paste the copied 8-character code.
- You should now see live streaming data on your device and be able to share it locally.
-
To send data to the MPMoCap App for broadcasting OSC data:
- Download and install the MPMoCap App for your platform.
- Open the app and paste the 8-character code.
- The data will now be available in OSC format on your chosen port.
If everything is correctly connected but no data is showing up, try refreshing the page to generate a new code.
-
-
- Download the latest Unity file (mpmocap-unity-vx.x.x.zip) from the release page
- Unzip it and drag all the files inside your Unity Assets folder.
- Check out Example.cs for basic usage. (It's also included in the release zip.)
Check out the docs for more examples!
- Download the latest Unreal file (mpmocap-unreal-vx.x.x.zip) from the release page
- Unzip it. Copy the Plugins folder to inside your project's root folder.
- Restart Unreal. Now all the necessary modules will be automatically compiled.
Check out the docs for instant setup for metahuman and other ways for common avatars.
MPMoCap also provides apps for Windows, MacOS, and Linux. These apps can receive data from the website and send OSC data to any software on your desktop.
-
Download the latest app for your platform from the release page
-
Follow the App Installation guide to install the app. Note that Apple and Microsoft may warn you that the app is potentially unsafe if the developer hasn't paid them an annual fee. However, this is an open-source project, and all source code is available in the repository for review.
-
Enter the 8-character code starting with "p-" (e.g., p-AwCodE). If successfully connected, you should see the incoming data.
-
Enter the port for OSC data to be sent to. Now the data is available throughout your computer.
Checkout the PureData example to learn how to use the 52 blendshapes as a synthesizer.
All data follows the OSC format. There are currently 4 channels of data.
-
/mpmocap/blendshapes
A float array [52 blendshape values] ranging from 0.0~1.0. Check here for the order of blendshapes.
-
/mpmocap/headRotation
A float array [x,y,z,w] ranging from -1.0 ~ 1.0.
These are extra eye rotation roughly estimated from the eyeLookAt blendshapes. It's usually not needed since common avatar has eye rotation build in their blendshapes.
-
/mpmocap/leftEyeRotation
A float array [x,y,z,w] ranging from -1.0 ~ 1.0.
-
/mpmocap/rightEyeRotation
A float array [x,y,z,w] ranging from -1.0 ~ 1.0.
All rotations are quaternions in right-handed, Y-Up, Z-Forward coordinate system.
-
/mpmocap/version
A string of the current version of MPMoCap website.
Let us know if you are using MPMoCap! We would love to see what you are making with MPMoCap and would be delighted to showcase your work.
MPMoCap is distributed under terms of General Public License v3. Put simply, this means:
- You are free to use MPMoCap, for any purpose
- You can study how MPMoCap works and change it
- You can distribute changed versions of MPMoCap
Note that once you distribute modified version of MPMoCap, you also must publish your changes to the source code under GPLv3 as well.
The accompanying plugins of MPMoCap are released under the MIT license. Which means you can include/embedded the plugins in your Unity and Unreal projects carefree.