- Notifications
You must be signed in to change notification settings - Fork18
Java mapping library for MusicXML
License
Audiveris/proxymusic
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
ProxyMusic allows to marshal/unmarshal Java objects in memory to/from MusicXML 4.0data in a Document, a stream or a file.
This binding provides an easy way for Java programs dealing with music symbolicinformation (such as score scanners, music editors, music sequencers, etc) to reador write files in MusicXML.
ProxyMusic supports the following MusicXML features:
- Marshalling/unmarshalling ofScorePartwise
- Marshalling/unmarshalling ofOpus
- Handling of standard (uncompressed)
.xml
files - Handling of compressed
.mxl
files
All MusicXML elements and attributes are implemented as about 325 Java classes that areautomatically generated from the MusicXML defining schema as found onits vendor site.
The main advantage of this automated approach is to result in an efficient and error-free implementation.
Building ProxyMusic is easily achieved with the following terminal command:
$> mvn clean package
This command will (re)build the ProxyMusic Maven artifacts (binary, source and doc),taking as input the schema definition filessrc/main/xsd/musicxml.xsd
andsrc/main/xsd/opus.xsd
.
The latest ProxyMusic release is available onMaven Centraland thus can be easily integrated in a Gradle or Maven build.Alternatively, it is possible tobuild a local artifact.
A utility Java class, namedproxymusic.util.Marshalling
, is available to ease the handlingof both marshalling and unmarshalling ofScorePartwise andOpus entities.
A few examples of use:
- A small example is available in the
proxymusic.util
package located in the test branch,its name isproxymusic.util.HelloWorldTest.java
.
This example performs marshalling and unmarshalling of the classical HelloWorld as available inthe MusicXML tutorial. - Another small example, focused on the marshalling and the unmarshalling of a part-list element,is available as
proxymusic.util.ScorePartTest.java
. - For marshalling and unmarshalling Opus entities, see
proxymusic.opus.OpusTest.java
simpleexample orproxymusic.opus.MxlOpusTest.java
more realistic example. - For dealing with compressed
.mxl
files, seeproxymusic.mxl.MxlTest.java
orproxymusic.opus.MxlOpusTest.java
examples. - A real size example is provided by the companionAudiveris project.
Audiveris is an Optical Music Recognition software (OMR) which uses ProxyMusic to handlethe marshalling layer.
For detailed information, refer to AudiverisScoreExporterandPartwiseBuilder Java classes.
About
Java mapping library for MusicXML