صوتی و تصویری

همانطور که در ماژول تصاویر یاد گرفتید، HTML جاسازی رسانه در یک صفحه وب را امکان پذیر می کند. در این بخش، ما به فایل‌های صوتی و تصویری، از جمله نحوه جاسازی آن‌ها، کنترل‌های کاربر، ارائه یک مکان‌نمای ثابت تصویر برای ویدیوهای شما، و بهترین روش‌ها، از جمله در دسترس‌سازی فایل‌های صوتی و تصویری، نگاه می‌کنیم.

عناصر <video> و <audio> را می‌توان برای جاسازی پخش‌کننده‌های رسانه مستقیماً با ویژگی src یا می‌توان به عنوان عنصر محفظه برای یک سری عناصر <source> استفاده کرد که هر کدام یک پیشنهاد فایل src را ارائه می‌دهند. در حالی که <video> می تواند برای جاسازی یک فایل صوتی استفاده شود، عنصر <audio> برای جاسازی فایل های صوتی ترجیح داده می شود.

تگ‌های <video> و <audio> باز می‌توانند شامل چندین ویژگی دیگر از جمله controls ، autoplay ، loop ، mute ، preload و ویژگی‌های سراسری باشند. عنصر <video> از ویژگی های height ، width و poster نیز پشتیبانی می کند.

<video src="videos/machines.webm" poster="images/machine.jpg" controls>
  <p>Watch <a href="https://youtube.com/link">video on Youtube</a></p>
</video>

این مثال <video> دارای یک منبع واحد با ویژگی src است که به منبع ویدیو مرتبط است. ویژگی poster تصویری را برای نمایش در حین بارگذاری ویدیو فراهم می کند. در نهایت، ویژگی controls کنترل‌های ویدیویی کاربر را فراهم می‌کند.

محتوای بازگشتی بین تگ های باز و بسته گنجانده شده است. اگر عامل کاربر از <video> پشتیبانی نمی کند (یا <audio> این محتوا نشان داده می شود. تگ بسته شدن </video> مورد نیاز است، حتی اگر محتوایی بین این دو وجود نداشته باشد (اما همیشه باید محتوای بازگشتی وجود داشته باشد، درست است ؟).

اگر هیچ ویژگی src در تگ های <video> یا <audio> درج نشده است، یک یا چند عنصر <source> را که هر کدام دارای ویژگی src در یک فایل رسانه ای هستند، اضافه کنید. مثال زیر شامل سه گزینه فایل رسانه، محتوای بازگشتی، و زیرنویس انگلیسی و فرانسوی بین تگ‌های باز و بسته می‌شود.

<video controls poster="images/machine.jpg">
  <source src="videos/machines.webm" type="video/webm">
  <source src="videos/machines.mp4" type="video/mp4">
  <source src="videos/machines.ogv" type="video/ogg">
  <track label="English" kind="subtitles" srclang="en" src="vtt/subtitles-en.vtt" default />
  <track label="Francais" kind="subtitles" srclang="fr" src="vtt/subtitles-fr.vtt" />
  <p>Watch <a href="https://youtube.com/link">video on Youtube</a></p>
</video>

هر فرزند <source> شامل یک ویژگی src است که به منبع اشاره می کند و ویژگی type به مرورگر از نوع رسانه فایل پیوند شده اطلاع می دهد. این باعث می‌شود مرورگر فایل‌های رسانه‌ای را که قادر به رمزگشایی آن نیست، واکشی کند.

در صفت type ، می‌توانید یک پارامتر codecs را وارد کنید که دقیقاً نحوه کدگذاری منبع را مشخص می‌کند. کدک ها راهی را در اختیار شما قرار می دهند که بهینه سازی های رسانه ای را که هنوز در همه مرورگرها پشتیبانی نمی شوند، اضافه کنید. کدک از نوع رسانه با نقطه ویرگول جدا می شود. به عنوان مثال، کدک را می توان با استفاده از نحو بصری نوشت، مانند <source src="videos/machines.webm" type="video/webm;codecs=vp8,vorbis"> که نشان می دهد فایل های WebM حاوی ویدئو VP8 و vorbis هستند. صوتی رمزگشایی کدک‌ها نیز می‌تواند دشوارتر باشد، مانند <source src="videos/machines.mp4" type="video/mp4; codecs=avc1.4d002a"> که نشان می‌دهد رمزگذاری MP4، سطح نمایه اصلی کدگذاری ویدیوی پیشرفته سطح 4.2 است. . توضیح این نحو از حوصله این درس خارج است. جیک آرچیبالد پستی دارد که در آن توضیح می دهد که چگونه پارامتر کدک را برای یک ویدیوی AV1 تعیین کنید اگر می خواهید بیشتر بدانید.

هنگام نمایش یک ویدیو، به‌طور پیش‌فرض، اولین فریم ویدیو به‌عنوان عکس ثابت نشان داده می‌شود. این چیزی است که قابل کنترل است. ویژگی poster منبع تصویر را قادر می‌سازد تا هنگام بارگیری ویدیو و تا زمانی که پخش شود نشان داده شود. اگر ویدیو پخش شود و متعاقباً متوقف شود، پوستر دوباره نمایش داده نمی شود.

مطمئن شوید که نسبت تصویر خود را مشخص کرده اید، زیرا زمانی که ویدیو بارگذاری می شود، تفاوت اندازه بین پوستر و ویدیو باعث جریان مجدد و رنگ آمیزی مجدد می شود.

همیشه ویژگی controls بولی را در نظر بگیرید. این باعث می‌شود کنترل‌های کاربر قابل مشاهده باشد و به کاربران امکان کنترل سطوح صدا، قطع کامل صدا و گسترش ویدیو به تمام صفحه را می‌دهد. حذف controls تجربه کاربری بدی ایجاد می کند، به خصوص اگر ویژگی autoplay بولی در آن گنجانده شود. توجه داشته باشید که برخی از مرورگرها به دستورالعمل مشخصه autoplay توجه نمی‌کنند، اگر ویژگی muted بولی حذف شود، زیرا پخش خودکار یک فایل رسانه‌ای معمولاً تجربه کاربری بدی است، حتی در صورت بی‌صدا بودن و با کنترل‌های قابل مشاهده.

آهنگ ها

بین تگ‌های باز و بسته شدن الزامی صدا و تصویر، یک یا چند عنصر <track> را برای تعیین آهنگ‌های متنی زمان‌بندی شده قرار دهید. مثال زیر شامل دو فایل <track> است که زیرنویس‌های متنی زمان‌بندی شده را به دو زبان انگلیسی و فرانسوی ارائه می‌کند.

<track label="English" kind="subtitles" srclang="en" src="vtt/subtitles-en.vtt" default />
<track label="Français" kind="subtitles" srclang="fr" lang="fr-fr" src="vtt/subtitles-fr.vtt" />

فایل های آهنگ، مشخص شده در ویژگی src ، باید در قالب WebVTT (.vtt) باشند. فایل‌ها باید در همان دامنه سند HTML باشند، مگر اینکه ویژگی crossorigin گنجانده شده باشد.

پنج مقدار برشماری شده برای ویژگی track kind وجود دارد: subtitles ، captions ، descriptions ، chapters و سایر metadata .

برای رونویسی و ترجمه دیالوگ ها، subtitles همراه با ویژگی srclang قرار دهید. مقدار هر ویژگی label به عنوان یک گزینه به کاربر نمایش داده می شود. محتوای گزینه VTT انتخاب شده روی ویدیو نمایش داده می شود. ظاهر زیرنویس ها را می توان با هدف قرار دادن ::cue/ ::cue() سبک سازی کرد.

مقدار kind="caption" باید برای رونویسی و ترجمه‌هایی که شامل جلوه‌های صوتی و سایر اطلاعات صوتی مرتبط هستند، رزرو شود. این فقط برای بینندگان ناشنوا نیست. شاید یک کاربر نتواند هدفون خود را پیدا کند بنابراین زیرنویس را روشن کرده است. یا شاید آنها چند نکته آخر صحبت را از یک پادکست مورد علاقه خود کاملاً نفهمیده اند، بنابراین می خواهند متن را بخوانند تا درک خود را تأیید کنند. داشتن راه های جایگزین برای دسترسی به محتوای صوتی و تصویری هم مهم و هم راحت است.

kind="description" برای توصیف متنی محتوای بصری در ویدیو برای کاربرانی است که نمی توانند ویدیو را ببینند، خواه از سیستمی بدون صفحه مانند Google Home یا Alexa استفاده می کنند یا نابینا هستند.

ارائه زیرنویس‌ها و زیرنویس‌ها با استفاده از قالب WebVTT باعث می‌شود که ویدیو برای افراد دارای اختلال شنوایی قابل دسترسی باشد. به یاد داشته باشید، ناتوانی عدم تطابق بین یک فرد و محیط فعلی است. اختلال شنوایی می تواند به دلیل قرار گرفتن کاربر در یک محیط پر سر و صدا، داشتن بلندگوهای معیوب یا هدفون شکسته یا به دلیل کم شنوایی یا ناشنوا بودن کاربر باشد. اطمینان از در دسترس بودن محتوای شما به افراد بیشتری از آنچه فکر می کنید کمک می کند. به همه کمک می کند.

ملاحظات ویدیوی پس زمینه

تیم بازاریابی یا طراحی شما ممکن است بخواهد که سایت شما یک ویدیوی پس زمینه داشته باشد. به طور کلی، این بدان معنی است که آنها می خواهند یک ویدیوی بی صدا، پخش خودکار و حلقه ای بدون کنترل داشته باشند. HTML ممکن است چیزی شبیه به این باشد:

<video autoplay loop muted poster="images/machine.jpg" role="none">
  <source src="videos/machines.webm" type="video/webm">
  <source src="videos/machines.mp4" type="video/mp4">
  <source src="videos/machines.ogv" type="video/ogg">
</video>

ویدئوهای پس زمینه قابل دسترسی نیستند. محتوا نباید از طریق ویدیوهای پس‌زمینه بدون کنترل کامل پخش و دسترسی به همه زیرنویس‌ها به کاربران منتقل شود. از آنجایی که این ویدیو صرفاً تزئینی است، نقش ARIA none را شامل می شود و هر گونه محتوای بازگشتی را حذف می کند. برای بهبود عملکرد ویدیوهای همیشه بی صدا، آهنگ صوتی را از منابع رسانه خود حذف کنید .

اگر ویدیوی شما به مدت پنج ثانیه یا کمتر پخش می‌شود، دستورالعمل‌های دسترس‌پذیری نیازی به مکانیزم مکث ندارند، اما هر چیزی که دارای ویژگی loop بولی باشد به‌طور پیش‌فرض برای همیشه حلقه می‌شود و از این پنج ثانیه یا هر محدودیت زمانی دیگری فراتر می‌رود. برای تجربه کاربری خوب، همیشه روشی برای مکث ویدیو در نظر بگیرید. این کار به راحتی با درج controls انجام می شود.

کنترل های رسانه ای سفارشی

برای نمایش کنترل‌های ویدیویی یا صوتی سفارشی، به‌جای کنترل‌های داخلی مرورگر، ویژگی controls را لحاظ کنید. سپس از جاوا اسکریپت برای افزودن کنترل های رسانه ای سفارشی و حذف ویژگی کنترل ها استفاده کنید. برای مثال، می‌توانید یک <button> اضافه کنید که وضعیت پخش یک فایل صوتی را تغییر می‌دهد.

<button id="playPause" aria-controls="idOfAudio"
  data-pause-text="Pause audio"
  data-play-text="Play audio">Pause audio</button>

این مثال شامل دکمه‌ای با ویژگی‌های dataset است که حاوی متنی است که با جابجایی بازدیدکننده بین حالت‌های پخش و مکث به‌روزرسانی می‌شود. ویژگی aria-controls همراه با id عنصری است که توسط دکمه کنترل می شود. در این مورد، صدا هر دکمه ای که صدا را کنترل می کند یک کنترل کننده رویداد دارد.

برای ایجاد کنترل های سفارشی شده، از HTMLMediaElement.play() و HTMLMediaElement.pause() استفاده کنید. هنگام تغییر وضعیت پخش، متن دکمه را نیز تغییر دهید:

const pauseButton = document.getElementById('playPause');

pauseButton.addEventListener("click", pauseAndPlay, false);

function pauseAndPlay() {
  console.log(this);
  const media = document.getElementById(this.getAttribute('aria-controls'));

  if (media.paused) {
    media.play();
    this.innerText = this.dataset.pauseText;
  } else {
    media.pause();
    this.innerText = this.dataset.playText;
  }
}

با گنجاندن ویژگی controls ، کاربر راهی برای کنترل صدا (یا ویدیو) حتی در صورت خرابی جاوا اسکریپت دارد. فقط زمانی که دکمه جایگزینی نصب شد، ویژگی کنترل ها را حذف کنید.

document.querySelector('[aria-controls]').removeAttribute('controls');

هنگامی که کاربران نمی توانند به کنترل ها دسترسی داشته باشند، همیشه کنترل های خارجی را شامل کنید، مانند ویدیوهای پس زمینه ای که کنترل های آنها در پشت محتوای سایت پنهان است. درک اصول اولیه الزامات دسترسی به رسانه برای پاسخگویی به کاربران با نیازهای مختلف محیطی و حسی، از جمله میلیون‌ها نفر با ناشنوایی و اختلالات بینایی، مهم است. ما به تازگی HTMLMediaElement را لمس کرده‌ایم که چندین ویژگی، روش و رویداد را ارائه می‌کند که توسط HTMLVideoElement و HTMLAudioElement به ارث برده می‌شوند، با HTMLMediaElement که چند ویژگی، روش و رویداد خاص خود را اضافه می‌کند. چندین API رسانه دیگر از جمله API TextTrack وجود دارد. می‌توانید از Media Capture و Streams و MediaDevices API برای ضبط صدا از میکروفون کاربر یا ضبط صفحه نمایش کاربر استفاده کنید. Web Audio API امکان دستکاری صداهای زنده و از پیش ضبط شده و پخش جریانی، ذخیره یا ارسال صدا را به عنصر <audio> می دهد.

درک خود را بررسی کنید

دانش خود را در زمینه صدا و تصویر آزمایش کنید.

عنصر <track> برای چیست؟

برای ذخیره چندین نسخه از ویدیو برای مرورگرها یا دستگاه های مختلف.
برای ذخیره اطلاعات در مورد طول و اندازه فایل ویدیو.
برای ارائه زیرنویس یا زیرنویس.

ویژگی poster چه چیزی را کنترل می کند؟

تصویری که قبل از پخش ویدیو به صورت عکس ثابت نمایش داده می شود.
یک ویدیوی مقدماتی
تصویری برای نمایش اگر مرورگر کاربر از ویدئو پشتیبانی نمی‌کند.