mirror of
https://github.com/kaythomas0/noisedash.git
synced 2025-11-15 04:38:00 +00:00
Start implementing sample playback mode
This commit is contained in:
@@ -79,6 +79,9 @@ module.exports = function () {
|
|||||||
db.run('ALTER TABLE profiles_samples ADD COLUMN reverb_pre_delay REAL DEFAULT 0')
|
db.run('ALTER TABLE profiles_samples ADD COLUMN reverb_pre_delay REAL DEFAULT 0')
|
||||||
db.run('ALTER TABLE profiles_samples ADD COLUMN reverb_decay REAL DEFAULT 0')
|
db.run('ALTER TABLE profiles_samples ADD COLUMN reverb_decay REAL DEFAULT 0')
|
||||||
db.run('ALTER TABLE profiles_samples ADD COLUMN reverb_wet INTEGER DEFAULT 0')
|
db.run('ALTER TABLE profiles_samples ADD COLUMN reverb_wet INTEGER DEFAULT 0')
|
||||||
|
db.run('ALTER TABLE profiles_samples ADD COLUMN playback_mode TEXT DEFAULT "continuous"')
|
||||||
|
db.run('ALTER TABLE profiles_samples ADD COLUMN sporadic_min INTEGER DEFAULT 30')
|
||||||
|
db.run('ALTER TABLE profiles_samples ADD COLUMN sporadic_max INTEGER DEFAULT 300')
|
||||||
|
|
||||||
db.run('PRAGMA user_version = 3')
|
db.run('PRAGMA user_version = 3')
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -66,15 +66,21 @@ router.post('/profiles', (req, res) => {
|
|||||||
reverb_enabled,
|
reverb_enabled,
|
||||||
reverb_pre_delay,
|
reverb_pre_delay,
|
||||||
reverb_decay,
|
reverb_decay,
|
||||||
reverb_wet)
|
reverb_wet,
|
||||||
VALUES (?, ?, ?, ?, ?, ?, ?)`, [
|
playback_mode,
|
||||||
|
sporadic_min,
|
||||||
|
sporadic_max)
|
||||||
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`, [
|
||||||
profileID,
|
profileID,
|
||||||
s.id,
|
s.id,
|
||||||
s.volume,
|
s.volume,
|
||||||
s.reverbEnabled,
|
s.reverbEnabled,
|
||||||
s.reverbPreDelay,
|
s.reverbPreDelay,
|
||||||
s.reverbDecay,
|
s.reverbDecay,
|
||||||
s.reverbWet
|
s.reverbWet,
|
||||||
|
s.playbackMode,
|
||||||
|
s.sporadicMin,
|
||||||
|
s.sporadicMax
|
||||||
],
|
],
|
||||||
(err) => {
|
(err) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
@@ -223,15 +229,21 @@ router.put('/profiles/:profileId', (req, res) => {
|
|||||||
reverb_enabled,
|
reverb_enabled,
|
||||||
reverb_pre_delay,
|
reverb_pre_delay,
|
||||||
reverb_decay,
|
reverb_decay,
|
||||||
reverb_wet)
|
reverb_wet,
|
||||||
VALUES (?, ?, ?, ?, ?, ?, ?)`, [
|
playback_mode,
|
||||||
|
sporadic_min,
|
||||||
|
sporadic_max)
|
||||||
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`, [
|
||||||
req.params.profileId,
|
req.params.profileId,
|
||||||
s.id,
|
s.id,
|
||||||
s.volume,
|
s.volume,
|
||||||
s.reverbEnabled,
|
s.reverbEnabled,
|
||||||
s.reverbPreDelay,
|
s.reverbPreDelay,
|
||||||
s.reverbDecay,
|
s.reverbDecay,
|
||||||
s.reverbWet
|
s.reverbWet,
|
||||||
|
s.playbackMode,
|
||||||
|
s.sporadicMin,
|
||||||
|
s.sporadicMax
|
||||||
],
|
],
|
||||||
(err) => {
|
(err) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
@@ -383,6 +395,9 @@ router.get('/profiles/:profileId', (req, res) => {
|
|||||||
profiles_samples.reverb_pre_delay as reverbPreDelay,
|
profiles_samples.reverb_pre_delay as reverbPreDelay,
|
||||||
profiles_samples.reverb_decay as reverbDecay,
|
profiles_samples.reverb_decay as reverbDecay,
|
||||||
profiles_samples.reverb_wet as reverbWet,
|
profiles_samples.reverb_wet as reverbWet,
|
||||||
|
profiles_samples.playback_mode as playbackMode,
|
||||||
|
profiles_samples.sporadic_min as sporadicMin,
|
||||||
|
profiles_samples.sporadic_max as sporadicMax,
|
||||||
fade_in as fadeIn,
|
fade_in as fadeIn,
|
||||||
loop_points_enabled as loopPointsEnabled,
|
loop_points_enabled as loopPointsEnabled,
|
||||||
loop_start as loopStart,
|
loop_start as loopStart,
|
||||||
@@ -414,6 +429,9 @@ router.get('/profiles/:profileId', (req, res) => {
|
|||||||
sample.reverbPreDelay = row.reverbPreDelay
|
sample.reverbPreDelay = row.reverbPreDelay
|
||||||
sample.reverbDecay = row.reverbDecay
|
sample.reverbDecay = row.reverbDecay
|
||||||
sample.reverbWet = row.reverbWet
|
sample.reverbWet = row.reverbWet
|
||||||
|
sample.playbackMode = row.playbackMode
|
||||||
|
sample.sporadicMin = row.sporadicMin
|
||||||
|
sample.sporadicMax = row.sporadicMax
|
||||||
|
|
||||||
samples.push(sample)
|
samples.push(sample)
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
|
|
||||||
<v-row justify="center">
|
<v-row justify="center">
|
||||||
<v-btn
|
<v-btn
|
||||||
:disabled="playDisabled || !isTimerValid"
|
:disabled="playDisabled || !isTimerValid || !isSporadicValid"
|
||||||
class="mx-3 mb-5"
|
class="mx-3 mb-5"
|
||||||
fab
|
fab
|
||||||
large
|
large
|
||||||
@@ -640,7 +640,7 @@
|
|||||||
v-if="canUpload"
|
v-if="canUpload"
|
||||||
cols="12"
|
cols="12"
|
||||||
>
|
>
|
||||||
<h2 class="display-1 font-weight-bold mb-5">
|
<h2 class="display-1 font-weight-bold mb-7">
|
||||||
Samples
|
Samples
|
||||||
</h2>
|
</h2>
|
||||||
|
|
||||||
@@ -652,7 +652,7 @@
|
|||||||
<v-row
|
<v-row
|
||||||
justify="center"
|
justify="center"
|
||||||
>
|
>
|
||||||
<h2 class="headline font-weight-bold mb-5">
|
<h2 class="mb-5">
|
||||||
{{ sample.name }}
|
{{ sample.name }}
|
||||||
</h2>
|
</h2>
|
||||||
</v-row>
|
</v-row>
|
||||||
@@ -685,29 +685,35 @@
|
|||||||
<v-row
|
<v-row
|
||||||
justify="center"
|
justify="center"
|
||||||
>
|
>
|
||||||
<h2 class="headline mb-5">
|
<h3 class="font-weight-regular mb-9">
|
||||||
Effects
|
Effects
|
||||||
</h2>
|
</h3>
|
||||||
</v-row>
|
</v-row>
|
||||||
|
|
||||||
|
<v-expansion-panels class="mb-9">
|
||||||
|
<v-expansion-panel>
|
||||||
|
<v-expansion-panel-header>
|
||||||
|
Reverb
|
||||||
|
</v-expansion-panel-header>
|
||||||
|
<v-expansion-panel-content>
|
||||||
<v-row justify="center">
|
<v-row justify="center">
|
||||||
<v-checkbox
|
<v-checkbox
|
||||||
v-model="sample.reverbEnabled"
|
v-model="sample.reverbEnabled"
|
||||||
label="Reverb"
|
:disabled="playDisabled"
|
||||||
|
label="Enabled"
|
||||||
/>
|
/>
|
||||||
</v-row>
|
</v-row>
|
||||||
|
|
||||||
<v-row justify="center">
|
<v-row justify="center">
|
||||||
<v-slider
|
<v-slider
|
||||||
v-model="sample.reverbPreDelay"
|
v-model="sample.reverbPreDelay"
|
||||||
:disabled="!sample.reverbEnabled"
|
:disabled="playDisabled || !sample.reverbEnabled"
|
||||||
label="Pre Delay"
|
label="Pre Delay"
|
||||||
thumb-label
|
thumb-label
|
||||||
max="16"
|
max="16"
|
||||||
min="0"
|
min="0"
|
||||||
step="0.5"
|
step="0.5"
|
||||||
class="mx-3"
|
class="mx-3"
|
||||||
@input="updateReverbPreDelay(sample.id, index)"
|
|
||||||
/>
|
/>
|
||||||
<div
|
<div
|
||||||
class="mx-3"
|
class="mx-3"
|
||||||
@@ -719,7 +725,7 @@
|
|||||||
<v-row justify="center">
|
<v-row justify="center">
|
||||||
<v-slider
|
<v-slider
|
||||||
v-model="sample.reverbDecay"
|
v-model="sample.reverbDecay"
|
||||||
:disabled="!sample.reverbEnabled"
|
:disabled="playDisabled || !sample.reverbEnabled"
|
||||||
label="Decay"
|
label="Decay"
|
||||||
thumb-label
|
thumb-label
|
||||||
max="16"
|
max="16"
|
||||||
@@ -738,7 +744,7 @@
|
|||||||
<v-row justify="center">
|
<v-row justify="center">
|
||||||
<v-slider
|
<v-slider
|
||||||
v-model="sample.reverbWet"
|
v-model="sample.reverbWet"
|
||||||
:disabled="!sample.reverbEnabled"
|
:disabled="playDisabled || !sample.reverbEnabled"
|
||||||
label="Wet"
|
label="Wet"
|
||||||
thumb-label
|
thumb-label
|
||||||
max="1"
|
max="1"
|
||||||
@@ -753,12 +759,81 @@
|
|||||||
<p>{{ sample.reverbWet }}%</p>
|
<p>{{ sample.reverbWet }}%</p>
|
||||||
</div>
|
</div>
|
||||||
</v-row>
|
</v-row>
|
||||||
|
</v-expansion-panel-content>
|
||||||
|
</v-expansion-panel>
|
||||||
|
</v-expansion-panels>
|
||||||
|
|
||||||
|
<v-row justify="center">
|
||||||
|
<h3 class="font-weight-regular">
|
||||||
|
Playback Mode
|
||||||
|
</h3>
|
||||||
|
</v-row>
|
||||||
|
|
||||||
|
<v-row
|
||||||
|
justify="center"
|
||||||
|
class="mb-5"
|
||||||
|
>
|
||||||
|
<v-radio-group
|
||||||
|
v-model="sample.playbackMode"
|
||||||
|
mandatory
|
||||||
|
>
|
||||||
|
<v-radio
|
||||||
|
label="Continuous"
|
||||||
|
value="continuous"
|
||||||
|
/>
|
||||||
|
<v-radio
|
||||||
|
label="Sporadic"
|
||||||
|
value="sporadic"
|
||||||
|
/>
|
||||||
|
</v-radio-group>
|
||||||
|
</v-row>
|
||||||
|
|
||||||
|
<v-form
|
||||||
|
v-model="isSporadicValid"
|
||||||
|
>
|
||||||
|
<v-row
|
||||||
|
justify="center"
|
||||||
|
>
|
||||||
|
<v-text-field
|
||||||
|
v-model="sample.sporadicMin"
|
||||||
|
type="number"
|
||||||
|
label="Sporadic Min"
|
||||||
|
class="mx-3"
|
||||||
|
:disabled="sample.playbackMode != 'sporadic'"
|
||||||
|
:rules="[rules.gt(0)]"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<v-text-field
|
||||||
|
v-model="sample.sporadicMax"
|
||||||
|
type="number"
|
||||||
|
label="Sporadic Max"
|
||||||
|
class="mx-3"
|
||||||
|
:disabled="sample.playbackMode != 'sporadic'"
|
||||||
|
:rules="[rules.gt(0)]"
|
||||||
|
/>
|
||||||
|
</v-row>
|
||||||
|
</v-form>
|
||||||
|
|
||||||
|
<v-row
|
||||||
|
justify="center"
|
||||||
|
class="my-7"
|
||||||
|
>
|
||||||
|
<p
|
||||||
|
v-if="sample.playbackMode != 'sporadic'"
|
||||||
|
class="text--disabled"
|
||||||
|
>
|
||||||
|
(Sample will play randomly, every {{ sample.sporadicMin }} to {{ sample.sporadicMax }} seconds)
|
||||||
|
</p>
|
||||||
|
<p
|
||||||
|
v-else
|
||||||
|
>
|
||||||
|
(Sample will play randomly, every {{ sample.sporadicMin }} to {{ sample.sporadicMax }} seconds)
|
||||||
|
</p>
|
||||||
|
</v-row>
|
||||||
|
|
||||||
<v-row>
|
|
||||||
<v-divider
|
<v-divider
|
||||||
class="mb-7"
|
class="mb-7"
|
||||||
/>
|
/>
|
||||||
</v-row>
|
|
||||||
</v-container>
|
</v-container>
|
||||||
</v-row>
|
</v-row>
|
||||||
|
|
||||||
|
|||||||
@@ -75,6 +75,7 @@ export default {
|
|||||||
unwatch: null,
|
unwatch: null,
|
||||||
confirmSwitchProfileDialog: false,
|
confirmSwitchProfileDialog: false,
|
||||||
activeProfile: {},
|
activeProfile: {},
|
||||||
|
isSporadicValid: false,
|
||||||
errorSnackbar: false,
|
errorSnackbar: false,
|
||||||
errorSnackbarText: '',
|
errorSnackbarText: '',
|
||||||
rules: {
|
rules: {
|
||||||
@@ -123,6 +124,10 @@ export default {
|
|||||||
|
|
||||||
this.loadedSamples.forEach(s => {
|
this.loadedSamples.forEach(s => {
|
||||||
settings.push(s.volume)
|
settings.push(s.volume)
|
||||||
|
settings.push(s.reverbEnabled)
|
||||||
|
settings.push(s.reverbPreDelay)
|
||||||
|
settings.push(s.reverbDecay)
|
||||||
|
settings.push(s.reverbWet)
|
||||||
})
|
})
|
||||||
|
|
||||||
return settings
|
return settings
|
||||||
@@ -186,10 +191,13 @@ export default {
|
|||||||
}
|
}
|
||||||
this.players.player(s.id).volume.value = s.volume
|
this.players.player(s.id).volume.value = s.volume
|
||||||
|
|
||||||
|
this.players.player(s.id).disconnect()
|
||||||
if (s.reverbEnabled) {
|
if (s.reverbEnabled) {
|
||||||
const reverb = new Tone.Reverb(s.reverbDecay).toDestination()
|
const reverb = new Tone.Reverb(s.reverbDecay).toDestination()
|
||||||
reverb.set({ preDelay: s.reverbPreDelay, wet: s.reverbWet })
|
reverb.set({ preDelay: s.reverbPreDelay, wet: s.reverbWet })
|
||||||
this.players.player(s.id).connect(reverb)
|
this.players.player(s.id).connect(reverb)
|
||||||
|
} else {
|
||||||
|
this.players.player(s.id).toDestination()
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -208,11 +216,16 @@ export default {
|
|||||||
this.noise.sync().start(0)
|
this.noise.sync().start(0)
|
||||||
|
|
||||||
this.loadedSamples.forEach(s => {
|
this.loadedSamples.forEach(s => {
|
||||||
|
if (s.playbackMode === 'sporadic') {
|
||||||
|
const playNextTime = Math.floor(Math.random() * (s.sporadicMax - s.sporadicMin + 1) + s.sporadicMin)
|
||||||
|
this.sporadicInterval = setInterval(() => console.log('Test'), playNextTime)
|
||||||
|
} else {
|
||||||
this.players.player(s.id).unsync().sync().start(0)
|
this.players.player(s.id).unsync().sync().start(0)
|
||||||
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
Tone.Transport.start()
|
Tone.Transport.start('+0.1')
|
||||||
},
|
},
|
||||||
stop () {
|
stop () {
|
||||||
clearInterval(this.transportInterval)
|
clearInterval(this.transportInterval)
|
||||||
|
|||||||
Reference in New Issue
Block a user