پس زمینه دوربین را تار کنید

فرانسوا بوفور
François Beaufort

تاری پس‌زمینه یک عملکرد محبوب در برنامه‌های کنفرانس ویدیویی مدرن است. به طور خودکار پس‌زمینه را از فرد مقابل دوربین متمایز می‌کند و در عین حال که تمرکز روی فرد را حفظ می‌کند، محیط اطراف را تار می‌کند.

Background Blur API قابلیت‌های پنهان‌سازی پس‌زمینه را به وب می‌آورد. این API این امکان را برای برنامه‌های وب فراهم می‌کند که از سیستم عامل بخواهند به طور موثر جلوه تاری پس‌زمینه را در فید ویدیوی دوربین اعمال کند. این امر نیاز پرهزینه به کاربرد دستی افکت را از طریق چارچوب‌های یادگیری ماشینی مانند TensorFlow.js، Mediapipe یا راه‌حل‌های مبتنی بر ابر، که نیاز به پردازش هر فریم ویدیو به‌صورت جداگانه دارند، از بین می‌برد.

عکس با تاری پس‌زمینه خاموش و روشن است.
عکس با تاری پس‌زمینه خاموش (چپ) و روشن (راست).

Background Blur API را فعال کنید

به‌طور پیش‌فرض، Background Blur API در Chrome فعال نیست، اما می‌توان با فعال کردن صریح این عملکرد، آن را در Chrome 114 آزمایش کرد. می‌توانید با فعال کردن پرچم «ویژگی‌های پلتفرم وب آزمایشی» در chrome://flags/#enable-experimental-web-platform-features آن را به صورت محلی فعال کنید.

برای فعال کردن آن برای همه بازدیدکنندگان برنامه شما، یک آزمایش اولیه در حال انجام است و قرار است در Chrome 117 (3 نوامبر 2023) به پایان برسد. برای شرکت در آزمایشی، ثبت نام کنید و یک عنصر متا را با نشانه آزمایشی اصلی در هدر HTML یا HTTP قرار دهید. برای اطلاعات بیشتر، به شروع کار با آزمایش‌های مبدا مراجعه کنید.

تغییرات تاری پس زمینه را مشاهده کنید

تنظیم بولی backgroundBlur در MediaStreamTrack به شما امکان می دهد بدانید که آیا سیستم عامل تاری پس زمینه را در دستگاه رسانه اعمال می کند یا خیر. به‌علاوه، وقتی کاربر تاری پس‌زمینه را از طریق یک سیستم عامل روشن یا خاموش می‌کند، یک رویداد "configurationchange" در MediaStreamTrack اجرا می‌شود.

قطعه کد زیر نحوه نظارت بر تغییرات تاری پس‌زمینه را در دستگاه رسانه‌ای که کاربر به آن اجازه دسترسی داده است، نشان می‌دهد.

// Prompt the user to grant access to a camera.
const stream = await navigator.mediaDevices.getUserMedia({ video: true });
// Show camera video feed to the user (optional).
document.querySelector("video").srcObject = stream;

// Read current background blur value.
const [track] = stream.getVideoTracks();
let { backgroundBlur } = track.getSettings();
console.log(`Background blur is ${backgroundBlur ? "ON" : "OFF"}`);

// Listen to background blur changes.
track.addEventListener("configurationchange", () => {
  if (backgroundBlur !== track.getSettings().backgroundBlur) {
    backgroundBlur = track.getSettings().backgroundBlur;
    console.log(`Background blur is now ${backgroundBlur ? "ON" : "OFF"}`);
  }
});

تاری پس‌زمینه را تغییر دهید

قابلیت آرایه backgroundBlur در MediaStreamTrack به شما این امکان را می دهد که بدانید آیا می توانید تاری پس زمینه را در دستگاه رسانه کنترل کنید یا خیر. اگر تعریف نشده باشد یا فقط یک مقدار ( [true] یا [false] ) داشته باشد، نمی‌توانید تاری پس‌زمینه دوربین را کنترل کنید. اگر حاوی دو مقدار باشد، می‌توانید از متد applyConstraints() در MediaStreamTrack استفاده کنید تا از سیستم‌عامل درخواست کنید تا افکت تاری پس‌زمینه را به فید ویدیوی دوربین تغییر دهد. وعده برگشتی در صورت موفقیت حل می شود و در صورت خطا رد می شود.

قطعه کد زیر نحوه کنترل تاری پس‌زمینه دوربین در دستگاه رسانه‌ای که کاربر اجازه دسترسی به آن را داده است را نشان می‌دهد.

// Prompt the user to grant access to a camera.
const stream = await navigator.mediaDevices.getUserMedia({ video: true });
// Show camera video feed to the user (optional).
document.querySelector("video").srcObject = stream;

// Check whether the user can toggle background blur in the web app.
// If not, note that you may still want to apply it through a fallback
// software solution.
const [track] = stream.getVideoTracks();
if (track.getCapabilities().backgroundBlur?.length === 2) {
  const button = document.querySelector("button");
  button.addEventListener("click", toggleBackgroundBlurButtonClick);
  button.disabled = false;
}

async function toggleBackgroundBlurButtonClick() {
  const constraints = {
    backgroundBlur: !track.getSettings().backgroundBlur,
  };
  // Request operating system to toggle background blur.
  await track.applyConstraints(constraints);
  const newSettings = track.getSettings();
  log(`Background blur is now ${newSettings.backgroundBlur ? "ON" : "OFF"}`);
}

پشتیبانی از پلتفرم

Background Blur API در Chrome 114 در ChromeOS، macOS و Windows موجود است.

ChromeOS و macOS در حال حاضر فقط به شما اجازه می‌دهند تا تغییرات محو شدن پس‌زمینه را مشاهده کنید که کاربر می‌تواند از طریق رابط کاربری سیستم عامل خود مانند مرکز کنترل در macOS انجام دهد. ویندوز به شما امکان می دهد تاری پس زمینه را مشاهده و کنترل کنید.

نسخه ی نمایشی

می‌توانید تاری پس‌زمینه را تغییر دهید و تغییرات را با بازی با نمونه رسمی مشاهده کنید. (همانطور که قبلا ذکر شد، در دسترس بودن آن ویژگی ها به پشتیبانی پلتفرم بستگی دارد.)

یک برنامه وب که تغییرات تاری پس‌زمینه دوربین را مشاهده می‌کند.

بازخورد

بازخورد برنامه‌نویس در این مرحله بسیار مهم است، بنابراین لطفاً مشکلات را با پیشنهادات و سؤالات در GitHub ارسال کنید .

مایلیم نظرات شما را در مورد اینکه آیا نمایش تاری پس‌زمینه به‌عنوان یک مقدار بولی با نیازهای شما مطابقت دارد یا خیر، یا رویکردی دقیق‌تر مانند «نور»، «قوی»، «خاموش» مناسب‌تر است، حتی اگر اینطور نباشد، بشنویم. سازگار با آنچه در همه سیستم عامل ها در معرض نمایش است.