Class Sequencer.SyncMode

Enclosing interface:
Sequencer
public static class Sequencer.SyncMode
extends Object

A SyncMode object represents one of the ways in which a MIDI sequencer's notion of time can be synchronized with a master or slave device. If the sequencer is being synchronized to a master, the sequencer revises its current time in response to messages from the master. If the sequencer has a slave, the sequencer similarly sends messages to control the slave's timing.

There are three predefined modes that specify possible masters for a sequencer: INTERNAL_CLOCK, MIDI_SYNC, and MIDI_TIME_CODE. The latter two work if the sequencer receives MIDI messages from another device. In these two modes, the sequencer's time gets reset based on system real-time timing clock messages or MIDI time code (MTC) messages, respectively. These two modes can also be used as slave modes, in which case the sequencer sends the corresponding types of MIDI messages to its receiver (whether or not the sequencer is also receiving them from a master). A fourth mode, NO_SYNC, is used to indicate that the sequencer should not control its receiver's timing.

See Also:
Sequencer.setMasterSyncMode(SyncMode), Sequencer.setSlaveSyncMode(SyncMode)

Field Summary

Fields
Modifier and Type Field Description
static Sequencer.SyncMode INTERNAL_CLOCK

A master synchronization mode that makes the sequencer get its timing information from its internal clock.

static Sequencer.SyncMode MIDI_SYNC

A master or slave synchronization mode that specifies the use of MIDI clock messages.

static Sequencer.SyncMode MIDI_TIME_CODE

A master or slave synchronization mode that specifies the use of MIDI Time Code.

static Sequencer.SyncMode NO_SYNC

A slave synchronization mode indicating that no timing information should be sent to the receiver.

Constructor Summary

Constructors
Modifier Constructor Description
protected SyncMode​(String name)

Constructs a synchronization mode.

Method Summary

All Methods Instance Methods Concrete Methods
Modifier and Type Method Description
boolean equals​(Object obj)

Indicates whether the specified object is equal to this synchronization mode, returning true if the objects are the same.

int hashCode()

Returns a hash code value for this synchronization mode.

String toString()

Provides this synchronization mode's name as the string representation of the mode.

Methods declared in class java.lang.Object

clone, finalize, getClass, notify, notifyAll, wait, wait, wait

Field Detail

INTERNAL_CLOCK

public static final Sequencer.SyncMode INTERNAL_CLOCK

A master synchronization mode that makes the sequencer get its timing information from its internal clock. This is not a legal slave sync mode.

MIDI_SYNC

public static final Sequencer.SyncMode MIDI_SYNC

A master or slave synchronization mode that specifies the use of MIDI clock messages. If this mode is used as the master sync mode, the sequencer gets its timing information from system real-time MIDI clock messages. This mode only applies as the master sync mode for sequencers that are also MIDI receivers. If this is the slave sync mode, the sequencer sends system real-time MIDI clock messages to its receiver. MIDI clock messages are sent at a rate of 24 per quarter note.

MIDI_TIME_CODE

public static final Sequencer.SyncMode MIDI_TIME_CODE

A master or slave synchronization mode that specifies the use of MIDI Time Code. If this mode is used as the master sync mode, the sequencer gets its timing information from MIDI Time Code messages. This mode only applies as the master sync mode to sequencers that are also MIDI receivers. If this mode is used as the slave sync mode, the sequencer sends MIDI Time Code messages to its receiver. (See the MIDI 1.0 Detailed Specification for a description of MIDI Time Code.)

NO_SYNC

public static final Sequencer.SyncMode NO_SYNC

A slave synchronization mode indicating that no timing information should be sent to the receiver. This is not a legal master sync mode.

Constructor Detail

SyncMode

protected SyncMode​(String name)

Constructs a synchronization mode.

Parameters:
name - name of the synchronization mode

Method Detail

equals

public final boolean equals​(Object obj)

Indicates whether the specified object is equal to this synchronization mode, returning true if the objects are the same.

Overrides:
equals in class Object
Parameters:
obj - the reference object with which to compare
Returns:
true if the specified object is equal to this synchronization mode; false otherwise
See Also:
Object.hashCode(), HashMap

hashCode

public final int hashCode()

Returns a hash code value for this synchronization mode.

Overrides:
hashCode in class Object
Returns:
a hash code value for this synchronization mode
See Also:
Object.equals(java.lang.Object), System.identityHashCode(java.lang.Object)

toString

public final String toString()

Provides this synchronization mode's name as the string representation of the mode.

Overrides:
toString in class Object
Returns:
the name of this synchronization mode