Skip to content

Hero Studio is an attempt to build an studio similar to Bitwig Studio or Ableton Live

License

Notifications You must be signed in to change notification settings

chris-zen/hero-studio

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

42 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

TravisCI build status

Hero Studio

This project is an attempt to build a music studio similar to Ableton Live or Bitwig Studio in the long term.

For the short term my main goal is to learn the core details about DAWs and audio programming, and may be to use the core engine to build more modest applications such as a VST host for development of plugins, a Raspberry Pi recording device, or a tracker.

UI development

I plan to make this project very modular and keep UIs as separate applications. The plan is to have an engine that allows communication from external systems such a UI or a surface MIDI controllers, through some RPC mechanism (currently WebSockets + some serialization protocol).

I have been exploring several possibilities for building GUIs, more information can be found in the wiki.

Organisation

This is a multi-project composed by:

  • core: The core data model and logic.
  • app-server: The application server that runs the Audio/MIDI engine.
  • app-electron: Very preliminary prototype of a GUI with Electron.

Running

For running the main application you need to run the following commands:

cd app-server
cargo run --release

But bear in mind that you will need to install PortAudio and PortMIDI before running the project, as this is using the portaudio and portmidi crates that depend on their binaries and headers.

If you get an error like:

error while loading shared libraries: libportaudio.so.2: cannot open shared object file: No such file or directory

then you should install the binary dependencies and headers for PortAudio and/or PortMIDI:

Installing PortAudio & PortMIDI in Ubuntu

# ubuntu
sudo apt-get install libportaudio2 libportmidi-dev

Installing PortAudio & PortMIDI in MacOS

brew install portaudio portmidi

Tests

Tests can be run with:

cargo test

Roadmap

Since the begining I knew that the scope of this project was too big for a single person, but anyway I was willing to learn as much as possible by exploring ideas myself through this project. At some point I needed to explore some more ideas from a fresher and newer perspective, so I put this project on hold and started working on a different one (see kiro-synth). This is giving me a new perspective on several fronts such as MIDI handling, threads communication, and UI development. So I expect to come back to this project and apply all of my learnings at some point in the future. I knew this was going to be a looong hobby project ;-P

I keep this roadmap for the record, although it might completely change once I'm back:

  • core: Basic transport logic with accurate timing: play, stop, loop
  • app-native: Allow MIDI configuration through studio.toml
  • core: MIDI bus system
  • core: Implement a basic metronome using MIDI notes
  • core: Management of time and sync between different clocks: Audio, Midi, Host, Ticks
  • app-server: Build MIDI output abstraction to send MIDI events to a device using CoreMIDI & PortMIDI as an initial impl
  • app-server: Explore ways to avoid locks and allocations from the real-time processing threads
  • core: Implement an audio based metronome and investigate the MIDI metronome drift.
  • app-server: Add MIDI input support
  • app-server: Add VST plugins support
  • rethink the project submodules into something like (ui-electron, server and engine)
  • Start exploring UI integrations (some progress already done with Electron, but would like to test Qt too)
  • core: Filling MIDI output buffers from the Song clips (initially choose one type of clip between pianoroll, step-sequencer, drum-box).
  • ...

About

Hero Studio is an attempt to build an studio similar to Bitwig Studio or Ableton Live

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published