Skip to content

Commit

Permalink
[WIP] Merge remote-tracking branch 'origin/wip/soft-pitch-ramp' into …
Browse files Browse the repository at this point in the history
…'staging'
  • Loading branch information
cr7pt0gr4ph7 committed Oct 21, 2024
2 parents 035e807 + 91036cb commit 2d79742
Show file tree
Hide file tree
Showing 2 changed files with 165 additions and 17 deletions.
171 changes: 154 additions & 17 deletions src/engine/controls/ratecontrol.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -140,6 +140,28 @@ RateControl::RateControl(const QString& group,
m_pButtonRateTempUpSmall =
new ControlPushButton(ConfigKey(group,"rate_temp_up_small"));

// This also changes the behavior of the rate_*_up/down controls
// to affect the soft ramp target rate instead of the current rate.
m_pButtonSoftRampEnabled =
new ControlPushButton(ConfigKey(group, "soft_ramp_enabled"));
m_pButtonSoftRampEnabled->setButtonMode(mixxx::control::ButtonMode::Toggle);

// Indicator for whether a soft rate ramp is currently in progress,
// and in which direction (+1 = speeding up, -1 = slowing down,
// 0 = inactive)
m_pSoftRampDirection =
new ControlObject(ConfigKey(group, "soft_ramp_dir"));

// The target of the soft rate ramp. Allow it to go out of bounds
// like the rate slider so that sync lock rate adjustments are not capped.
m_pSoftRampTargetSlider = new ControlPotmeter(
ConfigKey(group, "soft_ramp_target"), -1.0, 1.0, true);

// How fast the playback rate changes during a soft rate ramp.
// The unit is "percent per second".
m_pSoftRampSpeed = new ControlPotmeter(
ConfigKey(group, "soft_ramp_speed"), 0.0, 1.0, false, true, false, true, 0.01);

// We need the sample rate so we can guesstimate something close
// what latency is.
m_pSampleRate = ControlObject::getControl(
Expand Down Expand Up @@ -205,6 +227,11 @@ RateControl::~RateControl() {
delete m_pButtonRatePermUp;
delete m_pButtonRatePermUpSmall;

delete m_pSoftRampDirection;
delete m_pButtonSoftRampEnabled;
delete m_pSoftRampTargetSlider;
delete m_pSoftRampSpeed;

delete m_pWheel;
delete m_pScratch2;
delete m_pScratch2Scratching;
Expand Down Expand Up @@ -283,11 +310,45 @@ double RateControl::getPermanentRateChangeFineAmount() {
}

void RateControl::slotRateRangeChanged(double) {
// update RateSlider with the new Range value butdo not change m_pRateRatio
// Update RateSlider with the new Range value but do not change m_pRateRatio
slotRateRatioChanged(m_pRateRatio->get());
}

void RateControl::slotRateSliderChanged(double v) {
if (!m_pButtonSoftRampEnabled->toBool()) {
// Keep the soft ramp target slider in sync with
// the rate slider while soft ramping is disabled.
// Setting one of the two immediately sets the other as well.
m_pSoftRampTargetSlider->set(v);
}

setRateRatioFromSlider(v);
}

void RateControl::slotSoftRampEnabledChanged(double v) {
updateSoftRampState();

if (v == 0.0) {
// Keep the soft ramp target slider in sync with
// the rate slider while soft ramping is disabled.
m_pSoftRampTargetSlider->set(m_pRateSlider->get());
}
}

void RateControl::slotSoftRampTargetSliderChanged(double v) {
if (m_pButtonSoftRampEnabled->toBool()) {
// Soft ramping is enabled
updateSoftRampState();
} else {
// Keep the soft ramp target slider in sync with
// the rate slider while soft ramping is disabled.
// Setting one of the two immediately sets the other as well.
m_pRateSlider->set(v);
setRateRatioFromSlider(v);
}
}

void RateControl::setRateRatioFromSlider(double v) {
double rateRatio = 1.0 + m_pRateDir->get() * m_pRateRange->get() * v;
m_pRateRatio->set(rateRatio);
}
Expand Down Expand Up @@ -330,39 +391,47 @@ void RateControl::slotControlFastBack(double v) {
}
}

void RateControl::moveRateSlider(double amount) {
const double effectiveAmount =
m_pRateDir->get() * amount / (100 * m_pRateRange->get());

if (m_pButtonSoftRampEnabled->toBool()) {
// Soft ramp mode: Affect the soft ramp target
m_pSoftRampTargetSlider->set(m_pSoftRampTargetSlider->get() + effectiveAmount);
slotSoftRampTargetSliderChanged(m_pSoftRampTargetSlider->get());
updateSoftRampState();
} else {
// Normal behavior: Affect the rate slider directly
m_pRateSlider->set(m_pRateSlider->get() + effectiveAmount);
slotRateSliderChanged(m_pRateSlider->get());
}
}

void RateControl::slotControlRatePermDown(double v) {
// Adjusts temp rate down if button pressed
// Adjusts perm rate down if button pressed
if (v > 0.0) {
m_pRateSlider->set(m_pRateSlider->get() -
m_pRateDir->get() * m_dPermanentRateChangeCoarse.getValue() / (100 * m_pRateRange->get()));
slotRateSliderChanged(m_pRateSlider->get());
moveRateSlider(-m_dPermanentRateChangeCoarse.getValue());
}
}

void RateControl::slotControlRatePermDownSmall(double v) {
// Adjusts temp rate down if button pressed
// Adjusts perm rate down if button pressed
if (v > 0.0) {
m_pRateSlider->set(m_pRateSlider->get() -
m_pRateDir->get() * m_dPermanentRateChangeFine.getValue() / (100. * m_pRateRange->get()));
slotRateSliderChanged(m_pRateSlider->get());
moveRateSlider(-m_dPermanentRateChangeFine.getValue());
}
}

void RateControl::slotControlRatePermUp(double v) {
// Adjusts temp rate up if button pressed
// Adjusts perm rate up if button pressed
if (v > 0.0) {
m_pRateSlider->set(m_pRateSlider->get() +
m_pRateDir->get() * m_dPermanentRateChangeCoarse.getValue() / (100. * m_pRateRange->get()));
slotRateSliderChanged(m_pRateSlider->get());
moveRateSlider(m_dPermanentRateChangeCoarse.getValue());
}
}

void RateControl::slotControlRatePermUpSmall(double v) {
// Adjusts temp rate up if button pressed
// Adjusts perm rate up if button pressed
if (v > 0.0) {
m_pRateSlider->set(m_pRateSlider->get() +
m_pRateDir->get() * m_dPermanentRateChangeFine.getValue() / (100. * m_pRateRange->get()));
slotRateSliderChanged(m_pRateSlider->get());
moveRateSlider(m_dPermanentRateChangeFine.getValue());
}
}

Expand Down Expand Up @@ -402,6 +471,7 @@ double RateControl::calculateSpeed(double baserate, double speed, bool paused,
*pReportReverse = false;

processTempRate(iSamplesPerBuffer);
processSoftRamp(iSamplesPerBuffer);

double rate;
const double searching = m_pRateSearch->get();
Expand Down Expand Up @@ -510,6 +580,73 @@ double RateControl::calculateSpeed(double baserate, double speed, bool paused,
return rate;
}

void RateControl::updateSoftRampState() {
if (!m_pButtonSoftRampEnabled->toBool()) {
m_pSoftRampDirection->set(0.0);
return;
}

const double targetValue = m_pSoftRampTargetSlider->get();
const double currentValue = m_pRateSlider->get();

if (targetValue == currentValue) {
// RampDirection::None
m_pSoftRampDirection->set(0.0);
return;
} else if (currentValue < targetValue) {
// RampDirection::Up
m_pSoftRampDirection->set(1.0);
} else {
// RampDirection::Down
m_pSoftRampDirection->set(-1.0);
}
}

void RateControl::processSoftRamp(const int bufferSamples) {
if (!m_pButtonSoftRampEnabled->toBool()) {
// RampDirection::None
m_pSoftRampDirection->set(0.0);
return;
}

const double targetValue = m_pSoftRampTargetSlider->get();
const double currentValue = m_pRateSlider->get();

if (targetValue == currentValue) {
// RampDirection::None
m_pSoftRampDirection->set(0.0);
return;
}

const double amount = bufferSamples / m_pSampleRate->get() * m_pSoftRampSpeed->get();
double newValue = currentValue;

if (currentValue < targetValue) {
newValue = currentValue + amount;
if (newValue > targetValue) {
// RampDirection::None
m_pSoftRampDirection->set(0.0);
newValue = targetValue;
} else {
// RampDirection::Up
m_pSoftRampDirection->set(1.0);
}
} else {
newValue = currentValue - amount;
if (newValue < targetValue) {
// RampDirection::None
m_pSoftRampDirection->set(0.0);
newValue = targetValue;
} else {
// RampDirection::Down
m_pSoftRampDirection->set(-1.0);
}
}

m_pRateSlider->set(newValue);
setRateRatioFromSlider(newValue);
}

void RateControl::processTempRate(const int bufferSamples) {
// Code to handle temporary rate change buttons.
// We support two behaviors, the standard ramped pitch bending
Expand Down
11 changes: 11 additions & 0 deletions src/engine/controls/ratecontrol.h
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,8 @@ public slots:
void slotRateSliderChanged(double);
void slotRateRatioChanged(double);
void slotReverseRollActivate(double);
void slotSoftRampEnabledChanged(double);
void slotSoftRampTargetSliderChanged(double);
void slotControlRatePermDown(double);
void slotControlRatePermDownSmall(double);
void slotControlRatePermUp(double);
Expand All @@ -90,6 +92,10 @@ public slots:
void slotControlFastBack(double);

private:
void updateSoftRampState();
void moveRateSlider(double amount);
void setRateRatioFromSlider(double v);
void processSoftRamp(const int bufferSamples);
void processTempRate(const int bufferSamples);
double getJogFactor() const;
double getWheelFactor() const;
Expand Down Expand Up @@ -132,6 +138,11 @@ public slots:
ControlObject* m_pBackButton;
ControlObject* m_pForwardButton;

ControlObject* m_pSoftRampDirection;
ControlPushButton* m_pButtonSoftRampEnabled;
ControlPotmeter* m_pSoftRampTargetSlider;
ControlPotmeter* m_pSoftRampSpeed;

ControlTTRotary* m_pWheel;
ControlObject* m_pScratch2;
PositionScratchController* m_pScratchController;
Expand Down

0 comments on commit 2d79742

Please sign in to comment.