Skip to content

This project is a fork of Pila's Steam Controller Singer, including a dirty fix to make the Steam Controller sing again.

License

Notifications You must be signed in to change notification settings

jabe-dot-com/SteamControllerSinger

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

52 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Steam Controller Singer

This project is a fork of Pila's SteamControllerSinger including a dirty fix to make the Steam Controller sing again.

The Steam Deck is also supported, since its built-in controller is very similar to the Steam Controller!

Note: Steam Controller Singer currently only works on GNU/Linux, and this fork was created to address a GNU/Linux-only issue. Therefore, no Microsoft Windows executable is provided (if you want one, go to the original source), and no Microsoft Windows related issues will be accepted.

HOW TO

  1. Turn on your Steam Controller
  2. Drag the midi file onto steamcontrollersinger executable
  3. When prompted, press ENTER
  4. Enjoy!

Where can I find midi songs?

You can find midi songs ready to be played with Steam Controller Singer in my Personal Collection (I'll keep updating it with more songs). You can also download midi songs from various websites such musescore.com, but they may or may not be ready to be played with Steam Controller Singer (see Midi files tips in that case).

Usage from command prompt:

steamcontrollersinger [-r][-l DEBUG_LEVEL] [-i INTERVAL] [-c RECLAIM_PERIOD] MIDI_FILE

-i INTERVAL argument to choose player sleep interval (in microseconds). Lower generally means better song fidelity, but higher cpu usage, and at some point goidn lower won't improve any more. Default value is 10000

-l DEBUG_LEVEL argument to choose libusb debug level. Default is 0, no debug output. max is 4, max verbosity output

-r to enable repeat mode, which plays continously (restart the song when finished)

-c RECLAIM_PERIOD will change the default reclaiming period (2 seconds). A greater period will reduce notes hanging, but will also increase the probability of losing the control of the controller, depending on the song. All songs are known to fail with reclaim period over 5. After a failed attempt, you will need to reconnect the controller.

Midi files tips:

Midi files may need to be edited with a software such MidiEditor to be correctly played with Steam Controller Singer following the next tips:

  • Notes from midi channel 0 are played on right haptic
  • Notes from midi channel 1 are played on left haptic
  • Notes from others channels are ignored
  • Avoid multiple notes active at the same time on the same channel, since haptic actuators can only play one note at the time.

CHANGELOG

[V1.8]

  • User can now define the reclaim period with -c option.

[V1.7]

  • Fixed music stopped playing after a few seconds

[V1.6]

  • Fixed major bugs in playback algorithm

[V1.5]

  • Changed debug level argument from -d to -l
  • Added -r argument to enable demo mode
  • Enhanced arguments parsing
  • Does not rely on Steam Controller duration anymore
  • Updated note display
  • Now stops playing when interrupting the process ( on Ctrl+C )

[V1.4]

  • Fixed a bug in MIDI librairie that would compute a null duration for notes when ON event and previous OFF event had the same timetick

[V1.3]

  • Added -iINTERVAL argument
  • Added -dDEBUG_LEVEL argument

[V1.2]

  • Fixed being stuck on "Command error" when disconnecting controller while playing. Now continue playing (even if keep failing)
  • Removed the now deprecated 20ms note duration reduction

Compiling

You will need libusb(-dev) and pkgconf. If you have them, just type make.

On the Steam Deck, you'll also need the base-devel, gcc, and linux-api-headers packages, in addition to libusb. You can install these with pacman after running sudo steamos-readonly disable.

About

This project is a fork of Pila's Steam Controller Singer, including a dirty fix to make the Steam Controller sing again.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 89.8%
  • C++ 10.1%
  • Makefile 0.1%