اشکال زدایی برنامه های گیرنده Cast

1. بررسی اجمالی

نشان‌واره Google Cast

این کد لبه به شما یاد می دهد که چگونه Cast Debug Logger را به برنامه گیرنده وب سفارشی موجود خود اضافه کنید.

Google Cast چیست؟

Google Cast SDK به برنامه شما امکان پخش محتوا و کنترل پخش در دستگاه‌های دارای Google Cast را می‌دهد. این مؤلفه‌های لازم UI را بر اساس فهرست بررسی طراحی Google Cast در اختیار شما قرار می‌دهد.

چک لیست طراحی Google Cast برای ساده و قابل پیش بینی کردن تجربه کاربر Cast در همه پلتفرم های پشتیبانی شده ارائه شده است.

قرار است چه چیزی بسازیم؟

هنگامی که این کد لبه را تکمیل کردید، یک گیرنده وب سفارشی خواهید داشت که با Cast Debug Logger یکپارچه شده است.

برای جزئیات و اطلاعات بیشتر به راهنمای Cast Debug Logger مراجعه کنید.

چیزی که یاد خواهید گرفت

  • چگونه محیط خود را برای توسعه گیرنده وب تنظیم کنید.
  • نحوه ادغام Debug Logger در گیرنده Cast.

آنچه شما نیاز دارید

  • آخرین مرورگر گوگل کروم .
  • سرویس میزبانی HTTPS مانند میزبانی Firebase یا ngrok .
  • یک دستگاه Google Cast مانند Chromecast یا Android TV که با دسترسی به اینترنت پیکربندی شده است.
  • تلویزیون یا مانیتور با ورودی HDMI.

تجربه کنید

  • شما باید تجربه قبلی Cast داشته باشید و بدانید که گیرنده وب Cast چگونه کار می کند.
  • شما باید دانش قبلی توسعه وب داشته باشید.
  • شما همچنین به دانش قبلی در مورد تماشای تلویزیون نیاز دارید :)

چگونه از این آموزش استفاده خواهید کرد؟

فقط از طریق آن را بخوانید آن را بخوانید و تمرینات را کامل کنید

تجربه خود را با ساختن اپلیکیشن های وب چگونه ارزیابی می کنید؟

تازه کار متوسط مسلط

تجربه خود را از تماشای تلویزیون چگونه ارزیابی می کنید؟

تازه کار متوسط مسلط

2. کد نمونه را دریافت کنید

می توانید تمام کدهای نمونه را در رایانه خود دانلود کنید ...

و فایل فشرده دانلود شده را باز کنید.

3. استقرار گیرنده خود به صورت محلی

برای اینکه بتوانید از گیرنده وب خود با دستگاه Cast استفاده کنید، باید در جایی میزبانی شود که دستگاه Cast شما بتواند به آن دسترسی پیدا کند. اگر از قبل سروری در دسترس دارید که از https پشتیبانی می کند، دستورالعمل های زیر را نادیده بگیرید و URL را یادداشت کنید ، زیرا در بخش بعدی به آن نیاز خواهید داشت.

اگر سروری برای استفاده در دسترس ندارید، می توانید از Firebase Hosting یا ngrok استفاده کنید.

سرور را اجرا کنید

هنگامی که سرویس مورد نظر خود را راه اندازی کردید، به app-start بروید و سرور خود را راه اندازی کنید.

URL مربوط به گیرنده میزبان خود را یادداشت کنید. در بخش بعدی از آن استفاده خواهید کرد.

4. یک برنامه را در Cast Developer Console ثبت کنید

شما باید برنامه خود را ثبت کنید تا بتوانید یک گیرنده وب سفارشی، همانطور که در این لبه کد ساخته شده است، در دستگاه های Chromecast اجرا کنید. پس از اینکه برنامه خود را ثبت کردید، یک شناسه برنامه دریافت خواهید کرد که برنامه فرستنده شما باید از آن برای انجام تماس های API، مانند راه اندازی یک برنامه گیرنده، استفاده کند.

تصویر Cast Developer Console با دکمه «افزودن برنامه جدید» برجسته شده است

روی "افزودن برنامه جدید" کلیک کنید

تصویر صفحه «برنامه گیرنده جدید» با برجسته شدن گزینه «گیرنده سفارشی»

"دریافت کننده سفارشی" را انتخاب کنید، این همان چیزی است که ما می سازیم.

تصویر فیلد "URL برنامه گیرنده" در گفتگوی "گیرنده سفارشی جدید" در حال پر شدن

مشخصات گیرنده جدید خود را وارد کنید، حتما از URL قسمت آخر استفاده کنید. شناسه برنامه اختصاص داده شده به گیرنده جدید خود را یادداشت کنید .

همچنین باید دستگاه Google Cast خود را ثبت کنید تا قبل از انتشار به برنامه گیرنده شما دسترسی پیدا کند. هنگامی که برنامه گیرنده خود را منتشر کردید، برای همه دستگاه های Google Cast در دسترس خواهد بود. برای اهداف این نرم افزار کد، توصیه می شود با یک برنامه گیرنده منتشر نشده کار کنید.

تصویر Google Cast SDK Developer Console با دکمه «افزودن دستگاه جدید» برجسته شده است

روی "افزودن دستگاه جدید" کلیک کنید

تصویر گفتگوی «افزودن دستگاه گیرنده Cast».

شماره سریال چاپ شده در پشت دستگاه Cast خود را وارد کرده و نامی توصیفی برای آن بگذارید. هنگام دسترسی به Google Cast SDK Developer Console همچنین می‌توانید شماره سریال خود را با فرستادن صفحه نمایش خود در Chrome پیدا کنید.

5-15 دقیقه طول می کشد تا گیرنده و دستگاه شما برای آزمایش آماده شوند. پس از 5 تا 15 دقیقه انتظار، باید دستگاه Cast خود را راه اندازی مجدد کنید.

5. برنامه نمونه را اجرا کنید

لوگوی گوگل کروم

در حالی که منتظر آماده شدن Web Receiver جدید خود برای آزمایش هستیم، بیایید ببینیم یک نمونه برنامه Web Receiver کامل شده چگونه به نظر می رسد. گیرنده‌ای که می‌خواهیم بسازیم، می‌تواند رسانه‌ها را با استفاده از جریان نرخ بیت تطبیقی ​​پخش کند.

  1. در مرورگر خود، ابزار Command and Control (CaC) را باز کنید.

تصویر برگه «Cast Connect & Logger Controls» ابزار Command and Control (CaC)

  1. از شناسه گیرنده پیش فرض CC1AD845 استفاده کنید و روی دکمه SET APP ID کلیک کنید.
  2. روی دکمه Cast در بالا سمت چپ کلیک کنید و دستگاه دارای Google Cast را انتخاب کنید.

تصویر برگه «Cast Connect & Logger Controls» ابزار Command and Control (CaC) که نشان می‌دهد به یک برنامه گیرنده متصل است.

  1. به تب LOAD MEDIA در بالا بروید.

تصویر تب "Load Media" ابزار Command and Control (CaC).

  1. دکمه رادیویی نوع درخواست را به LOAD تغییر دهید.
  2. برای پخش یک ویدیوی نمونه روی دکمه SEND REQUEST کلیک کنید.
  3. این ویدیو در دستگاه دارای Google Cast شما شروع به پخش می کند تا نشان دهد که عملکرد اصلی گیرنده با استفاده از گیرنده پیش فرض چگونه به نظر می رسد.

6. پروژه شروع را آماده کنید

باید پشتیبانی از Google Cast را به برنامه شروعی که دانلود کردید اضافه کنیم. در اینجا برخی از اصطلاحات Google Cast وجود دارد که در این کد لبه استفاده خواهیم کرد:

  • یک برنامه فرستنده روی دستگاه تلفن همراه یا لپ تاپ اجرا می شود،
  • یک برنامه گیرنده در دستگاه Google Cast یا Android TV اجرا می شود.

اکنون شما آماده هستید تا با استفاده از ویرایشگر متن مورد علاقه خود، در بالای پروژه شروع بسازید:

  1. را انتخاب کنید نماد پوشه دایرکتوری app-start از دانلود کد نمونه شما.
  2. js/receiver.js و index.html را باز کنید

توجه داشته باشید، همانطور که شما از طریق این کد لبه کار می کنید، http-server باید تغییراتی را که ایجاد می کنید را انتخاب کند. اگر نشد، http-server متوقف و مجدداً راه اندازی کنید.

طراحی اپلیکیشن

برنامه گیرنده جلسه Cast را راه اندازی می کند و تا زمانی که یک درخواست LOAD (مانند فرمان پخش یک قطعه رسانه) از فرستنده برسد، در حالت آماده به کار خواهد بود.

این برنامه شامل یک نمای اصلی است که در index.html تعریف شده است و یک فایل جاوا اسکریپت به نام js/receiver.js که شامل تمام منطق برای کارکرد گیرنده ما است.

index.html

این فایل html شامل تمام رابط کاربری برنامه گیرنده ما است.

گیرنده.js

این اسکریپت تمام منطق برنامه گیرنده ما را مدیریت می کند.

سوالات متداول

7. با CastDebugLogger API یکپارچه شوید

Cast Receiver SDK گزینه دیگری را برای توسعه دهندگان فراهم می کند تا به راحتی برنامه گیرنده شما را با استفاده از CastDebugLogger API اشکال زدایی کنند.

برای جزئیات و اطلاعات بیشتر به راهنمای Cast Debug Logger مراجعه کنید.

مقداردهی اولیه

اسکریپت زیر را در تگ <head> برنامه گیرنده خود درست بعد از اسکریپت Web Receiver SDK در index.html قرار دهید:

<head>
  ...
  <script src="//www.gstatic.com/cast/sdk/libs/caf_receiver/v3/cast_receiver_framework.js"></script>
  <!-- Cast Debug Logger -->
  <script src="//www.gstatic.com/cast/sdk/libs/devtools/debug_layer/caf_receiver_logger.js"></script>
</head>

در js/receiver.js در بالای فایل و زیر playerManager ، نمونه CastDebugLogger را دریافت کنید و لاگر را در شنونده رویداد READY فعال کنید:

const context = cast.framework.CastReceiverContext.getInstance();
const playerManager = context.getPlayerManager();

// Debug Logger
const castDebugLogger = cast.debug.CastDebugLogger.getInstance();
const LOG_TAG = 'MyAPP.LOG';

// Enable debug logger and show a 'DEBUG MODE' overlay at top left corner.
context.addEventListener(cast.framework.system.EventType.READY, () => {
  if (!castDebugLogger.debugOverlayElement_) {
      castDebugLogger.setEnabled(true);
  }
});

هنگامی که ثبت اشکال زدایی فعال است، یک پوشش DEBUG MODE روی گیرنده نمایش داده می شود.

تصویر یک ویدیو در حال پخش با پیام «DEBUG MODE» که روی پس‌زمینه قرمز در گوشه سمت چپ بالای کادر ظاهر می‌شود.

رویدادهای پخش کننده را ثبت کنید

با استفاده از CastDebugLogger می‌توانید به راحتی رویدادهای پخش‌کننده را که توسط Cast Web Receiver SDK اجرا می‌شوند ثبت کنید و از سطوح مختلف ثبت‌کننده برای ثبت داده‌های رویداد استفاده کنید. پیکربندی loggerLevelByEvents cast.framework.events.EventType و cast.framework.events.category را برای مشخص کردن رویدادهایی که باید ثبت شوند را می گیرد.

موارد زیر را در زیر شنونده رویداد READY اضافه کنید تا زمانی که رویدادهای CORE پخش کننده فعال می شوند یا تغییر mediaStatus پخش می شود، ثبت نام کنید:

...

// Set verbosity level for Core events.
castDebugLogger.loggerLevelByEvents = {
  'cast.framework.events.category.CORE': cast.framework.LoggerLevel.INFO,
  'cast.framework.events.EventType.MEDIA_STATUS': cast.framework.LoggerLevel.DEBUG
};

ورود پیام ها و برچسب های سفارشی

CastDebugLogger API به شما امکان می دهد پیام های گزارشی را ایجاد کنید که روی پوشش اشکال زدایی گیرنده با رنگ های مختلف ظاهر می شوند. از روش های گزارش زیر استفاده کنید که به ترتیب از بالاترین اولویت به پایین ترین فهرست شده اند:

  • castDebugLogger.error(custom_tag, message);
  • castDebugLogger.warn(custom_tag, message);
  • castDebugLogger.info(custom_tag, message);
  • castDebugLogger.debug(custom_tag, message);

برای هر متد log، پارامتر اول باید یک تگ سفارشی باشد و پارامتر دوم پیام log است. تگ می تواند هر رشته ای باشد که به نظر شما مفید است.

برای نمایش گزارش‌ها در عمل، گزارش‌ها را به رهگیر LOAD خود اضافه کنید.

playerManager.setMessageInterceptor(cast.framework.messages.MessageType.LOAD,
      loadRequestData => {
    // Listed in order from highest to lowest priority.
    castDebugLogger.error(LOG_TAG, 'Test error log');

    castDebugLogger.warn(LOG_TAG, 'Test warn log');

    castDebugLogger.info(LOG_TAG, 'Intercepting LOAD request', loadRequestData);

    castDebugLogger.debug(LOG_TAG, 'Test debug log');

    return loadRequestData;
  }
);

با تنظیم سطح گزارش در loggerLevelByTags برای هر تگ سفارشی، می‌توانید پیام‌هایی را که در پوشش اشکال‌زدایی ظاهر می‌شوند، کنترل کنید. برای مثال، فعال کردن یک برچسب سفارشی با cast.framework.LoggerLevel.DEBUG در سطح گزارش، همه پیام‌های اضافه شده با پیام‌های خطا، هشدار، اطلاعات و اشکال‌زدایی را نمایش می‌دهد. مثال دیگر این است که فعال کردن یک برچسب سفارشی با سطح WARNING فقط پیام‌های خطا و هشدار را نمایش می‌دهد.

پیکربندی loggerLevelByTags اختیاری است. اگر یک تگ سفارشی برای سطح ثبت‌کننده آن پیکربندی نشده باشد، همه پیام‌های گزارش روی پوشش اشکال‌زدایی نمایش داده می‌شوند.

موارد زیر را در زیر تماس loggerLevelByEvents اضافه کنید:

...

// Set verbosity level for custom tags.
castDebugLogger.loggerLevelByTags = {
    LOG_TAG: cast.framework.LoggerLevel.DEBUG, // display all levels
};

...

8. استفاده از Debug Overlay

Cast Debug Logger یک پوشش اشکال‌زدایی روی گیرنده برای نمایش پیام‌های ثبت سفارشی شما فراهم می‌کند. از showDebugLogs برای تغییر همپوشانی اشکال زدایی و clearDebugLogs برای پاک کردن پیام‌های گزارش روی پوشش استفاده کنید.

موارد زیر را به شنونده رویداد READY اضافه کنید تا پیش نمایش همپوشانی اشکال زدایی روی گیرنده خود را مشاهده کنید:

// Enable debug logger and show a 'DEBUG MODE' overlay at top left corner.
context.addEventListener(cast.framework.system.EventType.READY, () => {
  if (!castDebugLogger.debugOverlayElement_) {
      castDebugLogger.setEnabled(true);

      // Show debug overlay.
      castDebugLogger.showDebugLogs(true);

      // Clear log messages on debug overlay.
      castDebugLogger.clearDebugLogs();
  }
});

تصویری که پوشش اشکال‌زدایی را نشان می‌دهد، فهرستی از پیام‌های گزارش اشکال‌زدایی در پس‌زمینه‌ای شفاف در بالای قاب ویدیو

9. استفاده از ابزار Command and Control (CaC).

نمای کلی

ابزار Command and Control (CaC) گزارش های شما را ضبط می کند و پوشش اشکال زدایی را کنترل می کند.

دو راه برای اتصال گیرنده به ابزار CaC وجود دارد:

اتصال Cast جدید را شروع کنید:

  1. ابزار CaC را باز کنید، شناسه برنامه گیرنده را تنظیم کنید و روی دکمه Cast کلیک کنید تا به گیرنده ارسال شود.
  2. یک برنامه فرستنده جداگانه را به همان دستگاه با همان شناسه برنامه گیرنده ارسال کنید.
  3. بارگیری رسانه از برنامه فرستنده و پیام‌های گزارش روی ابزار نشان داده می‌شوند.

به یک جلسه Cast موجود بپیوندید:

  1. شناسه جلسه Cast در حال اجرا را با استفاده از SDK گیرنده یا فرستنده SDK دریافت کنید. از سمت گیرنده، برای دریافت شناسه جلسه در کنسول Chrome Remote Debugger، موارد زیر را وارد کنید:
cast.framework.CastReceiverContext.getInstance().getApplicationData().sessionId;

یا می توانید شناسه جلسه را از یک فرستنده وب متصل دریافت کنید، از روش زیر استفاده کنید:

cast.framework.CastContext.getInstance().getCurrentSession().getSessionId();

تصویر برگه «Cast Connect & Logger Controls» ابزار Command and Control (CaC) برای از سرگیری جلسه

  1. شناسه جلسه را در ابزار CaC وارد کرده و روی دکمه RESUME کلیک کنید.
  2. دکمه Cast باید متصل شود و شروع به نمایش پیام های گزارش روی ابزار کند.

چیزهایی که باید امتحان کنید

در مرحله بعد، از ابزار CaC برای مشاهده گزارش‌ها در گیرنده نمونه شما استفاده می‌کنیم.

  1. ابزار CaC را باز کنید.

تصویر برگه «Cast Connect & Logger Controls» ابزار Command and Control (CaC)

  1. شناسه برنامه گیرنده برنامه نمونه خود را وارد کنید و روی دکمه SET APP ID کلیک کنید.
  2. روی دکمه Cast در بالا سمت چپ کلیک کنید و دستگاه مجهز به Google Cast خود را انتخاب کنید تا گیرنده باز شود.

تصویر برگه «Cast Connect & Logger Controls» ابزار Command and Control (CaC) که نشان می‌دهد به یک برنامه گیرنده متصل است.

  1. به تب LOAD MEDIA در بالا بروید.

تصویر تب "Load Media" ابزار Command and Control (CaC).

  1. دکمه رادیویی نوع درخواست را به LOAD تغییر دهید.
  2. برای پخش یک ویدیوی نمونه روی دکمه SEND REQUEST کلیک کنید.

تصویر برگه «Cast Connect & Logger Controls» ابزار Command and Control (CaC) با پیام‌های گزارش که قسمت پایینی را پر می‌کند.

  1. اکنون باید یک ویدیوی نمونه در دستگاه شما در حال پخش باشد. شما باید شروع به دیدن گزارش های خود از مراحل قبلی در تب "Log Messages" در پایین ابزار کنید.

سعی کنید ویژگی های زیر را برای بررسی گزارش ها و کنترل گیرنده بررسی کنید:

  • برای مشاهده اطلاعات رسانه و وضعیت رسانه، روی برگه MEDIA INFO رسانه یا MEDIA STATUS رسانه کلیک کنید.
  • روی دکمه SHOW OVERLAY کلیک کنید تا همپوشانی اشکال زدایی روی گیرنده را ببینید.
  • از دکمه CLEAR CACHE AND STOP برای بارگیری مجدد برنامه گیرنده و پخش مجدد استفاده کنید.

10. تبریک می گویم

اکنون می‌دانید چگونه با استفاده از آخرین Cast Receiver SDK، Cast Debug Logger را به برنامه گیرنده وب با قابلیت Cast اضافه کنید.

برای جزئیات بیشتر، به راهنمای برنامه‌نویس ابزار Debug Logger و Command and Control (CaC) مراجعه کنید.