add recording

This commit is contained in:
Tomáš Mládek 2018-02-21 14:43:38 +01:00 committed by Tomáš Mládek
parent 124161c26f
commit e871911c95
3 changed files with 46 additions and 4 deletions

15
package-lock.json generated
View file

@ -1228,6 +1228,11 @@
"integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=", "integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=",
"dev": true "dev": true
}, },
"bowser": {
"version": "1.9.2",
"resolved": "https://registry.npmjs.org/bowser/-/bowser-1.9.2.tgz",
"integrity": "sha512-fuiANC1Bqbqa/S4gmvfCt7bGBmNELMsGZj4Wg3PrP6esP66Ttoj1JSlzFlXtHyduMv07kDNmDsX6VsMWT/MLGg=="
},
"brace-expansion": { "brace-expansion": {
"version": "1.1.8", "version": "1.1.8",
"resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz",
@ -1507,6 +1512,11 @@
"integrity": "sha1-yVTMp4AEbzTEtDPTJO9Bnh21GlM=", "integrity": "sha1-yVTMp4AEbzTEtDPTJO9Bnh21GlM=",
"dev": true "dev": true
}, },
"ccapture.js": {
"version": "1.0.7",
"resolved": "https://registry.npmjs.org/ccapture.js/-/ccapture.js-1.0.7.tgz",
"integrity": "sha512-RuIOv/DDUR9PF9QU/NdkxjYQ/0zXi8jHfPc6ua6ljVZgq281iale5LBUNvv/5SDc5mW7i4KEIH5qTRmhKnPZjw=="
},
"center-align": { "center-align": {
"version": "0.1.3", "version": "0.1.3",
"resolved": "https://registry.npmjs.org/center-align/-/center-align-0.1.3.tgz", "resolved": "https://registry.npmjs.org/center-align/-/center-align-0.1.3.tgz",
@ -12039,6 +12049,11 @@
"integrity": "sha512-nqHUnMXmBzT0w570r2JpJxfiSD1IzoI+HGVdd3aZ0yNi3ngvQ4jv1dtHt5VGxfI2yj5yqImPhOK4vmIh2xMbGg==", "integrity": "sha512-nqHUnMXmBzT0w570r2JpJxfiSD1IzoI+HGVdd3aZ0yNi3ngvQ4jv1dtHt5VGxfI2yj5yqImPhOK4vmIh2xMbGg==",
"dev": true "dev": true
}, },
"whammy": {
"version": "0.0.1",
"resolved": "https://registry.npmjs.org/whammy/-/whammy-0.0.1.tgz",
"integrity": "sha1-z0vtn7qmh+2j9CCV/5m/cEsI0B4="
},
"whet.extend": { "whet.extend": {
"version": "0.9.9", "version": "0.9.9",
"resolved": "https://registry.npmjs.org/whet.extend/-/whet.extend-0.9.9.tgz", "resolved": "https://registry.npmjs.org/whet.extend/-/whet.extend-0.9.9.tgz",

View file

@ -11,9 +11,12 @@
"build": "node build/build.js" "build": "node build/build.js"
}, },
"dependencies": { "dependencies": {
"bowser": "^1.9.2",
"ccapture.js": "^1.0.7",
"q": "^1.5.1", "q": "^1.5.1",
"sprintf-js": "^1.1.1", "sprintf-js": "^1.1.1",
"vue": "^2.5.2" "vue": "^2.5.2",
"whammy": "0.0.1"
}, },
"devDependencies": { "devDependencies": {
"autoprefixer": "^7.1.2", "autoprefixer": "^7.1.2",

View file

@ -10,6 +10,10 @@
</canvas> </canvas>
</div> </div>
<div id="controls" class="{'fullscreen-controls': fullscreen}"> <div id="controls" class="{'fullscreen-controls': fullscreen}">
<div>
<label for="recordMode">Record output</label>
<input type="checkbox" v-model="record" id="recordMode">
</div>
<div> <div>
<input type="range" min="0" :max="frames - 1" value="0" class="slider" v-model.number="position"> <input type="range" min="0" :max="frames - 1" value="0" class="slider" v-model.number="position">
</div> </div>
@ -32,6 +36,9 @@
</template> </template>
<script> <script>
import CCapture from 'ccapture.js'
import bowser from 'bowser'
export default { export default {
name: 'player', name: 'player',
props: { props: {
@ -49,7 +56,12 @@
sortDirection: false, sortDirection: false,
position: 0, position: 0,
tmp_ctx: null, tmp_ctx: null,
animation_id: null animation_id: null,
record: false,
capturer: new CCapture({
format: 'webm',
verbose: true
})
} }
}, },
computed: { computed: {
@ -127,6 +139,12 @@
if (this.playing || this.image === null) return if (this.playing || this.image === null) return
this.tmp_ctx = this.$refs.canvas.getContext('2d') this.tmp_ctx = this.$refs.canvas.getContext('2d')
this.$render() this.$render()
},
record: function () {
if (this.record && !bowser.chrome) {
alert('Recording only supported in Chrome :( \n' +
'https://github.com/spite/ccapture.js/#limitations')
}
} }
}, },
methods: { methods: {
@ -136,9 +154,10 @@
} }
this.playing = !this.playing this.playing = !this.playing
if (this.playing) { if (this.playing) {
this.tmp_ctx = this.$refs.canvas.getContext('2d')
this.animation_id = requestAnimationFrame(this.$render_advance)
this.buttonLabel = 'STOP' this.buttonLabel = 'STOP'
this.tmp_ctx = this.$refs.canvas.getContext('2d')
if (this.record) this.capturer.start()
this.$render_advance()
} else { } else {
cancelAnimationFrame(this.animation_id) cancelAnimationFrame(this.animation_id)
this.buttonLabel = 'PLAY' this.buttonLabel = 'PLAY'
@ -163,9 +182,14 @@
if (this.position < this.frames) { if (this.position < this.frames) {
this.position += 1 this.position += 1
this.animation_id = requestAnimationFrame(this.$render_advance) this.animation_id = requestAnimationFrame(this.$render_advance)
if (this.record) this.capturer.capture(this.$refs.canvas)
} else { } else {
this.playPause() this.playPause()
this.position = 0 this.position = 0
if (this.record) {
this.record.stop()
this.record.save()
}
} }
} }
} }