java.lang.Objectjavax.sound.midi.MidiMessage
javax.sound.midi.SysexMessage
public class SysexMessage
A 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:
When Java Sound is used to handle system exclusive data that is being received
using MIDI wire protocol, it should place the data in one or more
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.
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 Summary | |
|---|---|
static int |
SPECIAL_SYSTEM_EXCLUSIVE
Status byte for Special System Exclusive message (0xF7, or 247), which is used in MIDI files. |
static int |
SYSTEM_EXCLUSIVE
Status byte for System Exclusive message (0xF0, or 240). |
| Fields inherited from class javax.sound.midi.MidiMessage |
|---|
data, length |
| Constructor Summary | |
|---|---|
|
SysexMessage()
Constructs a new SysexMessage. |
protected |
SysexMessage(byte[] data)
Constructs a new SysexMessage. |
| Method Summary | |
|---|---|
Object |
clone()
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. |
void |
setMessage(byte[] data,
int length)
Sets the data for the system exclusive message. |
void |
setMessage(int status,
byte[] data,
int length)
Sets the data for the system exclusive message. |
| Methods inherited from class javax.sound.midi.MidiMessage |
|---|
getLength, getMessage, getStatus |
| Methods inherited from class java.lang.Object |
|---|
equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| Field Detail |
|---|
public static final int SYSTEM_EXCLUSIVE
MidiMessage.getStatus(),
Constant Field Valuespublic static final int SPECIAL_SYSTEM_EXCLUSIVE
MidiMessage.getStatus(),
Constant Field Values| Constructor Detail |
|---|
public SysexMessage()
SysexMessage. 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 the setMessage
methods.
setMessage(byte[], int)protected SysexMessage(byte[] data)
SysexMessage.
data - an array of bytes containing the complete message.
The message data may be changed using the setMessage
method.setMessage(byte[], int)| Method Detail |
|---|
public void setMessage(byte[] data,
int length)
throws InvalidMidiDataException
setMessage in class MidiMessagedata - the system exclusive message datalength - the length of the valid message data in
the array, including the status byte.
InvalidMidiDataException
public void setMessage(int status,
byte[] data,
int length)
throws InvalidMidiDataException
status - the status byte for the message (0xF0 or 0xF7)data - the system exclusive message datalength - the length of the valid message data in
the array
InvalidMidiDataExceptionpublic byte[] getData()
public Object clone()
clone in class MidiMessageCloneableCes informations proviennent du site de http://java.sun.com
Le contenu de cette page provient du site de Sun, et est généré depuis un cache sur l'infobrol après certains traitements automatisés. La présentation peut donc différer du document original, mais le contenu aussi. Vous pouvez utiliser ce bouton pour afficher la page originale du site de Sun :
Maintenir les pages en cache sur différents sites peut offrir plus de disponibilité.
Chaque page est indexée dans la base de donnée, ce qui permet de retrouver facilement les informations, au moyen des sommaires, du moteur de recherche interne, etc.
Des facilités sont mises en place pour que les membres de l'infobrol puissent effectuer des traductions en français des différents documents. Ceci devrait permettre aux débutants en programmation Java de consulter les API en français s'ils maîtrisent moins bien la langue de Shakespeare. Dans le cas où une traduction a été soumise, elle est disponible au moyen d'un lien en bas de page. Si la traduction a été validée, la page s'affiche par défaut en français, et un lien en bas de page permet d'atteindre la version en anglais.
Le code sur l'infobrol est automatiquement coloré selon la syntaxe, et les différents mots clés sont transformés en liens pour accéder rapidement aux informations.
Vous avez la possibilité de partager vos expériences en proposant vos propres extraits de code en utilisant le bouton "ajouter un commentaire" en bas de page. Si vous visitez simplement l'infobrol, vous avez déjà accès à cette fonction, mais si vous étes membre du brol, vous pouvez en plus utiliser des boutons supplémentaires de mise en forme, dont la coloration automatique de vos extraits de codes.
Vous pouvez modifier vos préférences dans votre profil pour ne plus afficher les interactions avec les réseaux sociaux sur ces pages.
7 mots clés dont 0 définis manuellement (plus d'information...).
Avertissement
Cette page ne possède pas encore de mots clés manuels, ceci est donc un exemple automatique (les niveaux de pertinence sont fictifs, mais les liens sont valables). Pour tester le nuage avec une page qui contient des mots définis manuellement, vous pouvez cliquer ici.Vous pouvez modifier vos préférences dans votre profil pour ne plus afficher le nuage de mots clés.
Recherche (afficher)
Utilisateur (masquer)
Navigation (masquer)
Apparence (afficher)
Stats (afficher)
Citation (masquer)