mirror of
https://github.com/GuerillaStudio/souvenir.git
synced 2025-01-20 15:50: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>
|
||||
</template>
|
||||
<template v-else>
|
||||
<button class="btn btn--danger w100">Cancel countdown</button>
|
||||
<button class="btn btn--danger w100" @click="cancelCountdown">Cancel countdown</button>
|
||||
</template>
|
||||
</div>
|
||||
|
||||
|
@ -28,6 +28,7 @@ import captureOptions from '/views/components/capture-options'
|
|||
import captureProgress from '/views/components/capture-progress'
|
||||
import captureTimer from '/views/components/capture-timer'
|
||||
import { capture } from '/services/capture.js'
|
||||
import { countdown } from '/services/countdown.js'
|
||||
|
||||
import 'objectFitPolyfill'
|
||||
|
||||
|
@ -47,7 +48,8 @@ export default {
|
|||
capturing: false,
|
||||
capturingProgress: 0,
|
||||
timerActive: false,
|
||||
timerProgress: 5
|
||||
timerProgress: 5,
|
||||
countdown: null
|
||||
}),
|
||||
computed: {
|
||||
...mapState([
|
||||
|
@ -79,6 +81,45 @@ export default {
|
|||
this.$store.dispatch('requestCamera', true)
|
||||
},
|
||||
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
|
||||
const capturing = capture(this.camera, this.duration.selected * 1000)
|
||||
|
||||
|
|
Loading…
Reference in a new issue