Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stashymane/midifunk
Library for listening for and manipulating MIDI events
https://github.com/stashymane/midifunk
kotlin library midi
Last synced: 3 months ago
JSON representation
Library for listening for and manipulating MIDI events
- Host: GitHub
- URL: https://github.com/stashymane/midifunk
- Owner: stashymane
- License: apache-2.0
- Created: 2020-08-05T16:36:06.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-06-29T22:40:33.000Z (7 months ago)
- Last Synced: 2024-06-30T05:15:38.624Z (7 months ago)
- Topics: kotlin, library, midi
- Language: Kotlin
- Homepage:
- Size: 293 KB
- Stars: 5
- Watchers: 2
- Forks: 0
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# midifunk [![Version tag](https://img.shields.io/maven-central/v/dev.stashy.midifunk/events?logo=apachemaven&label=Maven%20Central&color=%23339AF0)][Maven central]
Kotlin Multiplatform MIDI library that just makes sense.
Currently focused on live MIDI I/O.Note: this is still in an experimental stage, expect breaking changes until the first stable release.
## Features
* Type-safe MIDI events with the `events` module
* MIDI as consumable channels with Coroutines
* Minimal code required for listening
* Easy input & output## Platforms
| Platform | Events | Devices | Comment |
|:---------|:-------|:--------|:------------------------------------------------|
| JVM | ✅️ | ✅️ | |
| Windows | ✅️ | ✖️ | Waiting on Windows MIDI services |
| Linux | ✅️ | ✖️ | Devices support coming after Windows |
| MacOS | ❔️ | ✖️ | No device for testing or development available. |## Usage
Version catalog
```toml
[versions]
midifunk = "[version]"[libraries]
midifunk-events = { module = "dev.stashy.midifunk:events", version.ref = "midifunk" }
midifunk-devices = { module = "dev.stashy.midifunk:devices", version.ref = "midifunk" }
```Gradle Kotlin
```kotlin
implementation("dev.stashy.midifunk", "events", "version")
implementation("dev.stashy.midifunk", "devices", "version")
```## Examples
### Opening device for reading inputs
```kotlin
val device = MidiDevice.list()[0]
device.input.open(coroutineScope).onEach { println(it) }
```### Opening output channel
```kotlin
val device = MidiDevice.list()[0]
val channel: SendChannel = device.output.open(coroutineScope)
channel.send(event)
```### Creating type-safe MIDI events with DSL
```kotlin
NoteEvent.create {
noteStatus = true
note = Note.C(4)
velocity = 127u
}
```## Roadmap
Top priority at the moment is to finalize the device input/output API.
The eventual goal is to be able to completely rip out the Java MIDI backend & use something else, which will also
provide multiplatform support.After the device API, virtual device support is going to be prioritized.
This will most likely require separate backends for each platform to be implemented already.## Contributing
Although not strictly, please try to adhere to the [standard Kotlin code style guidelines][1], more thoroughly defined
in JetBrains IDEs. Other than that, feel free to submit pull requests - I will gladly review them.[1]: https://kotlinlang.org/docs/reference/coding-conventions.html
[Maven central]: https://central.sonatype.com/namespace/dev.stashy.midifunk