Commit 9b81d326 by Jonathan Thomas

Load new videos when selected, protect video element when it does not exist,…

Load new videos when selected, protect video element when it does not exist, watch previewFile for changes, reload video element, support for mp3 audio files
parent d23c006c
...@@ -96,18 +96,24 @@ export default { ...@@ -96,18 +96,24 @@ export default {
await this.createClip(payload) await this.createClip(payload)
}, },
togglePause() { togglePause() {
if (this.$refs.video) {
this.is_paused = this.$refs.video.paused this.is_paused = this.$refs.video.paused
}
}, },
togglePlayback() { togglePlayback() {
if (this.$refs.video) {
if (this.$refs.video.paused) { if (this.$refs.video.paused) {
this.$refs.video.play() this.$refs.video.play()
} else { } else {
this.$refs.video.pause() this.$refs.video.pause()
} }
}
}, },
videoTimeUpdate() { videoTimeUpdate() {
if (this.$refs.video) {
let playback_percent = (this.$refs.video.currentTime / this.$refs.video.duration) let playback_percent = (this.$refs.video.currentTime / this.$refs.video.duration)
this.position = playback_percent this.position = playback_percent
}
}, },
startDrag(e, marker) { startDrag(e, marker) {
if (e) { if (e) {
...@@ -123,7 +129,9 @@ export default { ...@@ -123,7 +129,9 @@ export default {
if (!this.dragging_marker) { if (!this.dragging_marker) {
let percent_x = this.getCursorPosition(e) let percent_x = this.getCursorPosition(e)
this.position = percent_x this.position = percent_x
if (this.$refs.video) {
this.$refs.video.currentTime = this.position * this.$refs.video.duration this.$refs.video.currentTime = this.position * this.$refs.video.duration
}
return false return false
} }
}, },
...@@ -137,15 +145,21 @@ export default { ...@@ -137,15 +145,21 @@ export default {
drag(e) { drag(e) {
if (this.dragging_marker == 'start') { if (this.dragging_marker == 'start') {
this.markers.start = Math.min(this.getCursorPosition(e), this.markers.end) this.markers.start = Math.min(this.getCursorPosition(e), this.markers.end)
if (this.$refs.video) {
this.$refs.video.currentTime = this.markers.start * this.$refs.video.duration this.$refs.video.currentTime = this.markers.start * this.$refs.video.duration
}
} else if (this.dragging_marker == 'end') { } else if (this.dragging_marker == 'end') {
this.markers.end = Math.max(this.getCursorPosition(e, 12), this.markers.start) this.markers.end = Math.max(this.getCursorPosition(e, 12), this.markers.start)
if (this.$refs.video) {
this.$refs.video.currentTime = this.markers.end * this.$refs.video.duration this.$refs.video.currentTime = this.markers.end * this.$refs.video.duration
}
} else if (this.dragging_marker == 'playhead') { } else if (this.dragging_marker == 'playhead') {
let percent_x = this.getCursorPosition(e) let percent_x = this.getCursorPosition(e)
this.$refs.playhead.style.left = `${percent_x * 100}%` this.$refs.playhead.style.left = `${percent_x * 100}%`
if (this.$refs.video) {
this.$refs.video.currentTime = percent_x * this.$refs.video.duration this.$refs.video.currentTime = percent_x * this.$refs.video.duration
} }
}
}, },
getMarkerWidth() { getMarkerWidth() {
if (this.$refs.timeline) { if (this.$refs.timeline) {
...@@ -193,12 +207,25 @@ export default { ...@@ -193,12 +207,25 @@ export default {
return (this.previewFile && this.previewFile.json.vcodec == "QImage") return (this.previewFile && this.previewFile.json.vcodec == "QImage")
}, },
previewFormat() { previewFormat() {
if (this.previewFile) { if (this.previewFile && this.previewFile.json.acodec == "mp3") {
return 'audio/mpeg'
} else {
return `video/${this.previewFile.media.split('.').pop()}` return `video/${this.previewFile.media.split('.').pop()}`
} }
return ''
} }
}, },
watch: {
previewFile() {
if (this.$refs.video) {
this.is_paused = true
this.$refs.video.pause()
this.$refs.video.load()
}
this.position = 0.0
this.markers.start = 0.0
this.markers.end = 1.0
},
},
updated() { updated() {
this.marker_width_percent = this.getMarkerWidth() this.marker_width_percent = this.getMarkerWidth()
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment