Настройка для разработки с помощью Cast Application Framework (CAF) для Android

Предпосылки

Google Cast SDK для Android является частью SDK сервисов Google Play, и его не нужно загружать отдельно.

Примечание . Сервисы Google Play предоставляют вам доступ к ряду API для создания рекламы, сбора аналитики, аутентификации пользователей, интеграции карт и многого другого. Дополнительные сведения см. в разделе Обзор сервисов Google Play . Для вас важно убедиться, что на устройстве пользователя установлен правильный APK сервисов Google Play , поскольку обновления могут быть доступны не всем пользователям сразу.

Добавьте сервисы Google Play в свой проект

Выберите свою среду разработки ниже и добавьте сервисы Google Play в свой проект, следуя инструкциям.

Android-студия

Чтобы сделать API-интерфейсы сервисов Google Play доступными для вашего приложения:

  1. Откройте файл build.gradle в каталоге вашего модуля приложения.

    Примечание. Проекты Android Studio содержат файл build.gradle build.gradle каждого модуля. Обязательно отредактируйте файл для вашего модуля приложения. Дополнительные сведения о Gradle см. в разделе Создание проекта с помощью Gradle.

  2. Убедитесь, что google() включен в список repositories .
    repositories {
        google()
    }
    
  3. Добавьте новое правило сборки в dependencies от последней версии play-services . Например:
    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:21.2.0'
        }
    

    Обязательно обновляйте этот номер версии каждый раз при обновлении сервисов Google Play.

    Примечание. Если количество ссылок на методы в вашем приложении превышает ограничение в 65 КБ, ваше приложение может не скомпилироваться. Вы можете смягчить эту проблему при компиляции своего приложения, указав только определенные API сервисов Google Play, которые использует ваше приложение, а не все. Информацию о том, как это сделать, см. в разделе Выборочная компиляция API в ваш исполняемый файл .

  4. Сохраните изменения и нажмите «Синхронизировать проект с файлами Gradle» на панели инструментов.

Другая среда разработки

Чтобы сделать API-интерфейсы сервисов Google Play доступными для вашего приложения:

  1. Скопируйте проект библиотеки из <android-sdk>/extras/google/google_play_services/libproject/google-play-services_lib/ в папку, где вы храните проекты приложений для Android.
  2. В проекте приложения укажите ссылку на проект библиотеки сервисов Google Play. Дополнительные сведения о том, как это сделать, см. в разделе Ссылка на библиотечный проект в командной строке .

    Примечание. Вы должны ссылаться на копию библиотеки, которую вы скопировали в рабочую область разработки — вы не должны ссылаться на библиотеку непосредственно из каталога Android SDK.

  3. После добавления библиотеки сервисов Google Play в качестве зависимости для проекта приложения откройте файл манифеста приложения и добавьте следующий тег в качестве дочернего элемента элемента <application> :
    <meta-data android:name="com.google.android.gms.version"
        android:value="@integer/google_play_services_version" />
    
    .

После того как вы настроили свой проект для ссылки на проект библиотеки, вы можете приступить к разработке функций с помощью API сервисов Google Play .

Создайте исключение Proguard

Чтобы ProGuard не удалял необходимые классы, добавьте следующие строки в Файл /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