_ ____ _____ _____
| | / __ \ / ____| / ____|
| | __ _ __ __ __ _ | | | || (___ | |
_ | | / _` |\ \ / // _` || | | | \___ \ | |
| |__| || (_| | \ V /| (_| || |__| | ____) || |____
\____/ \__,_| \_/ \__,_| \____/ |_____/ \_____|
JavaOSC is primarily a library that gives JVM language programs the ability of serializing, parsing, sending and receiving data in the OSC content format. It is written in Java 8, and its only runtime dependency is a logging facade (SLF4J). It is also an OSGi (a dynamic module system for Java) bundle.
In a separate package, it also contains a sample GUI that allows to send OSC messages to SuperCollider.
is a simple content format, although it is often though of as a protocol for the transmission of data over a network.
- as a replacement for MIDI - a network-protocol for the exchange of musical control data between soft- and hardware, usually over a UDP/IP network
- in robotics - for communication between the parts of a robot, or multiple robots amongst each other
Its main strength is its simplicity.
The latest release version of the library is available on GitHub for manual download or on Maven central
<dependency>
<groupId>com.illposed.osc</groupId>
<artifactId>javaosc-core</artifactId>
<version>0.6</version>
</dependency>
The latest development sources can be found on GithHub.
JavaOSC is not a standalone application, but designed to be used in other applications. Though there is a very basic application for demonstration purposes.
To run the demo app, make sure you have all parts packaged and installed:
mvn install
Then start the UI:
cd modules/ui
mvn exec:java
Next, launch SuperCollider (SC), open the file located in the
modules/core/src/main/resources/supercollider/
directory,
and load the synthdef into SuperCollider.
Start the SC local server.
In the JavaOSC Demo UI, click the "All On" button and start moving the sliders.
You should hear the sounds change.
To see what messages the UI is sending, run either the CNMAT dumpOSC
,
or turn on dumpOSC in SuperCollider.
There is also a PureData patch created by Alexandre Quessy, available here.
To try the demo UI with PureData,
launch (this is important!) pd-extended and open the file
modules/core/src/main/resources/puredata/javaosc.pd
.
Turn down the volume a bit at first, as it might be very loud.
Click the "All On" button, and start moving the sliders.
You should hear the sounds change.
To see what messages the UI is sending, just look in the PD window or
in the terminal.
The classes that deal with sending OSC data are located in the com.illposed.osc
package.
The core classes are com.illposed.osc.transport.udp.OSCPort{In, Out}
,
com.illposed.osc.OSCMessage
and com.illposed.osc.OSCBundle
.
The common way to use the library is to instantiate an OSCPort{In, Out}
connected to the receiving machine, and then call port.send(myPacket)
.
There are some associated JUnit tests, which also contain code that may illustrate
how to use the library.
They can be run with mvn test
.
To release a development version to the Sonatype snapshot repository only:
# open a "private" shell, to not spill the changes in env vars
bash
# set env vars
export JAVA_HOME="${JAVA_8_HOME}"
export MAVEN_HOME="${MAVEN_3_2_5_HOME}"
export PATH="${MAVEN_HOME}/bin/:${PATH}"
# do the release
mvn clean deploy
# leave our "private" shell instance again
exit
mvn release:clean
To be able to sign the release artifacts,
make sure you have a section in your ~/.m2/settings.xml
that looks like this:
<profiles>
<profile>
<id>ossrh</id>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
<properties>
<gpg.executable>gpg2</gpg.executable>
<!--
This needs to match the `uid` as displayed by `gpg2 --list-keys`,
and needs to be XML escaped.
-->
<gpg.keyname>Firstname Lastname (Comment) <user@email.org></gpg.keyname>
</properties>
</profile>
</profiles>
If you have not yet done so, generate and publish a key-pair. See the Sonatype guide for further details about how to work with GPG keys.
# open a "private" shell, to not spill the changes in env vars
bash
# set env vars
export JAVA_HOME="${JAVA_8_HOME}"
export MAVEN_HOME="${MAVEN_3_2_5_HOME}"
export PATH="${MAVEN_HOME}/bin/:${PATH}"
# check if everything is in order
mvn \
clean \
package \
verify \
gpg:sign \
site
mvn release:clean
mvn \
-DdryRun=true \
release:prepare
# run the prepare phase for real
mvn release:clean
mvn \
-DdryRun=false \
release:prepare
# leave our "private" shell instance again
exit
This does the following:
- Important for backwards compatibility: use the oldest possible JDK version to compile (currently 1.8)
- asks for the release and new snapshot versions to use (for all modules)
- packages
- signs with GPG
- commits
- tags
# open a "private" shell, to not spill the changes in env vars
bash
# set env vars
export JAVA_HOME="${JAVA_8_HOME}"
export MAVEN_HOME="${MAVEN_3_2_5_HOME}"
export PATH="${MAVEN_HOME}/bin/:${PATH}"
# perform the release
git push origin master <release-tag>
mvn release:perform
mvn deploy -P release
# leave our "private" shell instance again
exit
This does the following:
- pushes to origin
- checks-out the release tag
- builds
- deploy into Sonatype staging repository
- promote it on Maven Central repository (may have a delay of up to 4h)
Thanks to John Thompson for writing the UI (demo application), Alexandre Quessy for the PD demo, and to Martin Kaltenbrunner and Alex Potsides for their contributions.