Quyền và khám phá trên iOS

Kể từ iOS 14, hệ điều hành sẽ thực thi các hạn chế và quyền mới ảnh hưởng đến trải nghiệm người dùng Cast. Điều này cũng sẽ ảnh hưởng đến cách bạn tạo Cast SDK trong ứng dụng của mình. Để ứng dụng duy trì chức năng truyền nội dung bằng các phiên bản iOS mới nhất, bạn phải cập nhật để xử lý những thay đổi về quyền này.

iOS 14

Nhà phát triển nên cập nhật ứng dụng người gửi Cast trên iOS lên Google Cast SDK phiên bản 4.6.0 trở lên. Các phiên bản này hỗ trợ iOS 14 và các yêu cầu của phiên bản này.

Kể từ iOS 14, những ứng dụng quét tìm thiết bị trên mạng cục bộ sẽ nhắc người dùng bằng một hộp thoại cấp quyền một lần để tìm và kết nối với các thiết bị trên mạng cục bộ. Nền tảng Cast sử dụng mạng cục bộ để tìm và điều khiển các thiết bị Cast. Vì vậy, nếu người dùng từ chối cấp quyền, họ sẽ không thể truyền nội dung.

Để cải thiện trải nghiệm người dùng, chúng tôi sẽ sửa đổi một số điểm trong trải nghiệm người dùng của SDK cho những ứng dụng đang sử dụng bộ chọn thiết bị tiêu chuẩn. Những điểm sửa đổi này về trải nghiệm người dùng giúp người dùng hiểu rõ hơn lý do cần có quyền truy cập vào mạng cục bộ, cũng như cách bật tính năng truyền nếu quyền truy cập vào thiết bị trên mạng cục bộ đã bị tắt.

Các ứng dụng được tạo bằng các phiên bản Cast SDK sử dụng phiên bản 4.4.8 trở về trước sẽ tiếp tục hoạt động miễn là được tạo bằng Xcode 11.7 trở về trước. Nếu đang tạo cho iOS 14 bằng Xcode 12 trở lên, bạn nên cập nhật lên Cast SDK phiên bản 4.6.0 trở lên để đảm bảo ứng dụng Cast của bạn sẽ tiếp tục hoạt động đúng cách.

Bạn có thể tải Cast iOS SDK phiên bản 4.6.0 trở lên bằng CocoaPods bằng cách làm theo chế độ thiết lập CocoaPods hoặc theo cách thủ công bằng cách làm theo chế độ thiết lập thủ công. Bản phát hành này bao gồm các thay đổi đối với cơ chế khám phá cơ bản để cho phép các ứng dụng được tạo bằng Xcode 12 tìm thấy các thiết bị Cast trên mạng. Giờ đây, nút Truyền sẽ luôn hiển thị. Nếu không có thiết bị nào khi người dùng nhấn vào nút Truyền, một hộp thoại sẽ xuất hiện để hướng dẫn lý do có thể không có thiết bị, bao gồm cả thông tin về cách bật lại quyền truy cập vào mạng cục bộ.

Các thay đổi trong Cast SDK

Truyền lần đầu

Lần đầu tiên người dùng cố gắng truyền, hộp thoại xen kẽ về quyền truy cập mạng cục bộ (LNA) sẽ xuất hiện để giải thích lý do cần có quyền truy cập mạng cục bộ, sau đó là lời nhắc về quyền truy cập mạng cục bộ trên iOS do Apple cung cấp. Các bản mô phỏng bên dưới minh hoạ quy trình:

Quy trình cấp quyền truy cập mạng cục bộ

Không dùng được tính năng truyền

Kể từ iOS Sender SDK 4.6.0, nút Truyền luôn xuất hiện khi người dùng kết nối với Wi-Fi. Khi thiết bị truyền không hoạt động, việc nhấn vào nút Truyền sẽ mở ra một hộp thoại gợi ý cho người dùng về những lý do có thể khiến tính năng Truyền không hoạt động, như minh hoạ trong các bản mô phỏng bên dưới:

Không dùng được Flow có tính năng truyền

Cập nhật ứng dụng trên iOS 14

  1. Thêm Cast iOS SDK 4.8.3 vào dự án của bạn

    Nếu bạn sử dụng CocoaPods, hãy dùng pod update để thêm SDK 4.8.3 vào dự án của bạn.

    Nếu không, hãy kéo SDK theo cách thủ công.

  2. Thêm NSBonjourServices vào Info.plist của bạn

    Chỉ định NSBonjourServices trong Info.plist để cho phép chế độ tìm mạng cục bộ hoạt động trên iOS 14.

    Bạn sẽ cần thêm cả _googlecast._tcp_<your-app-id>._googlecast._tcp làm dịch vụ để tính năng khám phá thiết bị hoạt động đúng cách.

    appID là receiverID của bạn, đây là mã nhận dạng giống với mã nhận dạng được xác định trong GCKDiscoveryCriteria.

    Cập nhật định nghĩa NSBonjourServices trong ví dụ sau và thay thế "ABCD1234" bằng appID của bạn.

    <key>NSBonjourServices</key>
    <array>
      <string>_googlecast._tcp</string>
      <string>_ABCD1234._googlecast._tcp</string>
    </array>
  3. Thêm NSLocalNetworkUsageDescription vào Info.plist của bạn

    Bạn nên tuỳ chỉnh thông báo xuất hiện trong lời nhắc Mạng cục bộ bằng cách thêm một chuỗi quyền dành riêng cho ứng dụng vào tệp Info.plist của ứng dụng cho NSLocalNetworkUsageDescription, chẳng hạn như để mô tả tính năng phát hiện Cast và các dịch vụ phát hiện khác, chẳng hạn như DIAL.

    <key>NSLocalNetworkUsageDescription</key>
    <string>${PRODUCT_NAME} uses the local network to discover Cast-enabled devices on your WiFi
    network.</string>

    Thông báo này sẽ xuất hiện trong hộp thoại Quyền truy cập mạng cục bộ của iOS như minh hoạ trong bản mô phỏng.

    Hình ảnh hộp thoại về quyền truy cập mạng cục bộ khi truyền
  4. Phát hành lại ứng dụng của bạn lên Apple App Store

    Bạn cũng nên phát hành lại ứng dụng của mình bằng phiên bản 4.8.3 càng sớm càng tốt.

Tùy chỉnh

Bắt đầu khám phá thiết bị truyền

Theo mặc định, quá trình khám phá thiết bị truyền sẽ bắt đầu vào lần đầu tiên người dùng nhấn vào nút Truyền (GCKUICastButton). Nếu đây là lần đầu tiên người dùng cố gắng sử dụng ứng dụng Truyền trên mạng cục bộ sau khi nâng cấp lên iOS 14, thì màn hình xen kẽ LNA mới sẽ xuất hiện, sau đó là hộp thoại cấp quyền truy cập mạng cục bộ trên iOS.

Một cờ mới có sẵn để cho phép bạn kiểm soát thời điểm bắt đầu phát hiện thiết bị và hành vi của một số phần tử nhất định trong trải nghiệm người dùng:

startDiscoveryAfterFirstTapOnCastButton: BOOL(true/false)

Giá trị mặc định là true. Cờ này chỉ áp dụng khi bạn đặt cờ GCKCastOptions::disableDiscoveryAutostart thành false.

Nếu được đặt thành true, chế độ khám phá thiết bị truyền sẽ bắt đầu khi người dùng nhấn vào GCKUICastButton lần đầu tiên. Một thông báo cung cấp thông tin sẽ xuất hiện cho người dùng biết lý do cần có quyền truy cập vào mạng cục bộ. Sau thông báo đó, thông báo LNA trên iOS 14 sẽ xuất hiện. Chế độ khám phá thiết bị truyền sẽ bắt đầu sau khi bạn xác nhận thông báo.

Trong những lần khởi chạy Ứng dụng tiếp theo, GCKUICastButton sẽ luôn hiển thị.

Nếu bạn đặt thành false, quá trình phát hiện thiết bị sẽ bắt đầu dựa trên giá trị của cờ GCKCastOptions::disableDiscoveryAutostart.

Câu hỏi thường gặp

Điều gì sẽ xảy ra nếu tôi phát hành lại ứng dụng người gửi Cast bằng Cast SDK phiên bản 4.4.8 và Xcode 12?

Ứng dụng của bạn có thể không tìm thấy các thiết bị Truyền trên mạng cục bộ, trừ phi bạn đã nhận được quyền truyền tin đa hướng trên mạng từ Apple. Xin lưu ý rằng Apple sẽ không cấp quyền truyền tin đa hướng chỉ nhằm mục đích hỗ trợ Cast. Nếu dự định tạo bằng Xcode 12, bạn nên phát hành ứng dụng bằng Cast 4.6.0.

Nếu tôi phát hành lại ứng dụng của mình bằng Cast SDK mới, thì người dùng đang chạy trên iOS 13 trở xuống sẽ gặp phải vấn đề gì?

Họ sẽ tiếp tục thấy trải nghiệm người dùng như trước khi bạn phát hành lại ứng dụng. Những thay đổi mà người dùng nhìn thấy chỉ giới hạn ở những người dùng chạy trên iOS 14.

Tôi cần làm gì để cập nhật ứng dụng của mình sau khi phiên bản Cast SDK mới được phát hành?

  • Cập nhật Info.plist của ứng dụng để thêm nội dung mô tả về việc sử dụng mạng cục bộ.
  • Thêm NSBonjourServices vào Info.plist của ứng dụng và cung cấp tên dịch vụ Bonjour cho Cast và mã ứng dụng của bạn.
  • Nâng cấp ứng dụng người gửi để sử dụng Cast SDK 4.6.0.
  • Phát hành lại ứng dụng của bạn lên cửa hàng ứng dụng của Apple.

Tại sao các thiết bị ngừng xuất hiện trong bộ chọn thiết bị tuỳ chỉnh sau khi tôi nâng cấp lên phiên bản 4.6.0?

Đây là một vấn đề đã biết và có thể xảy ra nếu bạn đang sử dụng bộ chọn thiết bị tuỳ chỉnh thay vì bộ chọn thiết bị tiêu chuẩn. Trong phiên bản 4.4.8 của Cast SDK trở về trước, quá trình quét thiết bị diễn ra tự động. Kể từ phiên bản 4.6.0, bạn sẽ cần gọi rõ ràng phương thức startDiscovery trên lớp GCKDiscoveryManager để bắt đầu quy trình phát hiện thiết bị.

Lý do cho thay đổi này là vì lời nhắc về quyền truy cập vào mạng cục bộ (LNA) sẽ xuất hiện sau khi ứng dụng quét lần đầu tiên. Điều này có thể dẫn đến việc hộp thoại quyền xuất hiện ở những vị trí ngẫu nhiên trong ứng dụng của bạn.

Những nhà phát triển tạo một bộ chọn thiết bị tuỳ chỉnh cho ứng dụng của họ sẽ phải cung cấp một quảng cáo xen kẽ một lần trước khi bắt đầu quét thiết bị lần đầu tiên trong iOS 14.

iOS 13

Với iOS 13, các yêu cầu mới về quyền đã được giới thiệu, ảnh hưởng đến những ứng dụng sử dụng Google Cast SDK.

Kể từ Google Cast SDK phiên bản 4.4.3, bạn có thể sử dụng một SDK khác không yêu cầu quyền Bluetooth®. Tính năng này có trên cả trang web dành cho nhà phát triển và Cocoapods google-cast-sdk-no-bluetooth mới.

Phân tích ứng dụng

Sau đây là thông tin chi tiết tuỳ thuộc vào phiên bản SDK iOS mà bạn hiện đang sử dụng:

Ứng dụng được tạo bằng SDK iOS 12 trở xuống

  • Hành động được đề xuất. Hiệu suất phát hiện thiết bị có thể giảm khi chạy trên iOS 13, nhưng vẫn hoạt động. Nhà phát triển nên nâng cấp lên Cast SDK phiên bản 4.4.4 (nếu có).
  • iOS 13 sẽ nhắc người dùng cấp quyền Bluetooth® cho ứng dụng.

Ứng dụng được xây dựng bằng iOS 13 SDK

  • Việc cần làm: Cập nhật lên Cast SDK 4.4.4 nếu không nút truyền có thể không xuất hiện nếu người dùng không cấp quyền truy cập vị trí. Bạn cần nâng cấp lên Cast SDK 4.4.4 để đảm bảo trải nghiệm truyền ổn định trên iOS 13.