IMA SDK Pre-roll 연동

Google IMA SDK 기반의 Pre-roll 광고를 지원합니다. options.ads.tagUrl에 VAST/VMAP 태그 URL을 전달하면 콘텐츠 재생 전에 광고가 자동으로 재생됩니다.

동작 방식

  • Google IMA SDK는 외부에서 자동 로드됩니다.
  • 광고 재생 중 콘텐츠는 일시정지되고 컨트롤바가 숨겨집니다.
  • 광고 완료/스킵/에러 이후 콘텐츠가 자동 재생됩니다.

제한사항

  • 스킵 버튼은 IMA SDK iframe 내부에 렌더링되어 외부에서 스타일링할 수 없습니다.
  • 광고 옵션이 없으면 기존 재생 흐름과 동일하게 동작합니다.

기본 사용법

const player = new ncplayer("video", {
    playlist: [
        { file: "https://CDN_DOMAIN/example.m3u8" },
    ],
    autostart: true,
    muted: true,
    ads: {
        tagUrl: "https://pubads.g.doubleclick.net/gampad/ads?iu=/21775744923/external/single_preroll_skippable&sz=640x480&ciu_szs=300x250%2C728x90&gdfp_req=1&output=vast&unviewed_position_start=1&env=vp&impl=s&correlator=",
    },
});

// 광고 이벤트 수신
player.on("adStart", function(e) { console.log("광고 시작"); });
player.on("adComplete", function(e) { console.log("광고 완료"); });
player.on("adSkip", function(e) { console.log("광고 스킵"); });
player.on("adError", function(e) { console.log("광고 에러", e.data?.message); });

광고 이벤트

이벤트설명
adStart광고 재생 시작
adComplete광고 재생 완료
adSkip사용자가 광고 스킵
adError광고 로드/재생 에러

광고 비활성화

enabled 값을 false로 설정하면 광고를 끌 수 있습니다.

ads: {
    tagUrl: "https://pubads.g.doubleclick.net/gampad/ads?iu=/21775744923/external/single_preroll_skippable&sz=640x480&ciu_szs=300x250%2C728x90&gdfp_req=1&output=vast&unviewed_position_start=1&env=vp&impl=s&correlator=",
    enabled: false,
}

전체 HTML 예제

<!DOCTYPE html>
<html lang="ko">
<head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>VPE Player - IMA 광고</title>
    <script src="https://player.vpe.naverncp.com/v2/ncplayer.js?access_key=YOUR_ACCESS_KEY"></script>
</head>
<body>
    <div id="video" style="max-width: 800px; margin: 0 auto;"></div>

    <script>
        const player = new ncplayer("video", {
            playlist: [
                {
                    file: "https://CDN_DOMAIN/example.m3u8",
                    poster: "https://CDN_DOMAIN/poster.jpg",
                },
            ],
            autostart: true,
            muted: true,
            ads: {
                tagUrl: "YOUR_VAST_TAG_URL",
            },
        });

        player.on("adStart", function(e) {
            console.log("광고 시작");
        });
        player.on("adComplete", function(e) {
            console.log("광고 완료");
        });
        player.on("adSkip", function(e) {
            console.log("광고 스킵");
        });
        player.on("adError", function(e) {
            console.log("광고 에러", e.data?.message);
        });
    </script>
</body>
</html>
UMD