Adds support for some computer-controlled sex toys in the following games:
Title | Developer | 🥽 VR | 🖥 Desktop |
---|---|---|---|
AI-deal-Rays | Riez-ON | ✓ | |
AI Shoujo | Illusion | ✓ with AISVR | ✓ |
Custom Order Maid 3D 2 | Kiss | ✓ | ✓ |
Datsui Janken | Visionary | ✓ | |
Emotion Creators | Illusion | ✓ with EC_VR | ✓ |
Holy Knight Ricca | Mogurasoft | ✓ | |
HoneyCome & Digital Craft | Illgames | ✓ in Digital Craft | ✓ |
Honey Select | Illusion | ✓ | |
Honey Select 2 | Illusion | ✓ | ✓ |
Houkago Rinkan Chuudoku | Miconisomi | ✓ with AGHVR | ✓ |
Incubus 2: Camlann | Tanpakusitsu | ✓ | |
Insult Order | Miconisomi | ✓ with IOVR | ✓ |
Koikatsu | Illusion | ✓ | ✓ |
Koikatsu Party | Illusion | ✓ | ✓ |
Koikatsu Sunshine | Illusion | ✓ | ✓ |
Koi-Koi VR: Love Blossoms | Apricot Heart | ✓ | ✓ |
Last Evil | Flametorch | ✓ | |
Oedo Trigger | CQC Software | ✓ sold separately | ✓ |
PlayHome | Illusion | ✓ | ✓ |
RoomGirl | Illusion | ✓ | |
Secrossphere | Illusion | ✓ | |
Sexaroid Girl | Daminz | ✓ | |
Solas City Heroes | MrZGames | ✓ | |
Succubus Cafe | Migi Studio | ✓ | |
Summer In Heat | Miconisomi | ✓ | |
VR Kanojo | Illusion | ✓ | |
Writhing Play | Robi | ✓ | ✓ |
The following early access games are also supported, but compatibility with later versions of them is not guaranteed.
Title | Developer | Supported Version | Plugin |
---|---|---|---|
Our Apartment | Momoiro Software | 0.5.3.a | Available in the installer |
Melty Night VR | Cauchemar | 0.5.5 | Patreon post, or build the mnvr branch |
Orc Massage | TorchEntertainment | July 11, 2023 | Patreon post, or build the om branch |
Summer Vacation Scramble | Illgames | 1.0.0 | Free patreon post |
Sex Formula | Migi Studio | 1.3.0 | Patreon post, or build the sf branch |
Gals Collector | Studio Tris | 1.04 | Free patreon post |
VR-Kanojo | Illumination | July 31, 2025 | Patreon post, or build the vrk2 branch |
LoveMachine connects to adult toys through the Buttplug protocol, which supports over 200 devices. Among those, LoveMachine can recognize linear (moving back-and-forth), vibrating, rotating and tightening sex toys.
Some of the devices that have been confirmed to work well with the mod:
Strokers
Vibrators
- Lovense Gush
- Lovense Max 2
- Lovense Diamo
- Lovense Domi 2
- Lovense Calor
- The Xbox gamepad
Rotators
- Vorze A10 Cyclone
Oscillators⚠
ℹ️ Every supported device works with every supported game.
⚠ The Solace Pro requires some extra steps to work smoothly. In the Plugin Settings, turn on Separate Tracking Settings for the device, then set the Tracking Setting for the Oscillate feature to Disabled.
⚠ Oscillators have no positional feedback. They can't move in perfect sync with the game. Devices that can are listed under Strokers.
The LoveMachine.Experiments plugin also adds experimental support for two depth sensing devices (Lovense Calor and the Hotdog) to Koikatsu and Koikatsu Sunshine.
Download and run the installer. If you encounter the "Windows protected your PC" message, click More info > Run anyway.
Intiface Central must also be installed.
- Open Intiface Central.
- Click on the big Play button.
- Turn on the device you want to use.
- Start the game.
The Space key acts as a kill switch for all devices while in-game. To reactivate your devices, press F8. Both of these key bindings can be modified under Plugin Settings > LoveMachine > Kill Switch Settings.
⚠ In certain games, the kill switch may not work if the BepInEx console is open while playing in VR, because it can steal focus from the game window. It is recommended to disable the console.
If you need further help in using the plugin, check the Troubleshooting page or open an issue.
If you found this project useful, please give it a ⭐.
Whenever a new animation loop starts, LoveMachine records the relative positions of certain bones for one cycle, then it tries to guess which bones are the most likely to be involved in the action (e.g. a penis and a mouth). More often than not, it guesses correctly; when it doesn't, you can manually select which bone of which character to track in the Plugin Settings. You can even select a different bone for each device to reenact more complex scenes.
After one cycle of learning, the plugin translates the relative movement of the guessed/selected bones into something that the device can perform (e.g. axial movement for strokers, or rotating back-and-forth for rotators).
As the whole thing is based on bone positions, this will only work for reasonably sized and proportioned characters.
⚠ IL2CPP games (RoomGirl, Holy Knight Ricca) are not compatible with ConfigurationManager at the
moment. If you want to change the settings in those games, you can edit the configuration file
(BepInEx\config\Sauceke.LoveMachine.IL2CPP.cfg
) in Notepad.
In Plugin Settings > LoveMachine, you can set the following parameters:
- Track Animation Blending: H-Scene animations in Koikatsu and KKS shift slowly back and forth between two variants of the same animation. The two variants sometimes have different stroke patterns. This setting allows you to track both variants, which makes animation tracking more precise, but may also result in some abrupt changes mid-stroke. Turned on by default.
- POV: Which character's point of view should be simulated. Possible values:
- Balanced: Replicates relative movement. Should work for most players, most of the time.
- Male: Male bottom POV. Only replicates the female character's movements.
- Female: Female bottom POV. Only replicates the male character's movements.
This is where all your devices connected to Intiface are listed.
- Save Group Role & Body Part: If enabled, the Group Role and Body Part settings will be saved between sessions for all devices. Disabled by default.
- Show Offline Devices: Lets you access some of the settings for devices that are not connected. Settings for offline devices are shown with a red background instead of green.
- Connect: Connect or reconnect to the Intiface server.
- Scan: Scan for devices.
General device settings (all devices):
- Latency (milliseconds): Latency of sex toys is usually negligible, but if you're experiencing any noticeable delay between your display and your device, use this setting to correct it. There's no way to automatically calibrate this, so you'll have to experiment.
- Updates per second: How often to send commands to this device. BLE devices can usually handle about 10-20 commands per second.
- Separate Tracking Settings: For devices with multiple features (e.g. multi-axis strokers, vibrators that also rotate, etc.), this setting gives you fine-tuned control over each separate feature by adding a Tracking Settings section for each one. Turned off by default to keep things simple for the average user.
Tracking settings:
- Enabled: Whether this feature should be enabled at all. Turned on by default.
- Group Role: Which girl the device is assigned to in a group scene. This also affects scenes that are not group scenes, e.g. if a device is assigned to second girl, and there is only one girl in the scene, it will not be activated at all.
- Body Part: Selects the body part that will be tracked by this feature. Defaults to Auto (which means it will find the one closest to the player character's genitals). Can be used to re-enact complex TJ or FJ scenes where two body parts are rubbed against one. In Koikatsu and KKS, it also tracks fondling/fingering movements.
- Phase Shift: Gives this feature a delay that is measured in stroke cycles. For example,
0.5
means the feature will always lag half a stroke behind the animation, resulting in an inverted motion. - Axis: This feature will track the component of movement that corresponds to the selected axis, relative to the tracked penis object. What X, Y and Z means can vary for each game, so some experimenting might be necessary. "Longest" always means the axis along which the most movement occurs.
- Movement Type: Whether this feature should re-enact linear (back-and-forth) movement or rotation. If "Rotation" is selected, the feature will match the rotation around the selected Axis, while "Linear" means it will match the movement along it.
Stroker settings:
- Stroke Zone: The range of the stroking motion. 0% is the bottom, 100% is the top.
- Orgasm Shake Zone: The stroker will shake during orgasm animations. This setting controls what two positions the shaking should occur between. 0% is the bottom, 100% is the top.
- Smooth Stroking: Makes the stroking movement less robotic, but not all strokers can handle this. Known to work well on Handy and OSR2 devices. Turned off by default.
- Stroking Pattern: If Smooth Stroking is turned on, this setting lets you select the exact type of curve the stroker should move according to. Available values are Sine, Cups, Arches, Animation and Custom. "Animation" matches the exact in-game motion.
- Custom Pattern: Available if Smooth Stroking is turned on and the Stroking Pattern is set to Custom. You can set the stroking curve using the sliders; it should go up then down, starting and ending at the bottom. I'm not responsible for any injuries that may occur due to the use of LoveMachine.
Vibrator settings:
- Intensity Range: Minimum and maximum vibration intensity allowed for this device. 0% = no vibration, 100% = full strength.
- Vibration Pattern: The waveform of the vibration intensity. Available values are Sine, Triangle, Saw, Pulse, Constant, Animation, and Custom. "Animation" matches the intensity to the exact in-game motion.
- Custom Pattern: Available if Vibration Pattern is set to Custom. You can set the vibration intensity curve using the sliders.
Oscillator settings:
- RPM Range: The minimum and maximum rotations per minute this device is capable of.
Pressure settings:
- Pressure Range: Minimum and maximum pressure allowed on this device, in percentages.
- Pressure Update Interval (seconds) How much time it takes for this device to change pressure, in seconds. Defaults to 5.
- WebSocket host: The URL of the host Intiface is running on. Should be
ws://127.0.0.1
unless it's running on a remote machine. - WebSocket port: The port Intiface is listening on. Usually
12345
. - Reconnect Backoff Time (seconds): Waiting time between attempts to connect if the connection was lost or not made.
Safety measure to avoid hurting yourself if the sex gets too rough or something goes wrong. By default, pressing Spacebar will immediately stop all connected devices.
- Emergency Stop Key Binding: Sets the keystroke for activating the kill switch (Space by default).
- Resume Key Binding: Sets the keystroke for deactivating the kill switch (F8 by default).
- RPM limit: Maximum allowed rotations per minute for any device. Default is 300.
- Intensity Mode: What to decide the pressure based on.
- Cycle: Gradually increase and decrease over a fixed duration (determined by the Intensity Cycle Length).
- Stroke Length: Match to the in-game stroking length (longer strokes in game = more pressure IRL).
- Stroke Speed: Match to the in-game stroking speed (faster in game = more pressure IRL).
- Intensity Scale: How much the pressure should be affected by the Intensity Mode.
- Intensity Cycle Length (seconds): The duration of a cycle if the Intensity Mode is set to Cycle.
- Intensity Mode: What to decide the rotation speed based on.
- Cycle: Gradually increase and decrease over a fixed duration (determined by the Intensity Cycle Length).
- Stroke Length: Match to the in-game stroking length (longer strokes in game = faster IRL).
- Stroke Speed: Match to the in-game stroking speed (faster in game = faster IRL).
- Intensity Scale: How much the rotation speed should be affected by the Intensity Mode.
- Intensity Cycle Length (seconds): The duration of a cycle if the Intensity Mode is set to Cycle.
- Rotation Direction Change Chance: The direction of rotation changes with the probability of this setting. Default is 30%.
- Intensity Mode: What to decide the stroking length based on.
- Cycle: Gradually increase and decrease over a fixed duration (determined by the Intensity Cycle Length).
- Stroke Length: Match to the in-game stroking length (longer strokes in game = longer strokes IRL).
- Stroke Speed: Match to the in-game stroking speed (faster in game = longer strokes IRL).
- Intensity Scale: How much the stroking length should be affected by the Intensity Mode.
- Intensity Cycle Length (seconds): The duration of a cycle if the Intensity Mode is set to Cycle.
- Hard Sex Intensity: How fast your stroker will fall during hard sex animations. 100% is twice as fast as 0%.
- Intensity Mode: What to decide the top vibration strength based on.
- Cycle: Gradually increase and decrease over a fixed duration (determined by the Intensity Cycle Length).
- Stroke Length: Match to the in-game stroking length (longer strokes in game = more vibration IRL).
- Stroke Speed: Match to the in-game stroking speed (faster in game = more vibration IRL).
- Intensity Scale: How much the top vibration strength should be affected by the Intensity Mode.
- Intensity Cycle Length (seconds): The duration of a cycle if the Intensity Mode is set to Cycle.
PRs for onboarding new games are welcome. The process is relatively simple and requires barely any coding. See the PlayHome implementation for reference. PRs for supporting new device types are also welcome.
This mod is provided free of charge, but I do accept donations. If you'd like to boost my morale, please check me out on Patreon.
Thanks to nhydock, hogefugamoga, RPKU, and andama777 for contributing to the project, and to my Patreon members for their generous support.
This mod would not have been possible without the BepInEx plugin framework and, of course, the Buttplug.io project.