24 threshold(threshold), ratio(ratio), attack(attack),
25 release(release), makeup_gain(makeup_gain), bypass(bypass)
28 init_effect_details();
32 void Expander::init_effect_details()
40 info.
description =
"Louder parts of audio becomes relatively louder and quieter parts becomes quieter.";
52 std::shared_ptr<openshot::Frame>
Expander::GetFrame(std::shared_ptr<openshot::Frame> frame, int64_t frame_number)
55 const int num_input_channels = frame->audio->getNumChannels();
56 const int num_output_channels = frame->audio->getNumChannels();
57 const int num_samples = frame->audio->getNumSamples();
68 for (
int channel = 0; channel < num_input_channels; ++channel)
69 mixed_down_input.addFrom(0, 0, *frame->audio, channel, 0, num_samples, 1.0f / num_input_channels);
71 for (
int sample = 0; sample < num_samples; ++sample) {
79 const float average_factor = 0.9999f;
87 yg = T + (xg - T) * R;
92 yl = alphaA *
yl_prev + (1.0f - alphaA) * xl;
94 yl = alphaR *
yl_prev + (1.0f - alphaR) * xl;
97 control = powf (10.0f, (gain - yl) * 0.05f);
100 for (
int channel = 0; channel < num_input_channels; ++channel) {
101 float new_value = frame->audio->getSample(channel, sample)*
control;
102 frame->audio->setSample(channel, sample, new_value);
106 for (
int channel = num_input_channels; channel < num_output_channels; ++channel)
107 frame->audio->clear(channel, 0, num_samples);
155 catch (
const std::exception& e)
158 throw InvalidJSON(
"JSON is invalid (missing keys or invalid data types)");
169 if (!root[
"threshold"].isNull())
172 if (!root[
"ratio"].isNull())
175 if (!root[
"attack"].isNull())
178 if (!root[
"release"].isNull())
181 if (!root[
"makeup_gain"].isNull())
184 if (!root[
"bypass"].isNull())
193 root[
"id"] =
add_property_json(
"ID", 0.0,
"string",
Id(), NULL, -1, -1,
true, requested_frame);
195 root[
"start"] =
add_property_json(
"Start",
Start(),
"float",
"", NULL, 0, 1000 * 60 * 30,
false, requested_frame);
196 root[
"end"] =
add_property_json(
"End",
End(),
"float",
"", NULL, 0, 1000 * 60 * 30,
false, requested_frame);
197 root[
"duration"] =
add_property_json(
"Duration",
Duration(),
"float",
"", NULL, 0, 1000 * 60 * 30,
true, requested_frame);
208 return root.toStyledString();
Expander()
Default constructor.
float inverse_sample_rate
std::string Id() const
Get the Id of this clip object.
float Start() const
Get start position (in seconds) of clip (trim start of video)
virtual void SetJsonValue(const Json::Value root)
Load Json::Value into this object.
std::string PropertiesJSON(int64_t requested_frame) const override
std::string Json() const override
Generate JSON string of this object.
virtual float End() const
Get end position (in seconds) of clip (trim end of video)
const Json::Value stringToJson(const std::string value)
virtual Json::Value JsonValue() const
Generate Json::Value for this object.
bool has_audio
Determines if this effect manipulates the audio of a frame.
Header file for Expander audio effect class.
Header file for all Exception classes.
Header file for Frame class.
void SetJsonValue(const Json::Value root) override
Load Json::Value into this object.
float calculateAttackOrRelease(float value)
std::string class_name
The class name of the effect.
std::string name
The name of the effect.
float Duration() const
Get the length of this clip (in seconds)
void SetJsonValue(const Json::Value root)
Load Json::Value into this object.
This class adds a expander (or noise gate) into the audio.
This namespace is the default namespace for all code in the openshot library.
Json::Value JsonValue() const
Generate Json::Value for this object.
std::string description
The description of this effect and what it does.
bool has_video
Determines if this effect manipulates the image of a frame.
Exception for invalid JSON.
double GetValue(int64_t index) const
Get the value at a specific index.
std::shared_ptr< openshot::Frame > GetFrame(int64_t frame_number) override
This method is required for all derived classes of ClipBase, and returns a new openshot::Frame object...
juce::AudioBuffer< float > mixed_down_input
A Keyframe is a collection of Point instances, which is used to vary a number or property over time...
Json::Value add_property_json(std::string name, float value, std::string type, std::string memo, const Keyframe *keyframe, float min_value, float max_value, bool readonly, int64_t requested_frame) const
Generate JSON for a property.
int Layer() const
Get layer of clip on timeline (lower number is covered by higher numbers)
Json::Value JsonValue() const override
Generate Json::Value for this object.
void SetJson(const std::string value) override
Load JSON string into this object.
EffectInfoStruct info
Information about the current effect.