Class MidiFileFormat
public class MidiFileFormat extends Object
MidiFileFormat
object encapsulates a MIDI file's type, as well as its length and timing information. A MidiFileFormat
object can include a set of properties. A property is a pair of key and value: the key is of type String
, the associated property value is an arbitrary object. Properties specify additional informational meta data (like a author, or copyright). Properties are optional information, and file reader and file writer implementations are not required to provide or recognize properties.
The following table lists some common properties that should be used in implementations:
Property key | Value type | Description |
---|---|---|
"author" |
String |
name of the author of this file |
"title" |
String |
title of this file |
"copyright" |
String |
copyright message |
"date" |
Date |
date of the recording or release |
"comment" |
String |
an arbitrary text |
Field Summary
Modifier and Type | Field | Description |
---|---|---|
protected int |
byteLength |
The length of the MIDI file in bytes. |
protected float |
divisionType |
The division type of the MIDI file. |
protected long |
microsecondLength |
The duration of the MIDI file in microseconds. |
protected int |
resolution |
The timing resolution of the MIDI file. |
protected int |
type |
The type of MIDI file. |
static final int |
UNKNOWN_LENGTH |
Represents unknown length. |
Constructor Summary
Constructor | Description |
---|---|
MidiFileFormat |
Constructs a MidiFileFormat . |
MidiFileFormat |
Construct a MidiFileFormat with a set of properties. |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
int |
getByteLength() |
Obtains the length of the MIDI file, expressed in 8-bit bytes. |
float |
getDivisionType() |
Obtains the timing division type for the MIDI file. |
long |
getMicrosecondLength() |
Obtains the length of the MIDI file, expressed in microseconds. |
Object |
getProperty |
Obtain the property value specified by the key. |
int |
getResolution() |
Obtains the timing resolution for the MIDI file. |
int |
getType() |
Obtains the MIDI file type. |
Map<String, |
properties() |
Obtain an unmodifiable map of properties. |
Field Details
UNKNOWN_LENGTH
public static final int UNKNOWN_LENGTH
type
protected int type
divisionType
protected float divisionType
resolution
protected int resolution
byteLength
protected int byteLength
microsecondLength
protected long microsecondLength
Constructor Details
MidiFileFormat
public MidiFileFormat(int type, float divisionType, int resolution, int bytes, long microseconds)
MidiFileFormat
.- Parameters:
-
type
- the MIDI file type (0, 1, or 2) -
divisionType
- the timing division type (PPQ or one of the SMPTE types) -
resolution
- the timing resolution -
bytes
- the length of the MIDI file in bytes, orUNKNOWN_LENGTH
if not known -
microseconds
- the duration of the file in microseconds, orUNKNOWN_LENGTH
if not known - See Also:
MidiFileFormat
public MidiFileFormat(int type, float divisionType, int resolution, int bytes, long microseconds, Map<String,Object> properties)
MidiFileFormat
with a set of properties.- Parameters:
-
type
- the MIDI file type (0, 1, or 2) -
divisionType
- the timing division type (PPQ or one of the SMPTE types) -
resolution
- the timing resolution -
bytes
- the length of the MIDI file in bytes, orUNKNOWN_LENGTH
if not known -
microseconds
- the duration of the file in microseconds, orUNKNOWN_LENGTH
if not known -
properties
- aMap<String,Object>
object with properties - Since:
- 1.5
- See Also:
Method Details
getType
public int getType()
- Returns:
- the file's type (0, 1, or 2)
getDivisionType
public float getDivisionType()
- Returns:
- the division type (PPQ or one of the SMPTE types)
- See Also:
getResolution
public int getResolution()
- Returns:
- the number of ticks per beat (PPQ) or per frame (SMPTE)
- See Also:
getByteLength
public int getByteLength()
- Returns:
- the number of bytes in the file, or
UNKNOWN_LENGTH
if not known - See Also:
getMicrosecondLength
public long getMicrosecondLength()
- Returns:
- the file's duration in microseconds, or
UNKNOWN_LENGTH
if not known - See Also:
properties
public Map<String,Object> properties()
class description
.- Returns:
- a
Map<String,Object>
object containing all properties. If no properties are recognized, an empty map is returned. - Since:
- 1.5
- See Also:
getProperty
public Object getProperty(String key)
class description
. If the specified property is not defined for a particular file format, this method returns null
.
- Parameters:
-
key
- the key of the desired property - Returns:
- the value of the property with the specified key, or
null
if the property does not exist - Since:
- 1.5
- See Also:
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/java.desktop/javax/sound/midi/MidiFileFormat.html