Skip to content

The js side of the hardware interface for icerink

Notifications You must be signed in to change notification settings

icerink/rinklink-js

Folders and files

NameName
Last commit message
Last commit date

Latest commit

dca4019 · Jan 24, 2019

History

10 Commits
Jan 22, 2019
Jan 23, 2019
Jan 23, 2019
Jan 21, 2019
Jan 24, 2019
Jan 23, 2019
Jan 23, 2019
Jan 21, 2019

Repository files navigation

rinklink.js

Tunneling hardware protocols over WebMidi to comunicate with hardware from within the browser. For the hardware side, see the microcontroller firmware of the rink link bridge.

Architecture

architecture diagram of rinklink

Message encoding

Rinklink is a packet based link. I.e. there are out of band messages for ending a packet and begining a new one. When an empty packet is ended (I.e. two subsequent packet end messages are sent) link is placed into command mode and the next packet is not sent to the target but is interpreted by the rinklink bridge. This can be used to reboot the target, or change settings of the bridge. For the format and types of command mode messages consult the documentation of the rinklink bridge

For staying inside the midi spec, only valid midi messages are sent. Comunication is done through Note-on, Note-off and Poly-KeyPress messages. Each of those messages has their very own meaning:

purpose midi message type raw payload midi messge (3 bytes)
transfer 1 byte Note-on 0bABCDEFGH 0b1000xxAx 0b0BCDEFGH 0bxxxxxxxx
transfer 2 bytes Note-off 0bABCDEFGH 0bIJKLMNOP 0b1001xxAI 0b0BCDEFGH 0b0JKLMNOP
end of packet Poly-KeyPress 0b1010xxxx 0bxxxxxxxx 0bxxxxxxxx

Note: It is desirable send two bytes at a time whenever possible to improve throughput end efficiency.

About

The js side of the hardware interface for icerink

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published