make sample rate changeable, probably
This commit is contained in:
		| @ -12,6 +12,7 @@ FluidSynthModel::FluidSynthModel(SharesParams& p) | |||||||
|           synth(nullptr), |           synth(nullptr), | ||||||
|           settings(nullptr), |           settings(nullptr), | ||||||
|           currentSoundFontAbsPath(), |           currentSoundFontAbsPath(), | ||||||
|  |           currentSampleRate(44100), | ||||||
|           initialised(false), |           initialised(false), | ||||||
|           sfont_id(0), |           sfont_id(0), | ||||||
|           channel(0) |           channel(0) | ||||||
| @ -38,6 +39,7 @@ void FluidSynthModel::initialise() { | |||||||
|     fluid_settings_setstr(settings, "synth.verbose", "yes"); |     fluid_settings_setstr(settings, "synth.verbose", "yes"); | ||||||
|  |  | ||||||
|     synth = new_fluid_synth(settings); |     synth = new_fluid_synth(settings); | ||||||
|  |     fluid_synth_set_sample_rate(synth, currentSampleRate); | ||||||
|  |  | ||||||
|     if (sharesParams.getSoundFontPath().isNotEmpty()) { |     if (sharesParams.getSoundFontPath().isNotEmpty()) { | ||||||
|         loadFont(sharesParams.getSoundFontPath()); |         loadFont(sharesParams.getSoundFontPath()); | ||||||
| @ -202,4 +204,13 @@ void FluidSynthModel::addListener (FluidSynthModel::Listener* const newListener) | |||||||
| void FluidSynthModel::removeListener (FluidSynthModel::Listener* const listener) | void FluidSynthModel::removeListener (FluidSynthModel::Listener* const listener) | ||||||
| { | { | ||||||
|     eventListeners.remove(listener); |     eventListeners.remove(listener); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void FluidSynthModel::setSampleRate(float sampleRate) { | ||||||
|  |     currentSampleRate = sampleRate; | ||||||
|  |     if (!initialised) { | ||||||
|  |         // don't worry; we'll do this in initialise phase regardless | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|  |     fluid_synth_set_sample_rate(synth, sampleRate); | ||||||
| } | } | ||||||
| @ -59,6 +59,8 @@ public: | |||||||
|     */ |     */ | ||||||
|     void removeListener (Listener* listener); |     void removeListener (Listener* listener); | ||||||
|  |  | ||||||
|  |     void setSampleRate(float sampleRate); | ||||||
|  |  | ||||||
|     const String& getCurrentSoundFontAbsPath(); |     const String& getCurrentSoundFontAbsPath(); | ||||||
|  |  | ||||||
| private: | private: | ||||||
| @ -70,6 +72,8 @@ private: | |||||||
|  |  | ||||||
|     String currentSoundFontAbsPath; |     String currentSoundFontAbsPath; | ||||||
|  |  | ||||||
|  |     float currentSampleRate; | ||||||
|  |  | ||||||
|     const fluid_preset_t getFirstPreset(); |     const fluid_preset_t getFirstPreset(); | ||||||
|     void selectFirstPreset(); |     void selectFirstPreset(); | ||||||
|     unique_ptr<BankAndPreset> getFirstBankAndPreset(); |     unique_ptr<BankAndPreset> getFirstBankAndPreset(); | ||||||
|  | |||||||
| @ -111,6 +111,7 @@ void JuicySFAudioProcessor::prepareToPlay (double sampleRate, int /*samplesPerBl | |||||||
|     // initialisation that you need.. |     // initialisation that you need.. | ||||||
|     synth.setCurrentPlaybackSampleRate (sampleRate); |     synth.setCurrentPlaybackSampleRate (sampleRate); | ||||||
|     keyboardState.reset(); |     keyboardState.reset(); | ||||||
|  |     fluidSynthModel.setSampleRate(static_cast<float>(sampleRate)); | ||||||
|  |  | ||||||
|     reset(); |     reset(); | ||||||
| } | } | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user