Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/keijiro/MidiAnimationTrack
SMF (.mid) file importer for Unity Timeline
https://github.com/keijiro/MidiAnimationTrack
midi timeline unity unity3d
Last synced: 3 months ago
JSON representation
SMF (.mid) file importer for Unity Timeline
- Host: GitHub
- URL: https://github.com/keijiro/MidiAnimationTrack
- Owner: keijiro
- License: unlicense
- Created: 2018-11-05T13:52:12.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2022-07-10T13:16:39.000Z (over 2 years ago)
- Last Synced: 2024-10-24T15:55:32.460Z (4 months ago)
- Topics: midi, timeline, unity, unity3d
- Language: C#
- Homepage:
- Size: 2.28 MB
- Stars: 444
- Watchers: 24
- Forks: 45
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
MIDI Animation Track for Unity Timeline
=======================================data:image/s3,"s3://crabby-images/23a61/23a6151a4868694c80b7de4fee05f377f996946b" alt="Ableton"
data:image/s3,"s3://crabby-images/21f3c/21f3c5b4cf11e6d3de0f878ad345da46bf09b863" alt="Unity"**MIDI Animation Track** is a custom timeline/playables package that provides
functionality to control object properties based on sequence data contained
in a standard MIDI file (`.mid` file). This allows you to create musically
synchronized animation using a DAW (digital audio workstation) that is easy
to manage accurately synchronized timings compared to other non-musical
timeline editors like Unity's one.System requirements
-------------------- Unity 2019.1 or later
Installation
------------This package is distributed via the [npmjs] registry. You can import it using
the [scoped registry] feature of Unity Package Manager.To import the package, please add the following sections to the package
manifest file (`Packages/manifest.json`).To the `scopedRegistries` section:
```
{
"name": "Keijiro",
"url": "https://registry.npmjs.com",
"scopes": [ "jp.keijiro" ]
}
```To the `dependencies` section:
```
"jp.keijiro.klak.timeline.midi": "1.0.5"
```After changes, the manifest file should look like below:
```
{
"scopedRegistries": [
{
"name": "Keijiro",
"url": "https://registry.npmjs.com",
"scopes": [ "jp.keijiro" ]
}
],
"dependencies": {
"jp.keijiro.klak.timeline.midi": "1.0.5",
...
```[npmjs]: https://www.npmjs.com/
[scoped registry]: https://docs.unity3d.com/Manual/upm-scoped.htmlImporting .mid files
--------------------You can import a `.mid` file as an asset file. Simply drag and drop it to the
project view, or navigate to "Assets" - "Import New Asset...".At the moment, the MIDI file importer doesn't support set-tempo meta events,
so the sequence tempo value (BPM) must be manually specified in the inspector.data:image/s3,"s3://crabby-images/0c344/0c344af998561a0ee3408071c79eb81e82d74ba8" alt="Inspector"
An imported asset may contain multiple tracks that are shown as sub-assets
under it.data:image/s3,"s3://crabby-images/045c8/045c8e8e5d853d91410dcb841c348f3538d4323c" alt="Sub-assets"
To create a MIDI animation track, drag and drop one of these clip assets to
a timeline.data:image/s3,"s3://crabby-images/809d9/809d930b4db54b1ea24c3000a108ea104de87fc9" alt="Drag and drop"
Track controls
--------------You can animate object properties from a MIDI animation track using **track
controls**. To create a new track control, select a MIDI animation track (not a
clip) in the Timeline editor. Then track control editor will appear in the
inspector.data:image/s3,"s3://crabby-images/b88c9/b88c907f3af63ef7460aec840de56f05fd2cfcea" alt="Track controls"
A track control only can animate a single property. You can add multiple
controls to animate multiple different properties.At the moment, a track control only supports `float`, `Vector3`, `Quaternion`
and `Color` properties. Please note that it requires a public *property* to
be animated; Just providing a public *variable* is not enough.There are three modes in the track control: **Note Envelope**, **Note Curve**
and **CC**.### Note Envelope mode
data:image/s3,"s3://crabby-images/458c0/458c0b05be8b9f245d9bab5adb0d9924c4b7affd" alt="Inspector"
**Note Envelope** is a mode where a property is animated by a classic [ADSR]
style envelope. This mode is useful when you want to make animation react to
key-off events.You can specify which **Note/Octave** the control reacts to. Please note that
key velocity affects the envelope. It's simply multiplied to the envelope
output.[ADSR]: https://en.wikipedia.org/wiki/Envelope_(music)
### Note Curve mode
data:image/s3,"s3://crabby-images/15a01/15a0194bd5ac10a183316c61611db29fed31aeee" alt="Inspector"
**Note Curve** is a mode where a property is animated by an animation curve.
It starts playing animation on key-on events and keeps playing until it ends
(key-off events will be ignored).You can specify which **Note/Octave** the control reacts to. Please note that
key velocity affects the animation curve. It's simply multiplied to the curve
value.### CC mode
data:image/s3,"s3://crabby-images/62095/62095c72d9e2f914ba06c1f4f7abd72ea3f6da91" alt="Inspector"
**CC** is a mode where a property is animated by CC (control change) events
contained in a MIDI track.You can specify which **CC Number** the control reacts to.
MIDI signals
------------A MIDI animation track also supports sending [Timeline Signals] on key-on/off
events. To receive MIDI events from a track, you can use the **MIDI Signal
Receiver** component.[Timeline Signals]:
https://blogs.unity3d.com/2019/05/21/how-to-use-timeline-signals/data:image/s3,"s3://crabby-images/943f7/943f70fbda04f2dd1ce1a0b6ec90be2e7d16317d" alt="Inspector"
1. Add the MIDI Signal Receiver component to a game object that receives MIDI
signals.
2. Specify which **Note/Octave** the receiver reacts to.
3. Register methods to **Note On/Off Events**.
4. Set the receiver game object as the output destination of the track.data:image/s3,"s3://crabby-images/ba86e/ba86ecf6cc7dfcd3a49b42994c8470358037c737" alt="Output destination"
You can add multiple receiver components to a single game object. It's useful
to invoke different methods for each note.