Giter Site home page Giter Site logo

coremidi's Introduction

coremidi

This is a CoreMIDI library for Rust built on top of the low-level bindings coremidi-sys. CoreMIDI is a macOS framework that provides APIs for communicating with MIDI (Musical Instrument Digital Interface) devices, including hardware keyboards and synthesizers.

This library preserves the fundamental concepts behind the CoreMIDI framework, while being Rust idiomatic. This means that if you already know CoreMIDI, you will find very easy to start using it.

The documentation for the master branch can be found here: https://chris-zen.github.io/coremidi/coremidi/

Please see the examples for an idea on how to use it, but if you are eager to see some code, this is how you would send some note:

use coremidi::{Client, Destination, EventBuffer, Protocol};
use std::time::Duration;
use std::thread;

fn main() {
  let client = Client::new("example-client").unwrap();
  let output_port = client.output_port("example-port").unwrap();
  let destination = Destination::from_index(0).unwrap();
  let chord_on = EventBuffer::new(Protocol::Midi10)
    .with_packet(0, &[0x2090407f])
    .with_packet(0, &[0x2090447f]);
  let chord_off = EventBuffer::new(Protocol::Midi10)
    .with_packet(0, &[0x2080407f])
    .with_packet(0, &[0x2080447f]);
  output_port.send(&destination, &chord_on).unwrap();
  thread::sleep(Duration::from_millis(1000));
  output_port.send(&destination, &chord_off).unwrap();
}

If you are looking for a portable MIDI library then you can look into:

For handling low level MIDI data you may look into:

Build Status Crates.io Crates.io Crates.io GitHub tag Minimum rustc version

Installation

The library is published into crates.io, so it can be used by adding the following lines into your Cargo.toml file (but remember to update the version number accordingly):

[dependencies]
coremidi = "^0.7.0"

If you prefer to live in the edge ;-) you can use the master branch by including this instead:

[dependencies]
coremidi = { git = "https://github.com/chris-zen/coremidi", branch="master" }

To play with the source code yourself you can clone the repo and build the code and documentation with the following commands:

git clone https://github.com/chris-zen/coremidi.git
cd coremidi
cargo build
cargo test
cargo doc
open target/doc/coremidi/index.html

Examples

The examples can be run with:

cargo run --example send

These are the provided examples:

  • endpoints: how to enumerate sources and destinations.
  • send: how to create an output port and send MIDI messages.
  • receive: how to create an input port and receive MIDI messages.
  • virtual-source: how to create a virtual source and generate MIDI messages.
  • virtual-destination: how to create a virtual destination and receive MIDI messages.
  • properties: how to set and get properties on MIDI objects.
  • notifications: how to receive MIDI client notifications.

coremidi's People

Contributors

boddlnagg avatar chris-zen avatar cornedriesprong avatar jasongrlicky avatar lashomb avatar raphlinus avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.