유튜브 동영상 시간체크 후 폼 전송하기
[code]
<style>
#ytDiv { width:800px; height:450px; }
#ytDiv iframe { width:100%; height:100%; }
</style>
<div id="ytDiv"><iframe src="https://www.youtube.com/embed/T2ZNOZmdD-E?enablejsapi=1" frameborder="0" allowfullscreen></iframe></div>
<input id="yt_current" name="yt_current">
<input id="yt_total" name="yt_total">
<script src="https://www.youtube.com/iframe_api"></script>
<script>
function onYouTubeIframeAPIReady() {
ytDiv = new YT.Player(document.querySelector("#ytDiv iframe"), { "onReady": (event) => { event.target.playVideo(); } } );
setInterval( () => {
yt_current.value = Math.ceil(ytDiv.getCurrentTime());
yt_total.value = Math.floor(ytDiv.getDuration());
}, 1000);
}
</script>
[/code]
유튜브 동영상을 강좌동영상 등으로 사용할 때 회원이 다 보았는지 덜 보았는지를 체크하는 기본 로직입니다.
https://wittazzurri.com/editor/html_editor.php 에서 확인해 보세요.
그리고 아래처럼 폼을 하나 감아서 액션문서에서 DB 에 저장하거나 아작스로 넘기거나 등등...
yt_current 가 yt_total 보다 크거나 같다면 모두시청 아니라면 시청미완료 등으로 로직을 짜 주면 되겠습니다.
<form>
<input id="yt_current" name="yt_current">
<input id="yt_total" name="yt_total">
</form>
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기
댓글 15개
저도 얼마전에 제작의뢰를 받아서 짜 본 코드에요.
이것 보다는 훨 디테일해서 5분을 듣고 다음에 입방하면 처음부터가 아니라 5분 시점부터 재생이 되게요.
폼에도 단순한 타이머 뿐만이 아니라 멤버아이디와 게시판아이디와 게시글아이디를 같이 날려 저장해서 관리자가 본 사람 안 본 사람의 리스트까지를 만드는 코드인데 기본이 이 로직입니다.
찾아보고 있었습니다.
좋은 정보 감사합니다.
궁금한 사항으로는 시청시간을 체크하는데 아래의 재생 이동하는 바를 움직일 수 없게 하거나 없애야 체크가 되지 않는지 궁금합니다.
예를 들면 재생 버튼을 끝까지 옮겨버리면 다 시청한걸로 인식되지 않은지 궁금합니다.