質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.34%
HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

2回答

11315閲覧

動画からサムネイル画像を複数取得

退会済みユーザー

退会済みユーザー

総合スコア0

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2017/04/05 06:12

###前提・実現したいこと

  1. <file>タグで動画ファイル選択


2. 動画が読み込まれて<video>タグ内に表示される

3. javascriptで<video>タグ内の表示をサムネイル画像として.imgAreaに追加

4. 再生位置を進めて<video>タグ内の表示を変える

5. javascriptで<video>タグ内の表示をサムネイル画像として.imgAreaに追加

6. 再生位置を進めて<video>タグ内の表示を変える

7. javascriptで<video>タグ内の表示をサムネイル画像として.imgAreaに追加


を実現したいです。

###発生している問題・エラーメッセージ
下記ソースコードの、
video.currentTime = 0

video.currentTime = 15
の場合しか期待した動作をしません。。

video.currentTime = 5

video.currentTime = 10
の処理が完了する前に処理が進んでしまっているような感じです

###該当のソースコード

<style type="text/css"> canvas{ display: none; } </style> </head> <body> <input type="file" id="file" name="movie_file"> <video controls></video> <canvas id="canvas"></canvas> <div class="imgArea"></div> <script src="//ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js"></script> <script> $(function () { $("#file").change(function(){ for(var i = 0; i < this.files.length; i++){ $('video').attr("src", URL.createObjectURL(this.files[i])); } var video = document.querySelector('video') video.onseeked = function(){ capture() } video.onloadeddata = function(){ video.currentTime = 0 setTimeout(function() { video.currentTime = 5 }, 1000); setTimeout(function() { video.currentTime = 10 }, 1000); setTimeout(function() { video.currentTime = 15 }, 1000); } }); function capture() { var canvas = document.querySelector("canvas"); var context = canvas.getContext("2d"); var video_img = document.querySelector("video"); video_img.width = video_img.videoWidth; video_img.height = video_img.videoHeight; canvas.width = video_img.width canvas.height = video_img.height context.drawImage(video_img, 0, 0); var imgSrc = canvas.toDataURL("image/jpeg" , 0.8); $('.imgArea').append('<img src=' + imgSrc + ') }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

こんな感じですかー?

JavaScript

1<!DOCTYPE html> 2<html lang="ja"> 3<head> 4<meta charset="UTF-8"> 5<title></title> 6<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js"></script> 7<style type="text/css"> 8 canvas{ 9 display: none; 10 } 11</style> 12</head> 13<body> 14<input type="file" id="file" name="movie_file"> 15<video controls></video> 16<canvas id="canvas"></canvas> 17<div class="imgArea"></div> 18<script> 19$(function(){ 20 var video = document.querySelector('video') 21 video.onloadedmetadata = function(){ 22 var canvas = document.querySelector("#canvas"); 23 canvas.width = video.videoWidth; 24 canvas.height = video.videoHeight; 25 }; 26 var current = 0; 27 video.onseeked = function(){ 28 if (current > 15) { 29 return; 30 } 31 capture(); 32 current += 5; 33 this.currentTime = current; 34 }; 35 video.onloadeddata = function(){ 36 this.currentTime = 0; 37 current = 0; 38 }; 39 $("#file").change(function(){ 40 video.src = (URL).createObjectURL(this.files[0]); 41 }); 42 function capture(){ 43 var canvas = document.querySelector("#canvas"); 44 var context = canvas.getContext("2d"); 45 context.drawImage(video, 0, 0); 46 var img = new Image(); 47 img.src = canvas.toDataURL("image/jpeg" , 0.8); 48 $('.imgArea').append(img); 49 } 50}); 51</script> 52</body> 53</html>

参考
Capture frames from video with HTML5 and JavaScript - Stack Overflow

投稿2017/04/05 09:06

編集2017/04/10 19:02
umyu

総合スコア5846

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/05/31 01:46

回答が非常に遅くなってしまいすみません。。 記載いただいたコードで確認したところ、こちらでも期待通りの動作を確認できました! ご教示いただきありがとうございます。
guest

0

ベストアンサー

全て見てはないですが、setTimeoutが同時に走っているからではないでしょうか。

javascript

1video.onloadeddata = function(){ 2 video.currentTime = 0 3 setTimeout(function() { 4 video.currentTime = 5 5 }, 1000); 6 setTimeout(function() { 7 video.currentTime = 10 8 }, 1000); 9 setTimeout(function() { 10 video.currentTime = 15 11 }, 1000); 12 } 13}); 14

以下のように修正

video.onloadeddata = function(){ video.currentTime = 0 var timer = setTimeout(function() { // 15以上の場合1sごとの処理を止める if(video.currentTime >= 15) clearTimeout(timer) // 5s追加 video.currentTime += 5 }, 1000); });

試してないのでえらーでたらすいません( ;∀;)
setTimeoutが原因だと思うので、その辺を修正してみて下さい!

投稿2017/04/05 08:01

MasakazuFukami

総合スコア1869

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/05/31 01:52

回答が非常に遅くなってしまいすみません。。 上記ご指摘いただいた内容で修正したところ、期待した通りの動作が実現できました! 私そもそもjavascriptの処理の実行順序など理解できていないところが多いので精進いたします。 ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.34%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問