mirror of
https://github.com/GuerillaStudio/souvenir.git
synced 2025-01-20 18:50:21 +00:00
refactor(capture): expose an Event Emitter API
This commit is contained in:
parent
21eaa1bda7
commit
3a2c80a2a5
2 changed files with 28 additions and 18 deletions
|
@ -1,16 +1,22 @@
|
|||
import {
|
||||
GIF_WIDTH,
|
||||
GIF_HEIGHT,
|
||||
GIF_FRAME_RATE
|
||||
} from '/constants.js'
|
||||
import EventEmitter from 'eventemitter3'
|
||||
|
||||
import {
|
||||
makeRectangle,
|
||||
crop
|
||||
} from '/services/rectangle.js'
|
||||
|
||||
export function capture (commit, mediaStream, duration) {
|
||||
return new Promise((resolve, reject) => {
|
||||
import {
|
||||
GIF_WIDTH,
|
||||
GIF_HEIGHT,
|
||||
GIF_FRAME_RATE
|
||||
} from '/constants.js'
|
||||
|
||||
|
||||
|
||||
export function capture (mediaStream, duration) {
|
||||
const emitter = new EventEmitter()
|
||||
|
||||
Promise.resolve().then(() => {
|
||||
const video = document.createElement('video')
|
||||
video.autoplay = true
|
||||
video.setAttribute('playsinline', '')
|
||||
|
@ -40,8 +46,6 @@ export function capture (commit, mediaStream, duration) {
|
|||
|
||||
const intervalId = setInterval(() => {
|
||||
if (imageDataList.length < totalFrames) {
|
||||
console.log(`Capturing frame ${imageDataList.length + 1} / ${totalFrames}`)
|
||||
|
||||
canvasContext.drawImage(
|
||||
video,
|
||||
soureRectangle.x,
|
||||
|
@ -63,11 +67,11 @@ export function capture (commit, mediaStream, duration) {
|
|||
|
||||
imageDataList.push(imageData)
|
||||
|
||||
commit('updateCaptureState', imageDataList.length / totalFrames * 100)
|
||||
emitter.emit('progress', imageDataList.length / totalFrames)
|
||||
} else {
|
||||
clearInterval(intervalId)
|
||||
|
||||
resolve({
|
||||
emitter.emit('done', {
|
||||
imageDataList,
|
||||
imageWidth: GIF_WIDTH,
|
||||
imageHeight: GIF_HEIGHT,
|
||||
|
@ -77,4 +81,7 @@ export function capture (commit, mediaStream, duration) {
|
|||
}, delayTime)
|
||||
})
|
||||
})
|
||||
.catch(error => emitter.emit('error', error))
|
||||
|
||||
return emitter;
|
||||
}
|
||||
|
|
17
src/store.js
17
src/store.js
|
@ -111,14 +111,17 @@ export default new Vuex.Store({
|
|||
},
|
||||
capture ({ commit, dispatch, state }) {
|
||||
commit('startCapture')
|
||||
const capturing = capture(state.mediaStream, state.timer.selected * 1000)
|
||||
|
||||
capture(commit, state.mediaStream, state.timer.selected * 1000)
|
||||
.then(captureData => {
|
||||
commit('stopCapture')
|
||||
commit('updateCaptureState', 0)
|
||||
dispatch('encode', captureData)
|
||||
})
|
||||
.catch(error => console.error(error))
|
||||
capturing.once('error', error => console.error(error))
|
||||
|
||||
capturing.on('progress', value => commit('updateCaptureState', Math.round(value * 100)))
|
||||
|
||||
capturing.once('done', captureData => {
|
||||
commit('stopCapture')
|
||||
commit('updateCaptureState', 0)
|
||||
dispatch('encode', captureData)
|
||||
})
|
||||
},
|
||||
encode ({ commit }, captureData) {
|
||||
commit('startEncoding')
|
||||
|
|
Loading…
Reference in a new issue