We have the need to allow our users to download any video they\'re currently watching in the JWPlayer. The most logical way to do this would be to add a \"download\" link i
Check this
<script>
jwplayer("myElement").setup({
image: "/uploads/myPoster.jpg",
file: "/uploads/myVideo.mp4"
});
</script>
<script>
jwplayer().addButton(
"/uploads/myButton.png",
"Download Video",
function() {
window.location.href = jwplayer().getPlaylist()[0].sources[0].file;
},
"download"
);
</script>
Drawback : only works for one video not for playlist (source : download-button-and-playlist)
Reference - video-download-button
Hope it helps :)
Here is a quick demo, I updated it so it works on a per playlist item basis, and I made the image base64encoded so you don't have to host the download png on your server:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<link rel="icon" type="image/x-icon" href="http://www.jwplayer.com/wp-content/themes/jwplayer-105/favicon.ico">
<title>Adding a Video Download Button</title>
<script type='text/javascript' src='http://p.jwpcdn.com/6/8/jwplayer.js'></script>
<style type="text/css">
body {
margin: 0; padding: 0
}
</style>
</head>
<body>
<div id="container"></div>
<script>
jwplayer("container").setup({
image: "http://content.bitsontherun.com/thumbs/bkaovAYt-640.jpg",
file: "http://content.bitsontherun.com/videos/bkaovAYt-kNspJqnJ.mp4"
});
jwplayer().addButton(
"%3D",
"Download Video",
function(){
window.location.href = jwplayer().getPlaylistItem()['file'];
},
"download"
);
</script>
</body>
</html>