|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- /*
- ==============================================================================
-
- This file is part of the JUCE library.
- Copyright (c) 2017 - ROLI Ltd.
-
- JUCE is an open source library subject to commercial or open-source
- licensing.
-
- The code included in this file is provided under the terms of the ISC license
- http://www.isc.org/downloads/software-support-policy/isc-license. Permission
- To use, copy, modify, and/or distribute this software for any purpose with or
- without fee is hereby granted provided that the above copyright notice and
- this permission notice appear in all copies.
-
- JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
- EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
- DISCLAIMED.
-
- ==============================================================================
- */
-
- namespace juce
- {
-
- MPESynthesiserBase::MPESynthesiserBase()
- : instrument (new MPEInstrument),
- sampleRate (0),
- minimumSubBlockSize (32),
- subBlockSubdivisionIsStrict (false)
- {
- instrument->addListener (this);
- }
-
- MPESynthesiserBase::MPESynthesiserBase (MPEInstrument* inst)
- : instrument (inst),
- sampleRate (0),
- minimumSubBlockSize (32)
- {
- jassert (instrument != nullptr);
- instrument->addListener (this);
- }
-
- //==============================================================================
- MPEZoneLayout MPESynthesiserBase::getZoneLayout() const noexcept
- {
- return instrument->getZoneLayout();
- }
-
- void MPESynthesiserBase::setZoneLayout (MPEZoneLayout newLayout)
- {
- instrument->setZoneLayout (newLayout);
- }
-
- //==============================================================================
- void MPESynthesiserBase::enableLegacyMode (int pitchbendRange, Range<int> channelRange)
- {
- instrument->enableLegacyMode (pitchbendRange, channelRange);
- }
-
- bool MPESynthesiserBase::isLegacyModeEnabled() const noexcept
- {
- return instrument->isLegacyModeEnabled();
- }
-
- Range<int> MPESynthesiserBase::getLegacyModeChannelRange() const noexcept
- {
- return instrument->getLegacyModeChannelRange();
- }
-
- void MPESynthesiserBase::setLegacyModeChannelRange (Range<int> channelRange)
- {
- instrument->setLegacyModeChannelRange (channelRange);
- }
-
- int MPESynthesiserBase::getLegacyModePitchbendRange() const noexcept
- {
- return instrument->getLegacyModePitchbendRange();
- }
-
- void MPESynthesiserBase::setLegacyModePitchbendRange (int pitchbendRange)
- {
- instrument->setLegacyModePitchbendRange (pitchbendRange);
- }
-
- //==============================================================================
- void MPESynthesiserBase::setPressureTrackingMode (TrackingMode modeToUse)
- {
- instrument->setPressureTrackingMode (modeToUse);
- }
-
- void MPESynthesiserBase::setPitchbendTrackingMode (TrackingMode modeToUse)
- {
- instrument->setPitchbendTrackingMode (modeToUse);
- }
-
- void MPESynthesiserBase::setTimbreTrackingMode (TrackingMode modeToUse)
- {
- instrument->setTimbreTrackingMode (modeToUse);
- }
-
- //==============================================================================
- void MPESynthesiserBase::handleMidiEvent (const MidiMessage& m)
- {
- instrument->processNextMidiEvent (m);
- }
-
- //==============================================================================
- template <typename floatType>
- void MPESynthesiserBase::renderNextBlock (AudioBuffer<floatType>& outputAudio,
- const MidiBuffer& inputMidi,
- int startSample,
- int numSamples)
- {
- // you must set the sample rate before using this!
- jassert (sampleRate != 0);
-
- MidiBuffer::Iterator midiIterator (inputMidi);
- midiIterator.setNextSamplePosition (startSample);
-
- bool firstEvent = true;
- int midiEventPos;
- MidiMessage m;
-
- const ScopedLock sl (noteStateLock);
-
- while (numSamples > 0)
- {
- if (! midiIterator.getNextEvent (m, midiEventPos))
- {
- renderNextSubBlock (outputAudio, startSample, numSamples);
- return;
- }
-
- const int samplesToNextMidiMessage = midiEventPos - startSample;
-
- if (samplesToNextMidiMessage >= numSamples)
- {
- renderNextSubBlock (outputAudio, startSample, numSamples);
- handleMidiEvent (m);
- break;
- }
-
- if (samplesToNextMidiMessage < ((firstEvent && ! subBlockSubdivisionIsStrict) ? 1 : minimumSubBlockSize))
- {
- handleMidiEvent (m);
- continue;
- }
-
- firstEvent = false;
-
- renderNextSubBlock (outputAudio, startSample, samplesToNextMidiMessage);
- handleMidiEvent (m);
- startSample += samplesToNextMidiMessage;
- numSamples -= samplesToNextMidiMessage;
- }
-
- while (midiIterator.getNextEvent (m, midiEventPos))
- handleMidiEvent (m);
- }
-
- // explicit instantiation for supported float types:
- template void MPESynthesiserBase::renderNextBlock<float> (AudioBuffer<float>&, const MidiBuffer&, int, int);
- template void MPESynthesiserBase::renderNextBlock<double> (AudioBuffer<double>&, const MidiBuffer&, int, int);
-
- //==============================================================================
- void MPESynthesiserBase::setCurrentPlaybackSampleRate (const double newRate)
- {
- if (sampleRate != newRate)
- {
- const ScopedLock sl (noteStateLock);
- instrument->releaseAllNotes();
- sampleRate = newRate;
- }
- }
-
- //==============================================================================
- void MPESynthesiserBase::setMinimumRenderingSubdivisionSize (int numSamples, bool shouldBeStrict) noexcept
- {
- jassert (numSamples > 0); // it wouldn't make much sense for this to be less than 1
- minimumSubBlockSize = numSamples;
- subBlockSubdivisionIsStrict = shouldBeStrict;
- }
-
- } // namespace juce
|