Github site | source documentation | change notes | application
What is Smoosic?
We are approaching Smoosic 1.0 status! Many of the things I wanted to do with Smoosic are working to some extent.
- scores with part extraction
- playback with instruments and samples
- real-time editing, even for large scores
- MIDI and MusicXML import and export has been enhanced. You can now export from Smoosic and import into MuseScore and vise-versa.
- dynamic music library with links to scores, tags etc. Inspired by iRealPro app 'ireal' format
- library mode for custom applications
Smoosic is highly dependent on the Vexflow engraving library, and especially its authors/maintainers @rvilari, @ronyeh and @0xfe.
See changes for changes, updates, initiatives etc.
There is a demo application that you can play around with that shows the capabilities.
What does it do?
Smoosic does the following things:
- Serialization and persistence of musical objects
- Online, searchable music libraries
- XML and MIDI import and export
- parts, instruments, staff groups, transposition, voices
- performant background rendering and asynchronous layout, pagination, line wrapping
- SVG text editing for score text, chord symbols and lyrics
- interactive user interface, mapping musical elements to UI components, mouse event binding, etc.
- fully customizable UI elements (buttons, key bindings, menus, dialogs)
- Real-time score playback
- natural language translation, including R to L language support (music still goes from left to right :)
You can see all these in the demo.
Why?
People often ask on the VexFlow forums: how can you add an accidental to a note once it's been rendered? The simple answer is that you don't. If you add an accidental or something to your measure, it changes the location of all the symbols, so the whole measure has to be re-formatted.
There is no easy way to do this using VexFlow alone, because the object model used by VexFlow to do the rendering is not serializable. This is the original problem Smoosic is trying to solve, with the Serializable Musical Objects model. SMO data objects have their own representation and can be easily serialized (that's what the 'S' is for), copied, changed programatically, and then re-rendered. This makes it easier to create a music application web UI.
How do I use Smoosic?
There are PEN/fiddles to help you understand and create your own applications:
But I just want to write music!
If you just want to use the application without any programming, there are some online instructions. The usage documentation is probably out of date, feel free to submit updates!
What's new in Smoosic?
Midi input! Also, see the change notes
SMO library details
The music library is divided into parts:
SMO modules
- modules in the Smo directory form the core object model.
- data modules are the serializable object part. xform modules handle some common operations like changing note lengths and transposing. Other directories handle different forms of import/export.
- SmoScore is the top-level object for the SMO object model.
Rendering modules
- modules in the render directory handle rendering
- The main class that you will interact with when modifying the score is SuiScoreViewOperations. All interactions with the score can be accomplished through this object.
- Modules in sui directory do the SVG background rendring. modules in vex directory interact with VexFlow. Modules in the audio directory handle playback.
Configuration
- You can start an instance of the library or application by calling
SuiApplication.configure()
. This will initialize the global objects and resolve a promise when complete.
- The application takes a single argument: a SmoConfiguration object. This lets you define all the no-code customizable features of the library such as: initial score, key bindings, language, run mode, and UI element bindings.
- The
mode
field of the configuration object determines what mode Smoosic is running in. If running in application mode, the full UI will be created and the configuration expects all the UI elements. If running in library mode, only the view is started.
Future SMO
Things I am actively working on:
- Part extraction and formatting
- XML import and export imrprovements
Things I hope to be working on soon:
- UI improvements
- More rendering features
I'd like to help
I'd appreciate it! Even if you are not a programmer, if you are interested in music and this project, you can contribute.
- Submit bug reports.
- If you speak a language that is not English, you can help with translations.
- If you are a coder, you could help by adding features. It would be fairly easy to add things like string ornamentation, lines (8va, rit.... etc).
- If a designer or artist, or even if you just have good eyesight, the design could use some help. Some transitions in the menu/dialogs would be nice, some better-looking dialog components, better-centered icons, more icons.
- Also on the design front, accessibility. I have ambitions that Smoosic can be screen-reader friendly, even though the SVG won't be. Aria tags on dialog components, that kind of thing.
- If you are a musician, you can contribute samples of your instrument. I can use them for instruments in Smoosic, for playback.
- You can write music to be used in Smoosic libraries.