Skip to content

VTS Model Settings

Denchi edited this page Dec 8, 2021 · 34 revisions

Basic Setup

Once you have loaded a model, you will be able to access the model settings in the VTube Studio model config tab.

At the top, you can enter a name for your model. This name will be shown in the model selection bar. Below that, you can see the name of the Live2D model file and the automatically created VTube Studio model file (VTS model).

You can choose an icon (.jpg or .png, click icon at top right to open file selection) and default idle animation (.motion3.json) for your model. You can choose from any file inside your model folder.

You can also run the auto-setup for your VTube Studio model. This will set up your model based on standard Live2D parameter names and values. For more information about these parameters, please see: https://docs.live2d.com/cubism-editor-manual/standard-parametor-list/#

If you change the parameter IDs or ranges, auto-setup will not be able to set up your model and you'll have to do it manually. Even if you use auto-setup, you may have to fine-tune your VTS model to fit your Live2D model.

Movement Config

With the "Movement Config" settings, you can move the model left/right and closer/further away from the screen based on your head position. With the sliders, you can configure how much the model is moved.

Physics Settings

Here, you can boost or reduce the effect of your Live2D physics setup. You can also activate “wind”, which will randomly apply a wind-like force to the physics system. This is experimental and may not look good depending on how your model is set up.

VTube Studio used to ignore the Live2D physics setting "Effectiveness". This has been fixed in a recent update. To turn on "Effectiveness", make sure the "Legacy Physics toggle is off.

You can also set the physics framerate for the model here. This allows you to calculate the model physics at a fixed framerate instead of the normal app framerate, which might depend on the monitor refresh rate if you're using VSync. Live2D modellers typically use a certain framerate in the physics editor window when modeling the physics, so you might want to set that same framerate here.

Please note that having this at anything other than "Match App FPS" uses multithreaded physics calculations, which is currently considered experimental. Use with caution and report any issues you have with this in the VTube Studio Discord.

VTS Parameter Setup

This is the most important part of your model settings. Here, you set up which face tracking parameters control which Live2D parameters.

The general idea is:

  • You can freely map any INPUT parameter (face-tracking, mouse, etc.) to any OUTPUT parameter (Live2D parameter).
  • How the values are mapped can be freely configured. For example, the input parameter MouthOpen is within the range [0, 1], with 0 being closed and 1 being all the way open. If your Live2D parameter (for example named ParamMouthOpen) has the range [-10, 10], you could map the ranges so (IN, 0) becomes (OUT, -10) and (IN, 1) becomes (OUT, 10). Or you map it any other way, there are no restrictions.
  • The red dot will show where the current value is placed within the input and output range.
  • By activating "Limit Range", you can make sure the the input or output values never exceed the range you set for the input or output. This will also cause the value to stop smoothly when approaching the limits.
  • Generally, it is recommended to only change the output range and leave the input range as is.
  • More smoothing will make the movements less shaky but will introduce lag. Experiment with the smoothing values until you find something that works for each parameter. On iOS, you will most likely need very little smoothing.
  • Auto-breath will fade the output parameter up and down in a breath-like motion. No input parameter is required when using this option. Any input will be ignored.
  • Auto-blink will randomly reduce the parameter to zero. This can be combined with an input parameter, but none is necessary.
  • As input parameter, you can choose from a list of available parameters. iOS supports more face tracking parameters than Android (see below).
  • As output parameter, you can choose any Live2D parameter. Each output parameter can only be chosen once, as otherwise you would have multiple input parameters writing to the same output parameter.


If your model doesn't move despite the Live2D parameter clearly moving in the VTS model config, the cause is most likely an expression, an animation or the physics system overwriting the value from the face tracking. This is explained in detail in the chapter:

Interaction between Animations, Expressions, Face Tracking, Physics, etc.

Supported INPUT parameters (face tracking, etc.)

VTube Studio currently supports the following input parameters that can be mapped to output Live2D parameters. The iOS-only parameters are also marked accordingly in the app.

Parameter Name Explanation iOS Android Webcam
FacePositionX horizontal position of face ✔️ ✔️ ✔️
FacePositionY vertical position of face ✔️ ✔️ ✔️
FacePositionZ distance from camera ✔️ ✔️ ✔️
FaceAngleX face right/left rotation ✔️ ✔️ ✔️
FaceAngleY face up/down rotation ✔️ ✔️ ✔️
FaceAngleZ face lean rotation ✔️ ✔️ ✔️
MouthSmile how much you're smiling ✔️ ✔️ ✔️
MouthOpen how open your mouth is ✔️ ✔️ ✔️
Brows up/down for both brows combined ✔️ ✔️ ✔️
MousePositionX x-pos. of mouse or finger within set range ✔️ ✔️ ✔️
MousePositionY y-pos. of mouse or finger within set range ✔️ ✔️ ✔️
TongueOut stick out your tongue ✔️
EyeOpenLeft how open your left eye is ✔️ ✔️
EyeOpenRight how open your right eye is ✔️ ✔️
EyeLeftX eye-tracking ✔️ ✔️
EyeLeftY eye-tracking ✔️ ✔️
EyeRightX eye-tracking ✔️ ✔️
EyeRightY eye-tracking ✔️ ✔️
CheekPuff detects when you puff out your cheeks ✔️
BrowLeftY up/down for left brow ✔️ ✔️
BrowRightY up/down for right brow ✔️ ✔️
VoiceFrequency* depends on detected phonemes ✔️
VoiceVolume* how loud microphone volume is ✔️
VoiceVolume
PlusMouthOpen
*
MouthOpen + VoiceVolume ✔️
VoiceFrequency
PlusMouthSmile
*
MouthSmile + VoiceFrequency ✔️
MouthX Mouth X position (shift mouth left/right) ✔️
FaceAngry detects angry face
(EXPERIMENTAL, not recommended)
✔️

* these parameters cannot be used directly on iOS/Android but will work on PC/Mac when using a smartphone for tracking. Parameters like VoiceVolumePlusMouthOpen will default to using the value from MouthOpen when the model is loaded on the smartphone.

Hotkey Settings and Types

In VTube Studio, you can use hotkeys to trigger various actions. When creating a new hotkey, it is saved in the VTube Studio model configuration file. You can give hotkeys names that are also shown in the logs when the hotkey is activated.

There are two ways to trigger hotkeys:

  • Keyboard-Hotkeys (PC/Mac only)

    • As the name implies, you can trigger hotkeys by pressing keys on your keyboard.
    • You can set combinations of up to 2 keys.
    • Keypresses are also read when the VTube Studio window is not in focus, for example when you're playing a game. However, this does not work on macOS.
    • Also included: Mouse-Hotkeys (right/left/middle click).
  • On-Screen Button Hotkeys (PC/Mac and smartphones)

    • Up to 8 hotkeys can be set as on-screen buttons. They will be shown as semi-transparent white circles on the right of the main screen (see picture 3).

    • Opacity can be changed. They can also be made invisible.

    • You can customize the color for each on-screen button.

    • If you activate "Send hotkeys to PC", pressing an on-screen hotkey on your smartphone will send a signal to your PC (if connected) that the key with that ID has been pressed. When the model you have loaded on your PC also has on-screen button hotkeys set up, the corresponding key will be triggered.

    • You do not need to have a model loaded on your smartphone to send hotkey presses to your PC. If no model is loaded, all 8 on-screen buttons will be shown.

Hotkey Actions

Various actions can be triggered by hotkeys:

  • Play Animation (.motion3.json)
    • Will play the given animation once (overwrites face tracking)
  • Change Idle Animation (.motion3.json)
    • Will change the currently looping idle animation. Will not be saved into the VTS model configuration.
  • Set/Unset Expression (.exp3.json)
    • Toggles the given expression in the model (overwrites face tracking and animations)
    • If multiple expressions set the same Live2D parameter to different values, the last expression will decide the value.
    • More on this in the chapter “Expressions”
  • Remove all Expressions
    • Removes all currently set expressions.
  • Reload Model Texture
    • Reloads the model texture. This means you can modify your model .PNG-texture outside the app and reload it on the fly. Can be used for various cool effects during streams.
  • Move Model
    • Moves the model to the given position/rotation/size.
    • You can configure a time that the movement should take.
    • The position for the hotkey can be set using the "Record Position" button, which will save the current model position, rotation and size. The numbers shown are:
      • x-pos/y-pos/size rotation
  • Change Background
    • Changes the background to the one you select for this hotkey.
  • Reload Microphone
    • Reloads the currently active microphone used for voice lipsync.
  • Calibrate Camera
    • Triggers camera calibration.
  • Change VTS Model
    • Changes the VTube Studio model to the one you select for this hotkey.
  • Take Screenshot
    • Triggers screenshot with the previously set screenshot settings.
  • Screen Overlay
    • Sets the Live2D model display overlay settings to the settings recorded in this hotkey. Will only work on Windows and macOS. For more info, see Display Light Overlay.

For animations and expressions, there are a few extra settings you can use to customize fade times and animation playback behavior. For example, you can stop animations/expressions after a certain number of seconds or once the button is let go.

For animations specifically, you can set them to stop on the last frame. This will stop the animation on the last frame once playback has finished and hold all parameters there until you press the hotkey again. All Live2D parameters used in face-tracking for your model will not be affected by this and fade back automatically after the animation has finished playing regardless.

Clone this wiki locally