use http server for poster generation
This commit is contained in:
@@ -3,23 +3,43 @@ module.exports = torrentPoster
|
|||||||
var captureVideoFrame = require('./capture-video-frame')
|
var captureVideoFrame = require('./capture-video-frame')
|
||||||
|
|
||||||
function torrentPoster (torrent, cb) {
|
function torrentPoster (torrent, cb) {
|
||||||
if (torrent.ready) onReady()
|
// use largest file
|
||||||
else torrent.once('ready', onReady)
|
var index = torrent.files.indexOf(torrent.files.reduce(function (a, b) {
|
||||||
|
return a.length > b.length ? a : b
|
||||||
|
}))
|
||||||
|
|
||||||
function onReady () {
|
var server = torrent.createServer(0)
|
||||||
// use largest file
|
server.listen(0, onListening)
|
||||||
var file = torrent.files.reduce(function (a, b) {
|
|
||||||
return a.length > b.length ? a : b
|
function onListening () {
|
||||||
})
|
var port = server.address().port
|
||||||
|
var url = 'http://localhost:' + port + '/' + index
|
||||||
var video = document.createElement('video')
|
var video = document.createElement('video')
|
||||||
file.renderTo(video)
|
video.addEventListener('canplay', onCanPlay)
|
||||||
|
|
||||||
video.currentTime = 10
|
video.volume = 0
|
||||||
video.addEventListener('seeked', onSeeked)
|
video.src = url
|
||||||
|
video.play()
|
||||||
|
|
||||||
function onSeeked (e) {
|
function onCanPlay () {
|
||||||
|
video.removeEventListener('canplay', onCanPlay)
|
||||||
|
video.addEventListener('seeked', onSeeked)
|
||||||
|
|
||||||
|
video.currentTime = Math.min((video.duration || 600) * 0.03, 60)
|
||||||
|
}
|
||||||
|
|
||||||
|
function onSeeked () {
|
||||||
video.removeEventListener('seeked', onSeeked)
|
video.removeEventListener('seeked', onSeeked)
|
||||||
|
|
||||||
var buf = captureVideoFrame(video)
|
var buf = captureVideoFrame(video)
|
||||||
|
|
||||||
|
// unload video element
|
||||||
|
video.pause()
|
||||||
|
video.src = ''
|
||||||
|
video.load()
|
||||||
|
|
||||||
|
server.destroy()
|
||||||
|
|
||||||
cb(null, buf)
|
cb(null, buf)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user