-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
make better use of intro/outro markers with AutoDJ #2103
Changes from 5 commits
0147a4f
7163fd3
7cfe38e
febce9b
450d409
c45b27f
580c20b
bad1178
648aaa7
6532bd7
3e11cf5
45f68e4
04b02f7
b1a74b5
1fa74b0
eec6bad
d3748e9
bc78357
caaff2d
b02feb0
c7cbebd
8a6dc26
3971e4a
adb4b14
5df43f6
cbe8b37
d3910ed
98d9daa
e5571d7
bf7a20c
313e894
a38c0b3
2320643
222a991
97597d3
c1dd217
66c42b1
187e5a9
6c7b335
5faf0de
242ab69
fc5eb53
a1b1038
0bc0587
9c43bac
4c035dc
c7ba79c
4393cc6
fb7114e
0697e5a
80557fc
cd3896c
422429a
4492823
9b562c9
06beddc
d80648e
29ab888
eaca9ff
f640846
6850e7f
499146a
6f98fd4
825912c
570e50c
6e7f171
71c7acf
032dc1f
d212dd9
e109bf1
c7a1d1d
d87db38
c0052a9
33ac5c5
7b8aade
a4d8b4e
adcbc3a
a5d3b9f
8e4669c
72dd93c
689b5a0
79c1b00
d315f0c
a1174e0
b52de8a
c3108c6
c48afb0
f8c5633
f6153cc
3fc81c7
8784be7
73089e5
932c48c
1263b46
e69c34b
461b7ca
f846e67
bd39923
7cdb5ed
429da12
611503c
8e6268b
2e045d3
888464b
05beecf
620e5f6
107c61d
aa05871
654e984
1ed918c
fbb274c
9d66c63
2f8d524
ddd872b
1f93568
0a5c8d6
f62e4ee
7189270
651b620
561bc5e
e2b5dba
0bf4166
4f753c9
7fd8e71
8d26c08
05351e6
29c31f4
be58358
500cb4d
6e1932c
af9a2ff
bcc8d16
0bcd3f4
2e6f6fd
5f3bc70
4b6567f
4a6dab2
381ba21
d15eee1
cdb8148
0fd21f9
3a7df2e
f13bb5d
ccdcb47
ab21ba9
d5b11cf
27c0b6d
d635329
36e31e5
d284d5e
2003966
3d7320b
f576021
6a4ea7c
11ce939
f97d31e
a44daca
8d23116
ece0161
5ab052d
77d25ad
0b79250
b2d35ef
187024f
b2d8bdd
0a2fda2
4970f0b
dd77030
0bc70f6
61e2e28
65fc8d0
1d97fb6
e997ff1
33adf4b
e1726f3
cba9dce
a15169e
b204342
ee9cfcc
28d5066
d855e37
0663bab
7daa180
eb2b0ba
c00eb3f
e53e9e5
01f354f
2076520
8757fdf
0d02783
aea297c
4c7b352
265b3c6
1fd1a04
010fd5c
e93ee52
c1010a6
cf658a9
df29633
2b1f525
5e6988e
74fdcb8
277f5da
96a5a45
873e313
d6e6cf4
70214df
e1c45e5
6dac3a6
fd36927
2f88f54
7036b74
9951daa
db49654
efa6c00
7658b51
e9bee7f
d099f04
10a4949
7a6bdc7
a744e43
5aafbd2
ea3f2b9
082e2e6
1ab1853
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -56,7 +56,9 @@ CueControl::CueControl(QString group, | |
|
||
m_pCueMode = new ControlObject(ConfigKey(group, "cue_mode")); | ||
|
||
m_pSeekOnLoadMode = new ControlObject(ConfigKey(group, "seekonload_mode")); | ||
m_pSeekOnLoadModeAutoDjOverride = new ControlObject(ConfigKey(group, "seekonload_mode_autodj")); | ||
m_pSeekOnLoadModeAutoDjOverride->set(static_cast<double>( | ||
static_cast<int>(SeekOnLoadMode::UsePreference))); | ||
|
||
m_pCueSet = new ControlPushButton(ConfigKey(group, "cue_set")); | ||
m_pCueSet->setButtonMode(ControlPushButton::TRIGGER); | ||
|
@@ -207,7 +209,7 @@ CueControl::CueControl(QString group, | |
CueControl::~CueControl() { | ||
delete m_pCuePoint; | ||
delete m_pCueMode; | ||
delete m_pSeekOnLoadMode; | ||
delete m_pSeekOnLoadModeAutoDjOverride; | ||
delete m_pCueSet; | ||
delete m_pCueClear; | ||
delete m_pCueGoto; | ||
|
@@ -347,29 +349,26 @@ void CueControl::trackLoaded(TrackPointer pNewTrack) { | |
loadCuesFromTrack(); | ||
|
||
// Seek track according to SeekOnLoadMode. | ||
SeekOnLoadMode seekOnLoadMode = getSeekOnLoadMode(); | ||
SeekOnLoadMode seekOnLoadMode = getSeekOnLoadModeAutoDjOverride(); | ||
if (seekOnLoadMode == SeekOnLoadMode::UsePreference) { | ||
seekOnLoadMode = getSeekOnLoadPreference(); | ||
} | ||
switch (seekOnLoadMode) { | ||
case SEEK_ON_LOAD_ZERO_POS: | ||
seekExact(0.0); | ||
case SeekOnLoadMode::Beginning: | ||
// This allows users to load tracks and have the needle-drop be maintained. | ||
if (!(m_pVinylControlEnabled->get() && | ||
m_pVinylControlMode->get() == MIXXX_VCMODE_ABSOLUTE)) { | ||
seekExact(0.0); | ||
} | ||
break; | ||
case SEEK_ON_LOAD_MAIN_CUE: | ||
case SeekOnLoadMode::MainCue: | ||
seekExact(m_pCuePoint->get()); | ||
break; | ||
case SEEK_ON_LOAD_INTRO_CUE: | ||
case SeekOnLoadMode::IntroStart: | ||
seekExact(m_pIntroStartPosition->get()); | ||
break; | ||
default: | ||
// Respect cue recall preference option. | ||
if (isCueRecallEnabled() && m_pCuePoint->get() != -1.0) { | ||
// If cue recall is ON and main cue point is set, seek to it. | ||
seekExact(m_pCuePoint->get()); | ||
} else if (!(m_pVinylControlEnabled->get() && | ||
m_pVinylControlMode->get() == MIXXX_VCMODE_ABSOLUTE)) { | ||
// Otherwise, seek to zero unless vinylcontrol is on and | ||
// set to absolute. This allows users to load tracks and | ||
// have the needle-drop be maintained. | ||
seekExact(0.0); | ||
} | ||
seekExact(0.0); | ||
break; | ||
} | ||
} | ||
|
@@ -491,16 +490,16 @@ void CueControl::reloadCuesFromTrack() { | |
double intro = m_pIntroStartPosition->get(); | ||
|
||
// Make track follow the updated cues. | ||
SeekOnLoadMode seekOnLoadMode = getSeekOnLoadMode(); | ||
if (seekOnLoadMode == SEEK_ON_LOAD_DEFAULT) { | ||
if ((trackAt == TrackAt::Cue || wasTrackAtZeroPos) && cue != -1.0 && isCueRecallEnabled()) { | ||
seekExact(cue); | ||
} | ||
} else if (seekOnLoadMode == SEEK_ON_LOAD_MAIN_CUE) { | ||
SeekOnLoadMode seekOnLoadMode = getSeekOnLoadModeAutoDjOverride(); | ||
if (seekOnLoadMode == SeekOnLoadMode::UsePreference) { | ||
seekOnLoadMode = getSeekOnLoadPreference(); | ||
} | ||
|
||
if (seekOnLoadMode == SeekOnLoadMode::MainCue) { | ||
if ((trackAt == TrackAt::Cue || wasTrackAtZeroPos) && cue != -1.0) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. use kNoTrigger and everywhere else in this file There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Can we put this off? I am not trying to refactor all the code. This PR has already had to deal with lots of merge conflicts because of making big changes and sitting unmerged for months. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It was introduced in this PR that we use kNoTrigger, originally introduced for looping also for cue points. It is ok for me to reuse this constant for cue here, but that means to update all occurences. Without this, there is a risk of errors in case we decide later to move a way from the -1 that is unfortunate a valid cue point on the lead in. |
||
seekExact(cue); | ||
} | ||
} else if (seekOnLoadMode == SEEK_ON_LOAD_INTRO_CUE) { | ||
} else if (seekOnLoadMode == SeekOnLoadMode::IntroStart) { | ||
if ((wasTrackAtIntroCue || wasTrackAtZeroPos) && intro != -1.0) { | ||
Be-ing marked this conversation as resolved.
Show resolved
Hide resolved
|
||
seekExact(intro); | ||
} | ||
|
@@ -1631,13 +1630,14 @@ bool CueControl::isPlayingByPlayButton() { | |
!m_iCurrentlyPreviewingHotcues && !m_bPreviewing; | ||
} | ||
|
||
bool CueControl::isCueRecallEnabled() { | ||
// Note that [Controls],CueRecall == 0 corresponds to "ON", not "OFF". | ||
return getConfig()->getValue(ConfigKey("[Controls]", "CueRecall"), 0) == 0; | ||
SeekOnLoadMode CueControl::getSeekOnLoadPreference() { | ||
int configValue = getConfig()->getValue(ConfigKey("[Controls]", "CueRecall"), | ||
static_cast<int>(SeekOnLoadMode::IntroStart)); | ||
return static_cast<SeekOnLoadMode>(configValue); | ||
} | ||
|
||
SeekOnLoadMode CueControl::getSeekOnLoadMode() { | ||
return seekOnLoadModeFromDouble(m_pSeekOnLoadMode->get()); | ||
SeekOnLoadMode CueControl::getSeekOnLoadModeAutoDjOverride() { | ||
return seekOnLoadModeFromDouble(m_pSeekOnLoadModeAutoDjOverride->get()); | ||
} | ||
|
||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure if this should be checked for any other SeekOnLoadModes. @ywwg maybe you can clarify?