mirror of
https://github.com/GuerillaStudio/souvenir.git
synced 2025-01-20 22:30:20 +00:00
feat(time): wip countdown
This commit is contained in:
parent
d9a0d40f91
commit
1fabbdf55e
2 changed files with 118 additions and 2 deletions
75
src/services/countdown.js
Normal file
75
src/services/countdown.js
Normal file
|
@ -0,0 +1,75 @@
|
||||||
|
import EventEmitter from 'eventemitter3'
|
||||||
|
|
||||||
|
export function countdown (n, delay) {
|
||||||
|
return new Countdown(n, delay)
|
||||||
|
}
|
||||||
|
|
||||||
|
class Countdown extends EventEmitter {
|
||||||
|
constructor (n, delay) {
|
||||||
|
super()
|
||||||
|
|
||||||
|
this._n = n
|
||||||
|
this._delay = delay
|
||||||
|
|
||||||
|
this._count = 0
|
||||||
|
this._intervalId = null
|
||||||
|
|
||||||
|
this._running = false
|
||||||
|
this._started = false
|
||||||
|
this._ended = false
|
||||||
|
this._cancelled = false
|
||||||
|
this._done = false
|
||||||
|
}
|
||||||
|
|
||||||
|
run () {
|
||||||
|
if (!this._running && !this._started) {
|
||||||
|
this._running = true
|
||||||
|
this._started = true
|
||||||
|
|
||||||
|
this.emit('started')
|
||||||
|
|
||||||
|
this.emit('progress', 0)
|
||||||
|
this.emit('update', this._n)
|
||||||
|
|
||||||
|
this._intervalId = setInterval(() => this._update(), this._delay)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
cancel () {
|
||||||
|
if (this.running && !this._ended) {
|
||||||
|
this._cleanup()
|
||||||
|
|
||||||
|
this._cancelled = true
|
||||||
|
this.emit('cancelled')
|
||||||
|
|
||||||
|
this.ended = true
|
||||||
|
this.emit('ended')
|
||||||
|
|
||||||
|
this.running = false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
_update () {
|
||||||
|
if (this._running) {
|
||||||
|
if (this._count < this._n) {
|
||||||
|
this._count++
|
||||||
|
this.emit('progress', this._count / this._n)
|
||||||
|
this.emit('update', this._n - this._count)
|
||||||
|
} else {
|
||||||
|
this._cleanup()
|
||||||
|
|
||||||
|
this.done = true
|
||||||
|
this.emit('done')
|
||||||
|
|
||||||
|
this.ended = true
|
||||||
|
this.emit('ended')
|
||||||
|
|
||||||
|
this.running = false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
_cleanup () {
|
||||||
|
clearInterval(this._intervalId)
|
||||||
|
}
|
||||||
|
}
|
|
@ -16,7 +16,7 @@
|
||||||
<button class="capture-switch" title="Switch camera" @click="switchCamera"><icon-switch></icon-switch></button>
|
<button class="capture-switch" title="Switch camera" @click="switchCamera"><icon-switch></icon-switch></button>
|
||||||
</template>
|
</template>
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<button class="btn btn--danger w100">Cancel countdown</button>
|
<button class="btn btn--danger w100" @click="cancelCountdown">Cancel countdown</button>
|
||||||
</template>
|
</template>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -28,6 +28,7 @@ import captureOptions from '/views/components/capture-options'
|
||||||
import captureProgress from '/views/components/capture-progress'
|
import captureProgress from '/views/components/capture-progress'
|
||||||
import captureTimer from '/views/components/capture-timer'
|
import captureTimer from '/views/components/capture-timer'
|
||||||
import { capture } from '/services/capture.js'
|
import { capture } from '/services/capture.js'
|
||||||
|
import { countdown } from '/services/countdown.js'
|
||||||
|
|
||||||
import 'objectFitPolyfill'
|
import 'objectFitPolyfill'
|
||||||
|
|
||||||
|
@ -47,7 +48,8 @@ export default {
|
||||||
capturing: false,
|
capturing: false,
|
||||||
capturingProgress: 0,
|
capturingProgress: 0,
|
||||||
timerActive: false,
|
timerActive: false,
|
||||||
timerProgress: 5
|
timerProgress: 5,
|
||||||
|
countdown: null
|
||||||
}),
|
}),
|
||||||
computed: {
|
computed: {
|
||||||
...mapState([
|
...mapState([
|
||||||
|
@ -79,6 +81,45 @@ export default {
|
||||||
this.$store.dispatch('requestCamera', true)
|
this.$store.dispatch('requestCamera', true)
|
||||||
},
|
},
|
||||||
startCapturing () {
|
startCapturing () {
|
||||||
|
if (this.timer > 0) {
|
||||||
|
this.runCountdown()
|
||||||
|
} else {
|
||||||
|
this.runCapture()
|
||||||
|
}
|
||||||
|
},
|
||||||
|
runCountdown () {
|
||||||
|
this.countdown = countdown(this.timer, 1000)
|
||||||
|
|
||||||
|
this.countdown.on('started', value => {
|
||||||
|
this.timerActive = true
|
||||||
|
})
|
||||||
|
|
||||||
|
this.countdown.on('update', value => {
|
||||||
|
this.timerProgress = value
|
||||||
|
})
|
||||||
|
|
||||||
|
this.countdown.on('ended', () => {
|
||||||
|
this.timerActive = false
|
||||||
|
this.timerProgress = 0
|
||||||
|
this.countdown = null
|
||||||
|
})
|
||||||
|
|
||||||
|
this.countdown.on('done', () => {
|
||||||
|
console.log('cancelled')
|
||||||
|
})
|
||||||
|
|
||||||
|
this.countdown.on('done', () => {
|
||||||
|
this.runCapture()
|
||||||
|
})
|
||||||
|
|
||||||
|
this.countdown.run()
|
||||||
|
},
|
||||||
|
cancelCountdown () {
|
||||||
|
if (this.countdown) {
|
||||||
|
this.countdown.cancel()
|
||||||
|
}
|
||||||
|
},
|
||||||
|
runCapture () {
|
||||||
this.capturing = true
|
this.capturing = true
|
||||||
const capturing = capture(this.camera, this.duration.selected * 1000)
|
const capturing = capture(this.camera, this.duration.selected * 1000)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue