Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
SDK Pemain IVS: Integrasi Video.js
Dokumen ini menjelaskan fungsi terpenting yang tersedia di Video.js pemutar Amazon Interactive Video Service (IVS).
Versi terbaru dari integrasi Video.js pemain: 1.52.0 (Catatan Rilis)
Memulai
Dukungan Amazon IVS untuk Video.js diimplementasikan melalui Video.js teknologi
Perhatikan bahwa saat membuat instance pemain, opsi Video.js sumbersrc() Jika putar otomatis diaktifkan, aliran akan mulai diputar; jika tidak, gunakan play() untuk memulai pemutaran.
Demo
Demo langsung berikut menunjukkan cara menggunakan Video.js integrasi dengan tag skrip dari Jaringan Pengiriman Konten kami: Video.js integrasi Amazon IVS Player
Pengaturan Dengan Tag Skrip
Untuk mengatur teknologi Amazon IVS menggunakan script tag:
-
Sertakan tag berikut (untuk versi terbaru dari integrasi pemain).
<script src="https://player.live-video.net/1.52.0/amazon-ivs-videojs-tech.min.js"></script> -
Daftarkan teknologi menggunakan
registerIVSTechfungsi:registerIVSTech(videojs);di
videojsmana objek yang disediakan oleh Video.js. -
Saat membuat instance pemain, tambahkan
AmazonIVSsebagai teknologi pertama Anda ditechOrderopsi.
Saat membuat instance pemain, opsi Video.js sumbersrc() fungsi di atasnya. Jika putar otomatis diaktifkan, aliran akan mulai diputar; jika tidak, gunakan play() untuk memulai pemutaran.
Kode Sampel
Dalam contoh ini, PLAYBACK_URL adalah aliran sumber yang ingin Anda muat. Contoh menggunakan versi terbaru dari Amazon IVS Player.
<!doctype html> <html lang="en"> <head> <link href="https://cdnjs.cloudflare.com/ajax/libs/video.js/7.14.3/video-js.css" rel="stylesheet"> <script src="https://cdnjs.cloudflare.com/ajax/libs/video.js/7.14.3/video.min.js"></script> <script src="https://player.live-video.net/1.52.0/amazon-ivs-videojs-tech.min.js"></script> </head> <body> <div class="video-container"> <video id="amazon-ivs-videojs" class="video-js vjs-4-3 vjs-big-play-centered" controls autoplay playsinline></video> </div> <style> body { margin: 0; } .video-container { width: 640px; height: 480px; margin: 15px; } </style> <script> (function play() { // Get playback URL from Amazon IVS API var PLAYBACK_URL = ''; // Register Amazon IVS as playback technology for Video.js registerIVSTech(videojs); // Initialize player var player = videojs('amazon-ivs-videojs', { techOrder: ["AmazonIVS"] }, () => { console.log('Player is ready to use!'); // Play stream player.src(PLAYBACK_URL); }); })(); </script> </body> </html>
Pengaturan Dengan NPM
Untuk menggunakan pemutar Amazon IVS melalui npm:
-
Instal paket npm video.js
atau pastikan proyek Anda memiliki akses lain ke Video.js perpustakaan. -
Instal paket
amazon-ivs-playernpm:npm install amazon-ivs-player -
Saat Anda siap mendaftarkan teknologi Amazon IVS, impor
registerIVSTechfungsinya:import { registerIVSTech } from 'amazon-ivs-player'; -
Daftarkan teknologi menggunakan
registerIVSTechfungsi:registerIVSTech(videojs, options);di mana:
-
videojsadalah objek yang disediakan oleh Video.js. -
optionsadalah opsi untuk lapisan teknologi Amazon IVS. Opsi yang didukung adalah:.-
wasmWorker: URL tempatamazon-ivs-wasmworker.min.jsfile di-host. -
wasmBinary: URL tempatamazon-ivs-wasmworker.min.wasmfile di-host.
File pekerja ada di
node_modules/folder Anda di bawahamazon-ivs-player/dist/. Anda perlu meng-host mereka, untuk menggunakan pemutar IVS. -
-
-
Saat membuat instance pemain, tambahkan
AmazonIVSsebagai teknologi pertama Anda ditechOrderopsi:const player = videojs('videojs-player', { techOrder: ["AmazonIVS"] });
TypeScript
Jika Anda menggunakan TypeScript, paket npm kami mencakup jenis berikut yang mungkin ingin Anda impor dan gunakan.
-
VideoJSEvents, yang menggambarkan struktur yang dikembalikan darigetIVSEvents(). -
VideoJSIVSTech, yang menggambarkan antarmuka ke instance pemain yang menggunakanAmazonIVSteknologi. Ini dapat berpotongan denganVideoJsPlayertipe yang dieksposoleh paket @ types/video .js npm. -
TechOptions, yang menjelaskan antarmuka yang menentukan opsi konfigurasi yang dapat Anda kirim.registerIVSTech()
Untuk informasi selengkapnya tentang jenis ini, lihat Amazon IVS Player SDK: Referensi Web
Peristiwa
Untuk mendengarkan Video.js acara standar, gunakan fungsi on
Untuk mendengarkan acara yang khusus untuk Amazon IVS, tambahkan dan hapus pendengar acara di pemutar Web Amazon IVS:
player.getIVSPlayer().addEventListener(event, callback); player.getIVSPlayer().removeEventListener(event, callback);
di callback mana panggilan balik yang Anda tentukan, dan event merupakan salah satu dari: PlayerEventType atauPlayerState. Untuk informasi selengkapnya tentang peristiwa, lihat Amazon IVS Player SDK: Referensi Web
Kesalahan
Untuk Video.js kesalahan umum, dengarkan error acara generik pada pemain:
player.on("error", callback);
Untuk kesalahan khusus untuk Amazon IVS, dengarkan di pemutar Amazon IVS untuk kesalahannya sendiri:
let playerEvent = player.getIVSEvents().PlayerEventType; player.getIVSPlayer().addEventListener(playerEvent.ERROR, callback);
Callback akan menerima objek dengan bidang berikut:
| Bidang | Deskripsi |
|---|---|
|
Jenis kesalahan. Sesuai dengan |
|
Kode kesalahan. |
|
Sumber kesalahan. |
|
Pesan kesalahan yang dapat dibaca manusia. |
Plugin
Kami menyediakan plugin yang membuat sakelar UI untuk kualitas yang tersedia. Untuk menggunakan plugin ini, plugin harus dimuat dengan menyertakan amazon-ivs-quality-plugin.min.js file jika Anda menggunakan teknologi kami melalui script tag berikut (untuk versi terbaru dari IVS Player):
<script src="https://player.live-video.net/1.52.0/amazon-ivs-quality-plugin.min.js"></script>
Jika Anda menggunakan npm, impor registerIVSQualityPlugin dari amazon-ivs-player modul:
import { registerIVSQualityPlugin } from 'amazon-ivs-player';
Kemudian, setelah Anda membuat instance Video.js pemain Anda, panggilan berikut diperlukan untuk mendaftar dan mengaktifkannya:
registerIVSQualityPlugin(videojs); // where videojs is the video.js variable player.enableIVSQualityPlugin(); // where player is the instance of the videojs player
Ini akan membuat tombol menu UI yang memungkinkan Anda memilih kualitas untuk streaming.
Plugin dan TypeScript
Jika Anda menggunakan TypeScript, paket npm kami mencakup VideoJSQualityPlugin jenis yang mungkin ingin Anda impor dan gunakan dengan plugin kami. Plugin pada dasarnya adalah mixin, jadi antarmuka tipe ini akan digunakan sebagai tipe persimpanganVideoJSIVSTech
Kebijakan Keamanan Konten
Amazon IVS Video.js API dikonfigurasi untuk bekerja pada halaman yang menggunakan Kebijakan Keamanan Konten (CSP). Lihat bagian “Bekerja dengan Kebijakan Keamanan Konten” diSDK IVS Player: Panduan Web.
Fungsi
Pemutaran
Amazon IVS Video.js API mendukung antarmuka yang diperlukan untuk penggunaan internal oleh kerangka kerja. Video.js Aplikasi klien tidak mungkin perlu menggunakan metode ini secara langsung, karena Video.js melakukan integrasi yang diperlukan dan menyajikan antarmuka standar. Namun, jika diperlukan, salah satu cara untuk mengakses metode pemain internal Video.js dan Amazon IVS adalah dengan menggunakan objek Video.js pemain untuk mendapatkan pegangan objek yang diperlukan untuk teknologi.
Untuk mengakses API, ambil instance Video.js pemain Anda seperti biasanya:
let player = videojs("videoTagId"); //replace videoTagId with your <video> tag’s id
Kemudian Anda dapat memanggil fungsi pada contoh itu.
Berikut ini adalah bagian dari Video.js fungsi yang diganti oleh lapisan teknologi Amazon IVS. Untuk daftar lengkap Video.js fungsi, lihat dokumentasi API video.js
| Fungsi | Deskripsi dan IVS-Specific Informasi Amazon |
|---|---|
|
Mendapat atau mengatur waktu (dalam hitungan detik dari awal). Amazon IVS: Kami tidak menyarankan pengaturan waktu saat ini untuk streaming langsung. |
|
Menghapus instance pemain Amazon IVS: Ini juga menghapus backend teknologi Amazon IVS. |
|
Mengembalikan durasi video, dalam hitungan detik. Amazon IVS: Untuk streaming langsung, ini kembali. |
|
Mulai memuat Amazon IVS: Ini adalah no-op. |
|
Memutar aliran yang diatur melalui Amazon IVS: Jika streaming langsung dijeda, ini memutar streaming langsung dari bingkai terbaru, alih-alih melanjutkan dari tempat itu dijeda. |
|
Mendapat atau menetapkan tingkat pemutaran video. 1.0 berarti kecepatan normal; 0,5, setengah kecepatan normal; 2.0, dua kali kecepatan normal; dan seterusnya. Amazon IVS: Pada streaming langsung, get mengembalikan 1, dan satu set diabaikan. |
|
Amazon IVS: Untuk streaming langsung, memanggil |
Amazon IVS Khusus
Video.js Teknologi Amazon IVS memiliki fungsi tambahan untuk mengakses perilaku khusus untuk fitur Amazon IVS:
| Fungsi | Deskripsi |
|---|---|
|
Mengembalikan instance pemutar Amazon IVS yang mendasarinya. API Web Amazon IVS Player lengkap tersedia melalui instance ini. Sebaiknya gunakan API Video.js pemutaran dasar sebanyak mungkin, dan gunakan fungsi ini hanya untuk mengakses IVS-specific fitur Amazon. Fungsi paling umum yang mungkin perlu Anda akses di instans pemutar Amazon IVS adalah |
|
Mengembalikan objek yang menyimpan IVS-specific enum Amazon. Ini digunakan untuk mendengarkan IVS-specific kesalahan Amazon. Untuk informasi selengkapnya, lihat Peristiwa dan Kesalahan. |
Waktu saat ini
Mendapat atau mengatur waktu (dalam hitungan detik dari awal).
Amazon IVS: Kami tidak menyarankan pengaturan waktu saat ini untuk streaming langsung.
Tanda tangan
currentTime currentTime(time)
Parameter
| Parameter | Jenis | Deskripsi |
|---|---|---|
|
number |
Jika tidak |
Nilai yang Ditampilkan
| Tipe | Deskripsi |
|---|---|
number |
Waktu saat ini, dalam hitungan detik dari awal. |
buang
Menghapus instance pemain.
Amazon IVS: Ini juga menghapus backend teknologi Amazon IVS.
Tanda tangan
dispose()
Parameter
Tidak ada
Nilai yang Ditampilkan
Tidak ada
durasi
Mengembalikan durasi video, dalam hitungan detik.
Amazon IVS: Untuk streaming langsung, ini kembali. Infinity
Tanda tangan
duration()
Parameter
Tidak ada
Nilai yang Ditampilkan
| Tipe | Deskripsi |
|---|---|
number |
Durasi aliran, dalam hitungan detik. Untuk streaming langsung, nilai ini adalah |
GetivsEvents
Mengembalikan objek yang menyimpan IVS-specific enum Amazon. Ini digunakan untuk mendengarkan IVS-specific kesalahan dan peristiwa Amazon. Untuk informasi lebih lanjut, lihat:
-
Amazon IVS Player SDK: Referensi Web
untuk informasi selengkapnya tentang peristiwa, jenis kesalahan, dan sumber kesalahan.
Tanda tangan
getIVSEvents()
Parameter
Tidak ada
Nilai yang Ditampilkan
| Tipe | Deskripsi |
|---|---|
|
Objek dengan |
GetivsPlayer
Mengembalikan instance pemutar Amazon IVS yang mendasarinya. API Web Amazon IVS Player lengkap tersedia melalui instance ini. Sebaiknya gunakan API Video.js pemutaran dasar sebanyak mungkin, dan gunakan fungsi ini hanya untuk mengakses IVS-specific fitur Amazon. Fungsi paling umum yang mungkin perlu Anda akses di instans pemutar Amazon IVS adalah setQuality() danaddEventListener()/removeEventListener().
Tanda tangan
getIVSPlayer()
Parameter
Tidak ada
Nilai yang Ditampilkan
| Tipe | Deskripsi |
|---|---|
|
Contoh yang dibuat dari pemain. |
muat
Mulai memuat src() data.
Amazon IVS: Ini adalah no-op.
Tanda tangan
load()
Parameter
Tidak ada
Nilai yang Ditampilkan
Tidak ada
pementasan
Memutar aliran yang diatur melalui src panggilan.
Amazon IVS: Jika streaming langsung dijeda, ini memutar streaming langsung dari bingkai terbaru, alih-alih melanjutkan dari tempat itu dijeda.
Tanda tangan
play()
Parameter
Tidak ada
Nilai yang Ditampilkan
Tidak ada
PlaybackRate
Mendapat atau menetapkan tingkat pemutaran video. 1.0 berarti kecepatan normal; 0,5, setengah kecepatan normal; 2.0, dua kali kecepatan normal; dan seterusnya.
Amazon IVS: Pada streaming langsung, get mengembalikan 1, dan satu set diabaikan.
Tanda tangan
playbackRate playbackRate(rate)
Parameter
| Parameter | Jenis | Deskripsi |
|---|---|---|
|
number |
Tingkat pemutaran. Nilai yang valid: dalam kisaran [0.25, 2.0]. |
Nilai yang Ditampilkan
| Tipe | Deskripsi |
|---|---|
number |
Tingkat pemutaran. |
dicari
TimeRangesMengembalikan media yang dapat dicari.
Amazon IVS: Untuk streaming langsung, memanggil end(0) return value (TimeRange) mengembalikan Infinity.
Tanda tangan
seekable()
Parameter
Tidak ada
Nilai yang Ditampilkan
| Tipe | Deskripsi |
|---|---|
|
TimeRange dari media yang tersedia untuk dicari. |