The code that sends out Control Changes in Rosegarden is pretty convoluted. This document points out the key areas of interest. Hopefully this will ease future maintenance.
Note that code related to sending out Bank Selects and Program Changes can be found along with the code related to Control Changes. This will be pointed out below.
This preference sends a CC 121 at file load and at playback in the middle of a Segment. The 121 happens prior to sending any other controllers to set up the channel.
The user can turn this on and off in the MIDI preferences:
Edit > Preferences... > MIDI > General tab
The MIDI preferences are displayed by the MIDIConfigurationPage
class. The preference itself is stored in Rosegarden.conf as follows:
[Sequencer_Options] allowresetallcontrollers=true
This is a preference that is only available via the Rosegarden.conf file.
[Sequencer_Options] forceChannelSetups=false
When set to true, channel setups will be sent out every time play is pressed. If outside of a Segment, the channel setups will be based on the track values in the Instrument Parameters panel (MIPP).
The default for this preference is false.
To get there: Studio > Manage MIDI Devices > pick a playback device > Controllers…
The ControlEditorDialog
class is the “Manage Controllers” dialog.
A better name for this class might be “ManageControllers
”.
Controllers can be added, modified and deleted here. Deleting a controller here will prevent it from ever being sent out at composition load time, and playback time.
The MIDIInstrumentParameterPanel
class is the “Instrument Parameters” panel that appears in the lower left when a MIDI track is selected. Here the user can adjust the initial settings for the various controllers that were configured in the “Manage Controllers” dialog for a Device.
The ControllerEventsRuler
class provides the controller rulers that can be displayed in both the Matrix and Notation editors. These can be enabled from both editors by:
View > Rulers > Add Control Ruler > ...
Or for the pitchbend ruler:
View > Rulers > Show Pitch Bend Ruler
The PitchbendSequenceDialog
class provides both the controller sequence dialogs and the “PitchBend Sequence” dialog.
These dialogs are accessible from both the Matrix and Notation editors:
Controllers > Insert Controller Sequence... Controllers > Insert Pitch Bend Sequence...
Both of these dialogs require that a note be selected in order to launch them. The menu items will be disabled if no note is selected. Also, for the controller sequence dialog, a controller ruler must be enabled and selected.
Call diagram. “>” means “calls”.
- RosegardenMainWindow::setDocument() > RosegardenDocument::initialiseStudio() > RosegardenDocument::sendChannelSetups() (added January 2021) > Instrument::sendChannelSetup()
RosegardenDocument::initialiseStudio()
RosegardenDocument::sendChannelSetups()
Instrument::sendChannelSetup()
- InternalSegmentMapper::makeReady() > InternalSegmentMapper::getControllers() > InternalSegmentMapper::getControllerValue() > ControllerContextMap::getControllerValue() > ChannelManager::makeReady()
InternalSegmentMapper::getControllers()
to get the controllers that are needed for a channel setup.ChannelManager::makeReady()
to set up the channel.ControllerContextMap::getControllerValue()
which gets the current CC values when in the middle of a Segment.Segment
.Segment
, sends out a channel setup.If changes are made to the way CCs are sent, MIDI export needs to be regression tested to make sure nothing breaks.
- MidiFile::convertToMidi() > MappedBufMetaIterator::fetchFixedChannelSetup(inserter) > InternalSegmentMapper::insertChannelSetup(inserter) > ChannelManager::insertChannelSetup(TrackId, RealTime, ...)