Skip to content

Latest commit

 

History

History
197 lines (141 loc) · 7.76 KB

README.md

File metadata and controls

197 lines (141 loc) · 7.76 KB

Low cost sprite based V-Tubing

A lightweight Sprite based VTube environment, that you can control with Stream Deck or Websocket requests.

If you like the content, consider buying me a ☕.

Windows version

If you don't want to fiddle with any of the manual parts, here is a Windows version you can just download and use.

Command line version (NodeJS)

Requirements

Instalation/Usage

First, install the required Node dependencies in the project folder:
npm i ws express express-es6-template-engine skia-canvas

Then, run the main script:
node app.js

Making it visible on OBS

Simply add the http://127.0.0.1:3000/ address as OBS Browser source.
That's all.

Using with Stream Deck

Stream Deck Intallation

Just double click the .streamDeckPlugin file and accept the installation.

Stream Deck Usage

Just pick an action and follow the instructions.
If you didn't change the default port, you should have little to no work with each action.

sd-spritetube-1.png

sd-spritetube-2.png

Using with Touch Portal

Touch Portal Intallation

Install the .tpp file from the menu:

tp-install.png

Touch Portal Usage

Just pick an action and follow the instructions.
If you didn't change the default port (under settings -> plugins -> SpriteTube), you should have little to no work with each action.

tp-action-frame.png

tp-action-name.png

Touch Portal events (and creating a preview)

You can use the When the plug-in state (under Values) event to track the current frame.
You can also use the Change the visuals by plug-in state (under Visuals) action to actually show the current frame.

tp-event.png

Available commands

  • Use flip, unflip and toggleflip as commands to (un)flip the frame.
  • Use first to jump to the first frame.
  • Use last to jump to the last frame.
  • Use random to jump to a random frame.
  • Use hide to hide the avatar.
  • Use show to show the avatar.
  • Any invalid command or innexistent frame number will remove the sprite from screen.

Character editor

By opening the http://127.0.0.1:3000/editor.html URL (after starting the server) or by opening the APP, you'll find a character editor.

editor-1.png

These are the currently available actions:

  • Party mode (see characters from friends).
  • Upload a new spritesheet.
  • Move the spritesheet (drag and drop).
  • Snapshot a frame.
  • Snapshot an icon.
  • Edit a frame.
  • Delete a frame.
  • Reorganize frames (drag and drop).
  • Click sprites in the timeline to quickly navigate and preview.
  • Toggle the timeline.
  • Save (replaces your current frames.json file, but makes a backup once a day inside the backups folder).
  • Preview.

FAQ

Q: Why do you use WebSockets?
A: It's faster and simpler.

Q: Are you going to improve this project?
A: Yes.

Q: Your demo has a white background on my OBS!
A: Yes. I'm lazy and didn't bother finding a demo sheet without background.

Q: Your demo has more frames than the three you mapped!
A: I. Am. LAZY!

Q: I already use the 3000 port for something else. Can I change the script?
A: Yes.

Q: Can I change the script in general?
A: Yes. But I'd appreciate if you shared your customization with everyone else. And give credits.

Q: I see a lot of unused code. Are you adding new stuff?
A: Yes. I may send commits with placeholder code I am working on.

Q: Can I have a copy of the party server?
A: Sure. Just ask me on Twitter.

Q: Can I message you if I have issues or suggestions?
A: Sure. You can open an issue here, or message me on Discord or Twitter.

Credits

Known bugs

  • One to two pixels as margin error are randomly added/removed when saving from the editor. That means you need to fiddle with positions, till you get the perfect frame.
  • The sprite frame actually working flawless (despite the item above) in the player is actually a bug.

Todo

  • ⬜ Support for small movement when microphone is detected.
  • ⬜ Support for loop through predefined frames when microphone is detected.
  • ⬜ Support for second set of frames for mouth movement when microphone is detected.
  • ⬜ Support for idle set of frames.
  • 🟥 (Removed - Too Buggy) Zoom in and out with mouse scroll wheel.
  • ✅ (1.1.1) Touch Portal plugin.
  • ✅ (1.1) Party mode (be able to see someone else's character and frames).
  • ✅ (0.3.0) Remove load from the player (make server send a base64 encoded image ready to use).
  • ✅ (0.3.0) Sincronize all players in general.
  • ✅ (0.3.0) Make "random" syncronize with all players.
  • ✅ (APP) Backup download and upload.
  • ✅ (Pre 0.3.0) Hold SHIFT to move the shpritesheet in bigger intervals. Add CTRL for even mode distance.
  • ✅ (Pre 0.3.0) Frame info button.
  • ✅ (Pre 0.3.0) Code cleanup.
  • ✅ (Pre 0.3.0) Make replacing a frame in the editor less annoying.
  • ✅ (Pre 0.3.0) Remember last frame used on boot (local to each player).
  • ✅ (Pre 0.3.0) Snapshot a frame to use as icon.
  • ✅ (Pre 0.3.0) Reload player when saving the timeline.
  • ✅ (Pre 0.3.0) Show frame number in the editor.
  • ✅ (Pre 0.3.0) Support for uploading new spritesheet to the editor.
  • ✅ (Pre 0.3.0) Character preview inside the editor.
  • ✅ (Pre 0.3.0) Character editor.
  • ✅ (Pre 0.3.0) "first", "last" and "random" actions.
  • ✅ (Pre 0.3.0) "flip" and "unflip" actions.

Changelog

  • (1.1.1) Touch Portal integration.
  • (1.1) Party mode.
  • (1.0) New, more powerful, editor.
  • (1.0) CTRL+Z will try to place frames you deleted back into the list.
  • (1.0) Backup and restore are now part of the main editor (instead of the Windows app only).
  • (1.0) You can name frames from the editor.
  • (1.0) You can take snapshots of what you currently see inside the crop box.
  • (1.0) Crop box and icon crop box now have a minimum usable size.
  • (1.0) You can now center the spritesheet, in case it gets moved away from the screen.
  • (1.0) Added an outline to mark the limits of the spritesheet image.
  • (1.0) Info tab now hosts the preview.
  • (1.0) Info tab now shows keyboard shortcuts.
  • (1.0) Drag and drop to reorder frames is untouched.
  • (0.3.0) Introduced the Stream Deck Plugin.
  • (0.3.0) Removed HTTP GET and Socket.io integrgations.
  • (0.3.0) Added /player.html endpoint.
  • (0.3.0) Renamed "map" to "editor".
  • (0.3.0) Renamed /map.html endpoint to /editor.html.
  • (0.3.0) Removed comma separated commands.
  • (0.3.0) Removed /port endpoint.
  • (0.3.0) Several performance improvements.