Thiết lập để phát triển bằng Khung ứng dụng truyền (CAF) dành cho Android

Điều kiện tiên quyết

Google Cast SDK cho Android là một phần của Google Play Services SDK và không cần tải xuống riêng.

Lưu ý: Dịch vụ Google Play cho phép bạn truy cập vào nhiều API để tạo quảng cáo, thu thập số liệu phân tích, xác thực người dùng, tích hợp bản đồ và nhiều tính năng khác. Để biết thêm thông tin, hãy xem phần Tổng quan về Dịch vụ Google Play. Bạn cần đảm bảo rằng APK Dịch vụ Google Play chính xác đã được cài đặt trên thiết bị của người dùng vì các bản cập nhật có thể không đến được với tất cả người dùng ngay lập tức.

Thêm Dịch vụ Google Play vào dự án của bạn

Chọn môi trường phát triển của bạn bên dưới rồi thêm các dịch vụ Google Play vào dự án bằng cách làm theo các bước được cung cấp.

Android Studio

Cách cung cấp API Dịch vụ Google Play cho ứng dụng của bạn:

  1. Mở tệp build.gradle trong thư mục mô-đun ứng dụng.

    Lưu ý: Các dự án Android Studio chứa một tệp build.gradle cấp cao nhất và một tệp build.gradle cho mỗi mô-đun. Hãy nhớ chỉnh sửa tệp cho mô-đun ứng dụng của bạn. Hãy xem phần Tạo dự án bằng Gradle để biết thêm thông tin về Gradle.

  2. Xác minh rằng google() có trong repositories được liệt kê.
    repositories {
        google()
    }
  3. Thêm quy tắc bản dựng mới trong dependencies cho phiên bản mới nhất của play-services. Ví dụ:
    apply plugin: 'com.android.application'
        ...
    
        dependencies {
            implementation 'androidx.appcompat:appcompat:1.3.1'
            implementation 'androidx.mediarouter:mediarouter:1.2.5'
            implementation 'com.google.android.gms:play-services-cast-framework:22.1.0'
        }

    Hãy nhớ cập nhật số phiên bản này mỗi khi Dịch vụ Google Play được cập nhật.

    Lưu ý: Nếu số lượng tham chiếu phương thức trong ứng dụng của bạn vượt quá giới hạn 65K, thì ứng dụng của bạn có thể không biên dịch được. Bạn có thể giảm thiểu vấn đề này khi biên dịch ứng dụng bằng cách chỉ định những API Dịch vụ Google Play cụ thể mà ứng dụng của bạn sử dụng, thay vì tất cả các API. Để biết thông tin về cách thực hiện việc này, hãy xem phần Chọn lọc các API để biên dịch vào tệp thực thi.

  4. Lưu các thay đổi và nhấp vào Đồng bộ hoá dự án với tệp Gradle trên thanh công cụ.

IDE khác

Cách cung cấp API Dịch vụ Google Play cho ứng dụng của bạn:

  1. Sao chép dự án thư viện tại <android-sdk>/extras/google/google_play_services/libproject/google-play-services_lib/ vào vị trí mà bạn duy trì các dự án ứng dụng Android.
  2. Trong dự án ứng dụng, hãy tham chiếu dự án thư viện Dịch vụ Google Play. Hãy xem phần Tham chiếu một dự án thư viện trên dòng lệnh để biết thêm thông tin về cách thực hiện việc này.

    Lưu ý: Bạn nên tham chiếu đến một bản sao của thư viện mà bạn đã sao chép vào không gian làm việc phát triển của mình – bạn không nên tham chiếu trực tiếp đến thư viện từ thư mục Android SDK.

  3. Sau khi bạn thêm thư viện Dịch vụ Google Play làm phần phụ thuộc cho dự án ứng dụng, hãy mở tệp kê khai của ứng dụng rồi thêm thẻ sau đây làm thành phần con của phần tử <application>:
    <meta-data android:name="com.google.android.gms.version"
        android:value="@integer/google_play_services_version" />

Sau khi thiết lập dự án để tham chiếu dự án thư viện, bạn có thể bắt đầu phát triển các tính năng bằng API Dịch vụ Google Play.

Tạo một ngoại lệ Proguard

Để ngăn ProGuard loại bỏ các lớp bắt buộc, hãy thêm các dòng sau vào tệp /proguard-project.txt:

-keep public class com.google.android.gms.common.internal.safeparcel.SafeParcelable {
    public static final *** NULL;
}

-keepnames class * implements android.os.Parcelable
-keepclassmembers class * implements android.os.Parcelable {
  public static final *** CREATOR;
}

-keep @interface android.support.annotation.Keep
-keep @android.support.annotation.Keep class *
-keepclasseswithmembers class * {
  @android.support.annotation.Keep <fields>;
}
-keepclasseswithmembers class * {
  @android.support.annotation.Keep <methods>;
}

-keep @interface com.google.android.gms.common.annotation.KeepName
-keepnames @com.google.android.gms.common.annotation.KeepName class *
-keepclassmembernames class * {
  @com.google.android.gms.common.annotation.KeepName *;
}

-keep @interface com.google.android.gms.common.util.DynamiteApi
-keep public @com.google.android.gms.common.util.DynamiteApi class * {
  public <fields>;
  public <methods>;
}

-dontwarn android.security.NetworkSecurityPolicy