Class SysexMessage
- All Implemented Interfaces:
- Cloneable
SysexMessage object represents a MIDI system exclusive message.
 
 When a system exclusive message is read from a MIDI file, it always has a
 defined length. Data from a system exclusive message from a MIDI file should
 be stored in the data array of a SysexMessage as follows: the system
 exclusive message status byte (0xF0 or 0xF7), all message data bytes, and
 finally the end-of-exclusive flag (0xF7). The length reported by the
 SysexMessage object is therefore the length of the system exclusive
 data plus two: one byte for the status byte and one for the end-of-exclusive
 flag.
 
 As dictated by the Standard MIDI Files specification, two status byte values
 are legal for a SysexMessage read from a MIDI file:
 
- 0xF0: System Exclusive message (same as in MIDI wire protocol)
- 0xF7: Special System Exclusive message
SysexMessages. In this case, the length of the system exclusive data
 is not known in advance; the end of the system exclusive data is marked by an
 end-of-exclusive flag (0xF7) in the MIDI wire byte stream.
 - 0xF0: System Exclusive message (same as in MIDI wire protocol)
- 0xF7: End of Exclusive (EOX)
SysexMessage object containing data for a particular system
 exclusive message should have the status value 0xF0. If this message contains
 all the system exclusive data for the message, it should end with the status
 byte 0xF7 (EOX). Otherwise, additional system exclusive data should be sent
 in one or more SysexMessages with a status value of 0xF7. The
 SysexMessage containing the last of the data for the system exclusive
 message should end with the value 0xF7 (EOX) to mark the end of the system
 exclusive message.
 
 If system exclusive data from SysexMessages objects is being
 transmitted using MIDI wire protocol, only the initial 0xF0 status byte, the
 system exclusive data itself, and the final 0xF7 (EOX) byte should be
 propagated; any 0xF7 status bytes used to indicate that a
 SysexMessage contains continuing system exclusive data should not be
 propagated via MIDI wire protocol.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intStatus byte for Special System Exclusive message (0xF7, or 247), which is used in MIDI files.static final intStatus byte for System Exclusive message (0xF0, or 240).Fields declared in class javax.sound.midi.MidiMessagedata, length
- 
Constructor SummaryConstructorsModifierConstructorDescriptionConstructs a newSysexMessage.protectedSysexMessage(byte[] data) Constructs a newSysexMessage.SysexMessage(byte[] data, int length) Constructs a newSysexMessageand sets the data for the message.SysexMessage(int status, byte[] data, int length) Constructs a newSysexMessageand sets the data for the message.
- 
Method SummaryModifier and TypeMethodDescriptionclone()Creates a new object of the same class and with the same contents as this object.byte[]getData()Obtains a copy of the data for the system exclusive message.voidsetMessage(byte[] data, int length) Sets the data for the system exclusive message.voidsetMessage(int status, byte[] data, int length) Sets the data for the system exclusive message.Methods declared in class javax.sound.midi.MidiMessagegetLength, getMessage, getStatus
- 
Field Details- 
SYSTEM_EXCLUSIVEpublic static final int SYSTEM_EXCLUSIVEStatus byte for System Exclusive message (0xF0, or 240).- See Also:
 
- 
SPECIAL_SYSTEM_EXCLUSIVEpublic static final int SPECIAL_SYSTEM_EXCLUSIVEStatus byte for Special System Exclusive message (0xF7, or 247), which is used in MIDI files. It has the same value as END_OF_EXCLUSIVE, which is used in the real-time "MIDI wire" protocol.- See Also:
 
 
- 
- 
Constructor Details- 
SysexMessagepublic SysexMessage()Constructs a newSysexMessage. The contents of the new message are guaranteed to specify a valid MIDI message. Subsequently, you may set the contents of the message using one of thesetMessagemethods.- See Also:
 
- 
SysexMessageConstructs a newSysexMessageand sets the data for the message. The first byte of the data array must be a valid system exclusive status byte (0xF0 or 0xF7). The contents of the message can be changed by using one of thesetMessagemethods.- Parameters:
- data- the system exclusive message data including the status byte
- length- the length of the valid message data in the array, including the status byte; it should be non-negative and less than or equal to- data.length
- Throws:
- InvalidMidiDataException- if the parameter values do not specify a valid MIDI meta message
- Since:
- 1.7
- See Also:
 
- 
SysexMessageConstructs a newSysexMessageand sets the data for the message. The contents of the message can be changed by using one of thesetMessagemethods.- Parameters:
- status- the status byte for the message; it must be a valid system exclusive status byte (0xF0 or 0xF7)
- data- the system exclusive message data (without the status byte)
- length- the length of the valid message data in the array; it should be non-negative and less than or equal to- data.length
- Throws:
- InvalidMidiDataException- if the parameter values do not specify a valid MIDI system exclusive message
- Since:
- 1.7
- See Also:
 
- 
SysexMessageprotected SysexMessage(byte[] data) Constructs a newSysexMessage.- Parameters:
- data- an array of bytes containing the complete message. The message data may be changed using the- setMessagemethod.
- See Also:
 
 
- 
- 
Method Details- 
setMessageSets the data for the system exclusive message. The first byte of the data array must be a valid system exclusive status byte (0xF0 or 0xF7).- Overrides:
- setMessagein class- MidiMessage
- Parameters:
- data- the system exclusive message data
- length- the length of the valid message data in the array, including the status byte
- Throws:
- InvalidMidiDataException- if the parameter values do not specify a valid MIDI system exclusive message
 
- 
setMessageSets the data for the system exclusive message.- Parameters:
- status- the status byte for the message (0xF0 or 0xF7)
- data- the system exclusive message data
- length- the length of the valid message data in the array
- Throws:
- InvalidMidiDataException- if the status byte is invalid for a system exclusive message
 
- 
getDatapublic byte[] getData()Obtains a copy of the data for the system exclusive message. The returned array of bytes does not include the status byte.- Returns:
- array containing the system exclusive message data
 
- 
cloneCreates a new object of the same class and with the same contents as this object.- Specified by:
- clonein class- MidiMessage
- Returns:
- a clone of this instance
- See Also:
 
 
-