X-Git-Url: https://ruin.nu/git/?p=moosique.git;a=blobdiff_plain;f=MooInstrumentList.java;h=91f8eea239733139899db97a5401ed8b585f978b;hp=388a9d6b4dc3d3748f82c826eee97428af0fbb93;hb=HEAD;hpb=347729cadd1844ab1de02fff8559119abea2e483 diff --git a/MooInstrumentList.java b/MooInstrumentList.java index 388a9d6..91f8eea 100644 --- a/MooInstrumentList.java +++ b/MooInstrumentList.java @@ -11,17 +11,22 @@ import java.awt.event.*; public class MooInstrumentList extends JComboBox implements ActionListener { - protected int channel; + private int channel; + private ShortMessage programChangeMessage; public static final int INSTRUMENTS = 0, DRUMS = 1; /** * Creates the instrument list. - * @param chan The channel it will operate on. + * @param chan the channel it will operate on. + * @param type one of the constants: INSTRUMENTS and DRUMS + * @param chan the MIDI message assigning the initial program change */ - public MooInstrumentList(int chan, int listType) { + public MooInstrumentList(int chan, int listType, ShortMessage programMsg) { super(instruments[listType]); + programChangeMessage = programMsg; + if (programChangeMessage != null) setSelectedIndex(programChangeMessage.getData1()); setChannel(chan); - setFont(new Font("Helvetica", Font.PLAIN, 10)); + setFont(Moosique.getGUI().FONT); addActionListener(this); } @@ -30,20 +35,22 @@ public class MooInstrumentList extends JComboBox implements ActionListener { */ public void setChannel(int chan) { channel = chan; - setSelectedIndex(Moosique.getChannel(channel).getProgram()); + try {programChangeMessage.setMessage(programChangeMessage.getCommand(), chan, programChangeMessage.getData1(), 0);} + catch (Exception e) {} } /** * Sets the instrument on a channel when it's changed in the combobox. */ public void actionPerformed(ActionEvent e) { - JComboBox box = (JComboBox)e.getSource(); - int instrument = box.getSelectedIndex(); + int instrument = ((JComboBox)e.getSource()).getSelectedIndex(); Moosique.getChannel(channel).programChange(instrument); + try {programChangeMessage.setMessage(programChangeMessage.getCommand(), programChangeMessage.getChannel(), instrument, 0);} + catch (InvalidMidiDataException ex) {} } /** - * The list with standard midi instruments. + * The list with standard MIDI instruments. */ public static final String[][] instruments = {{ " 0 Acoustic Grand Piano",