System kompilacji Androida kompiluje zasoby aplikacji i kod źródłowy, a potem pakuje je w pliki APK lub pakiety Android App Bundle, które możesz testować, wdrażać, podpisywać i rozpowszechniać.
W artykułach Omówienie kompilacji Gradle i Struktura kompilacji na Androida omawialiśmy pojęcia związane z kompilacją oraz strukturę aplikacji na Androida. Teraz nadszedł czas na skonfigurowanie kompilacji.
Glosariusz dotyczący kompilacji Androida
Gradle i wtyczka Androida do obsługi Gradle pomagają skonfigurować te aspekty kompilacji:
- Typy kompilacji
-
Typy kompilacji definiują określone właściwości, których Gradle używa podczas kompilowania i pakowania aplikacji. Typy kompilacji są zwykle konfigurowane na różne etapy cyklu życia rozwoju.
Na przykład typ kompilacji debugowania umożliwia korzystanie z opcji debugowania i podpisuje aplikację kluczem debugowania, a typ kompilacji wersji może kompresować, zaciemniać i podpisywać aplikację kluczem wersji na potrzeby dystrybucji.
Aby skompilować aplikację, musisz zdefiniować co najmniej 1 typ kompilacji. Android Studio domyślnie tworzy typy kompilacji debugowania i wersji. Aby zacząć dostosowywać ustawienia pakowania aplikacji, dowiedz się, jak skonfigurować typy kompilacji.
- Smaki produktów
- Wersje produktu to różne wersje aplikacji, które możesz udostępnić użytkownikom, np. bezpłatne i płatne. Możesz dostosowywać wersje produktu, aby używać różnych wersji kodu i zasobów podczas udostępniania oraz ponownie używać elementów wspólnych dla wszystkich wersji aplikacji. Wersje produktu są opcjonalne i musisz je utworzyć ręcznie. Aby zacząć tworzyć różne wersje aplikacji, dowiedz się, jak skonfigurować wersje produktu.
- Tworzenie wariantów
- Wariant kompilacji to połączenie typu kompilacji i wersji produktu. Jest to konfiguracja, której Gradle używa do kompilowania aplikacji. Dzięki wariantom kompilacji możesz kompilować wersję debugową wersji produktu na etapie rozwoju oraz podpisane wersje wersji produktu na potrzeby dystrybucji. Nie konfigurujesz bezpośrednio wariantów kompilacji, ale konfigurujesz typy kompilacji i wersje produktów, z których są one tworzone. Tworzenie dodatkowych typów kompilacji lub wersji produktu powoduje też utworzenie dodatkowych wariantów kompilacji. Aby dowiedzieć się, jak tworzyć wersje kompilacji i nimi zarządzać, przeczytaj artykuł Konfigurowanie wersji kompilacji.
- Wpisy w pliku manifestu
- Wartości niektórych właściwości pliku manifestu możesz określić w konfiguracji wariantu kompilacji. Te wartości kompilacji zastąpią dotychczasowe wartości w pliku manifestu. Jest to przydatne, jeśli chcesz wygenerować kilka wersji aplikacji z inną nazwą, inną minimalną wersją pakietu SDK lub inną wersją docelową pakietu SDK. Jeśli jest więcej niż jeden plik manifestu, narzędzie do łączenia plików manifestu scala ustawienia manifestu.
- Zależności
- System kompilacji zarządza zależnościami projektu z lokalnego systemu plików i z repozytoriów zdalnych. Oznacza to, że nie musisz ręcznie wyszukiwać, pobierać ani kopiować pakietów binarnych zależności do katalogu projektu. Więcej informacji znajdziesz w artykule Dodawanie zależności kompilacji.
- Podpisywanie
- System kompilacji umożliwia określenie ustawień podpisywania w konfiguracji kompilacji i automatyczne podpisywanie aplikacji podczas procesu kompilacji. System kompilacji podpisuje wersję debugową za pomocą domyślnego klucza i certyfikatu, używając znanych poświadczeń, aby uniknąć wyświetlania monitu o hasło podczas kompilacji. System kompilacji nie podpisuje wersji wydania, chyba że wyraźnie zdefiniujesz konfigurację podpisywania dla tej kompilacji. Jeśli nie masz klucza wersji, możesz go wygenerować w sposób opisany w artykule Podpisywanie aplikacji. Aby rozpowszechniać aplikacje w większości sklepów z aplikacjami, musisz używać podpisanych wersji.
- Zmniejszanie kodu i zasobów
- System kompilacji umożliwia określenie innego pliku reguł ProGuard dla każdego wariantu kompilacji. Podczas kompilowania aplikacji system kompilacji stosuje odpowiedni zbiór reguł, aby skracać kod i zasoby za pomocą wbudowanych narzędzi, takich jak R8. Skracanie kodu i zasobów może pomóc w zmniejszeniu rozmiaru pliku APK lub AAB.
- Obsługa wielu plików APK
- System kompilacji umożliwia automatyczne kompilowanie różnych plików APK, z których każdy zawiera tylko kod i zasoby potrzebne do obsługi określonej gęstości ekranu lub interfejsu binarnego aplikacji (ABI). Więcej informacji znajdziesz w artykule Tworzenie wielu plików APK. Zalecamy jednak opublikowanie pojedynczego pakietu AAB, ponieważ umożliwia ono podział nie tylko według gęstości ekranu i interfejsu ABI, ale też według języka, a zarazem pozwala uniknąć przesyłania wielu artefaktów do Google Play. Wszystkie nowe aplikacje przesłane po sierpniu 2021 r. muszą używać pakietów AAB.
Wersje Javy w kompilacji Androida
Niezależnie od tego, czy Twój kod źródłowy jest napisany w języku Java, Kotlin czy w obu tych językach, musisz wybrać wersję JDK lub Javy na potrzeby kompilacji. Więcej informacji znajdziesz w artykule Java w wersjach na Androida.
Tworzenie plików konfiguracji
Aby utworzyć niestandardowe konfiguracje kompilacji, musisz wprowadzić zmiany w co najmniej jednym pliku konfiguracji kompilacji. Te pliki w czystym tekście używają języka domenowego (DSL), aby opisywać i modyfikować logikę kompilacji za pomocą skryptu Kotlina, który jest odmianą języka Kotlin. Do konfigurowania kompilacji możesz też użyć Groovy, czyli języka dynamicznego dla maszyny wirtualnej Java (JVM).
Aby zacząć konfigurować kompilację, nie musisz znać skryptu Kotlin ani Groovy, ponieważ wtyczka Gradle dla Androida udostępnia większość potrzebnych elementów DSL. Więcej informacji o wtyczce DSL dla Androida Gradle znajdziesz w dokumentacji na temat DSL. Skrypt Kotlin korzysta też z podstawowego Gradle Kotlin DSL.
Gdy rozpoczynasz nowy projekt, Android Studio automatycznie tworzy niektóre z tych plików i wypełnia je na podstawie sensownych wartości domyślnych. Przegląd utworzonych plików znajdziesz w artykule Struktura kompilacji Androida.
Plik Gradle Wrapper
Opakowanie Gradle (gradlew
) to niewielka aplikacja dołączona do kodu źródłowego, która pobiera i uruchamia Gradle.
Dzięki temu proces kompilacji jest bardziej spójny. Deweloperzy pobierają źródło aplikacji i uruchamiają gradlew
. Spowoduje to pobranie wymaganej dystrybucji Gradle i uruchomienie Gradle w celu skompilowania aplikacji.
Plik gradle/wrapper/gradle-wrapper.properties
zawiera właściwość distributionUrl
, która określa, której wersji Gradle używasz do uruchamiania kompilacji.
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.0-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
Plik ustawień Gradle
Plik settings.gradle.kts
(w przypadku DSL w języku Kotlin) lub plik settings.gradle
(w przypadku DSL w języku Groovy) znajduje się w katalogu głównym katalogu projektu. Ten plik ustawień definiuje ustawienia repozytorium na poziomie projektu i informuje Gradle, które moduły należy uwzględnić podczas kompilowania aplikacji. Projekty wielomodułowe muszą określać każdy moduł, który powinien zostać uwzględniony w końcowej kompilacji.
W przypadku większości projektów plik domyślnie wygląda tak:
Kotlin
pluginManagement { /** * The pluginManagement.repositories block configures the * repositories Gradle uses to search or download the Gradle plugins and * their transitive dependencies. Gradle pre-configures support for remote * repositories such as JCenter, Maven Central, and Ivy. You can also use * local repositories or define your own remote repositories. Here we * define the Gradle Plugin Portal, Google's Maven repository, * and the Maven Central Repository as the repositories Gradle should use to look for its * dependencies. */ repositories { gradlePluginPortal() google() mavenCentral() } } dependencyResolutionManagement { /** * The dependencyResolutionManagement.repositories * block is where you configure the repositories and dependencies used by * all modules in your project, such as libraries that you are using to * create your application. However, you should configure module-specific * dependencies in each module-level build.gradle file. For new projects, * Android Studio includes Google's Maven repository and the Maven Central * Repository by default, but it does not configure any dependencies (unless * you select a template that requires some). */ repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { google() mavenCentral() } } rootProject.name = "My Application" include(":app")
Groovy
pluginManagement { /** * The pluginManagement.repositories block configures the * repositories Gradle uses to search or download the Gradle plugins and * their transitive dependencies. Gradle pre-configures support for remote * repositories such as JCenter, Maven Central, and Ivy. You can also use * local repositories or define your own remote repositories. Here we * define the Gradle Plugin Portal, Google's Maven repository, * and the Maven Central Repository as the repositories Gradle should use to look for its * dependencies. */ repositories { gradlePluginPortal() google() mavenCentral() } } dependencyResolutionManagement { /** * The dependencyResolutionManagement.repositories * block is where you configure the repositories and dependencies used by * all modules in your project, such as libraries that you are using to * create your application. However, you should configure module-specific * dependencies in each module-level build.gradle file. For new projects, * Android Studio includes Google's Maven repository and the Maven Central * Repository by default, but it does not configure any dependencies (unless * you select a template that requires some). */ repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { google() mavenCentral() } } rootProject.name = "My Application" include ':app'
Plik kompilacji najwyższego poziomu
Plik build.gradle.kts
(w przypadku Kotlin DSL) lub plik build.gradle
(w przypadku Groovy DSL) znajduje się w katalogu głównym katalogu projektu. Zwykle definiuje ona typowe wersje wtyczek używanych przez moduły w Twoim projekcie.
Poniższy przykładowy kod przedstawia domyślne ustawienia i elementy DSL w skrypcie kompilacji najwyższego poziomu po utworzeniu nowego projektu:
Kotlin
plugins { /** * Use `apply false` in the top-level build.gradle file to add a Gradle * plugin as a build dependency but not apply it to the current (root) * project. Don't use `apply false` in sub-projects. For more information, * see Applying external plugins with same version to subprojects. */ id("com.android.application") version "8.8.0" apply false id("com.android.library") version "8.8.0" apply false id("org.jetbrains.kotlin.android") version "2.0.20" apply false }
Groovy
plugins { /** * Use `apply false` in the top-level build.gradle file to add a Gradle * plugin as a build dependency but not apply it to the current (root) * project. Don't use `apply false` in sub-projects. For more information, * see Applying external plugins with same version to subprojects. */ id 'com.android.application' version '8.8.0' apply false id 'com.android.library' version '8.8.0' apply false id 'org.jetbrains.kotlin.android' version '2.0.20' apply false }
Plik kompilacji na poziomie modułu
Plik build.gradle.kts
(w przypadku Kotlin DSL) lub plik build.gradle
(w przypadku Groovy DSL) znajduje się w każdym katalogu project/module/
. Umożliwia skonfigurowanie ustawień kompilacji dla konkretnego modułu, w którym się znajduje. Skonfigurowanie tych ustawień kompilacji pozwala określić niestandardowe opcje pakowania, takie jak dodatkowe typy kompilacji i wersje produktu, oraz zastąpić ustawienia w pliku main/
pliku manifestu aplikacji lub skrypcie kompilacji najwyższego poziomu.
Ustawienia Android SDK
Plik kompilacji na poziomie modułu Twojej aplikacji zawiera ustawienia, które wskazują wersje pakietu Android SDK używane podczas kompilowania, wybierania zachowań platformy i określania minimalnej wersji, w której działa aplikacja.
-
compileSdk
-
compileSdk
określa, które interfejsy API Androida i Java są dostępne podczas kompilowania kodu źródłowego. Aby korzystać z najnowszych funkcji Androida, podczas kompilowania używaj najnowszego pakietu Android SDK.Niektóre interfejsy API platformy Android mogą być niedostępne na starszych poziomach interfejsu API. Możesz warunkowo zablokować korzystanie z nowych funkcji lub użyć bibliotek zgodności AndroidX, aby korzystać z nowych funkcji na niższych poziomach interfejsu API Androida.
Każdy pakiet Android SDK udostępnia podzbiór interfejsów API Javy do użycia w aplikacji. Tabela Dostępnych interfejsów API Javy, których możesz używać w kodzie źródłowym w języku Java lub Kotlin pokazuje, który poziom interfejsu API Javy jest dostępny w zależności od wersji pakietu Android SDK. Nowsze interfejsy API Javy są obsługiwane w starszych wersjach Androida dzięki desugaringowi, który musi być włączony w kompilacji.
Android Studio wyświetla ostrzeżenia, jeśli
compileSdk
jest w sprzeczności z bieżącą wersją Android Studio, AGP lub wymaganiami dotyczącymi zależności biblioteki projektu. -
minSdk
-
Wartość
minSdk
określa najstarszą wersję Androida, którą ma obsługiwać aplikacja. UstawienieminSdk
ogranicza liczbę urządzeń, na których można zainstalować Twoją aplikację.Obsługa starszych wersji Androida może wymagać większej liczby sprawdzeń warunkowych w kodzie lub większego wykorzystania bibliotek zgodności AndroidX. Należy porównać koszty utrzymania obsługi starszych wersji z procentem użytkowników, którzy nadal z nich korzystają. Aby sprawdzić aktualne wartości procentowe używania wersji, otwórz kreator nowego projektu w Android Studio.
Podczas edytowania kodu w Android Studio lub wykonywania kontroli podczas kompilacji lint ostrzeże Cię przed interfejsami API, których używasz, a których nie ma w
minSdk
. Należy je naprawić, uwzględniając nowsze funkcje w warunkach lub używającAppcompat
w celu zapewnienia zgodności wstecznej. -
targetSdk
-
targetSdk
służy do 2 celów:- Określa ono zachowanie aplikacji w czasie działania.
- Potwierdza, w której wersji Androida przeprowadzono testy.
Jeśli aplikacja działa na urządzeniu z wersją Androida nowszą niż ta wskazana w
targetSdk
, Android uruchamia ją w trybie zgodności, który działa podobnie do wersji niższej wskazanej wtargetSdk
. Na przykład, gdy w interfejsie API 23 wprowadzono model uprawnień czasu działania, nie wszystkie aplikacje były gotowe do natychmiastowego skorzystania z tego rozwiązania. Ustawienie wartościtargetSdk
na 22 pozwala na uruchamianie tych aplikacji na urządzeniach z poziomem API 23 bez konieczności używania uprawnień w czasie wykonywania oraz na korzystanie z funkcji zawartych w najnowszej wersjicompileSdk
. Zasady dystrybucji Google Play nakładają dodatkowe zasady na docelowym poziomie interfejsu API.Wartość parametru
targetSdk
musi być równa lub mniejsza od wartości parametrucompileSdk
.
Uwaga: wartości compileSdk
i targetSdk
nie muszą być takie same. Pamiętaj o tych podstawowych zasadach:
compileSdk
zapewnia dostęp do nowych interfejsów APItargetSdk
określa zachowanie aplikacji w czasie działaniatargetSdk
musi być równa lub mniejsza niżcompileSdk
Przykładowy skrypt kompilacji modułu aplikacji
Ten przykładowy skrypt kompilacji modułu aplikacji na Androida zawiera podstawowe elementy i ustawienia DSL:
Kotlin
/** * The first section in the build configuration applies the Android Gradle plugin * to this build and makes the android block available to specify * Android-specific build options. */ plugins { id("com.android.application") } /** * Locate (and possibly download) a JDK used to build your kotlin * source code. This also acts as a default for sourceCompatibility, * targetCompatibility and jvmTarget. Note that this does not affect which JDK * is used to run the Gradle build itself, and does not need to take into * account the JDK version required by Gradle plugins (such as the * Android Gradle Plugin) */ kotlin { jvmToolchain(11) } /** * The android block is where you configure all your Android-specific * build options. */ android { /** * The app's namespace. Used primarily to access app resources. */ namespace = "com.example.myapp" /** * compileSdk specifies the Android API level Gradle should use to * compile your app. This means your app can use the API features included in * this API level and lower. */ compileSdk = 33 /** * The defaultConfig block encapsulates default settings and entries for all * build variants and can override some attributes in main/AndroidManifest.xml * dynamically from the build system. You can configure product flavors to override * these values for different versions of your app. */ defaultConfig { // Uniquely identifies the package for publishing. applicationId = "com.example.myapp" // Defines the minimum API level required to run the app. minSdk = 21 // Specifies the API level used to test the app. targetSdk = 33 // Defines the version number of your app. versionCode = 1 // Defines a user-friendly version name for your app. versionName = "1.0" } /** * The buildTypes block is where you can configure multiple build types. * By default, the build system defines two build types: debug and release. The * debug build type is not explicitly shown in the default build configuration, * but it includes debugging tools and is signed with the debug key. The release * build type applies ProGuard settings and is not signed by default. */ buildTypes { /** * By default, Android Studio configures the release build type to enable code * shrinking, using minifyEnabled, and specifies the default ProGuard rules file. */ getByName("release") { isMinifyEnabled = true // Enables code shrinking for the release build type. proguardFiles( getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro" ) } } /** * The productFlavors block is where you can configure multiple product flavors. * This lets you create different versions of your app that can * override the defaultConfig block with their own settings. Product flavors * are optional, and the build system does not create them by default. * * This example creates a free and paid product flavor. Each product flavor * then specifies its own application ID, so that they can exist on the Google * Play Store or an Android device simultaneously. * * If you declare product flavors, you must also declare flavor dimensions * and assign each flavor to a flavor dimension. */ flavorDimensions += "tier" productFlavors { create("free") { dimension = "tier" applicationId = "com.example.myapp.free" } create("paid") { dimension = "tier" applicationId = "com.example.myapp.paid" } } /** * To override source and target compatibility (if different from the * toolchain JDK version), add the following. All of these * default to the same value as kotlin.jvmToolchain. If you're using the * same version for these values and kotlin.jvmToolchain, you can * remove these blocks. */ //compileOptions { // sourceCompatibility = JavaVersion.VERSION_11 // targetCompatibility = JavaVersion.VERSION_11 //} //kotlinOptions { // jvmTarget = "11" //} } /** * The dependencies block in the module-level build configuration file * specifies dependencies required to build only the module itself. * To learn more, go to Add build dependencies. */ dependencies { implementation(project(":lib")) implementation("androidx.appcompat:appcompat:1.7.0") implementation(fileTree(mapOf("dir" to "libs", "include" to listOf("*.jar")))) }
Groovy
/** * The first line in the build configuration applies the Android Gradle plugin * to this build and makes the android block available to specify * Android-specific build options. */ plugins { id 'com.android.application' } /** * Locate (and possibly download) a JDK used to build your kotlin * source code. This also acts as a default for sourceCompatibility, * targetCompatibility and jvmTarget. Note that this does not affect which JDK * is used to run the Gradle build itself, and does not need to take into * account the JDK version required by Gradle plugins (such as the * Android Gradle Plugin) */ kotlin { jvmToolchain 11 } /** * The android block is where you configure all your Android-specific * build options. */ android { /** * The app's namespace. Used primarily to access app resources. */ namespace 'com.example.myapp' /** * compileSdk specifies the Android API level Gradle should use to * compile your app. This means your app can use the API features included in * this API level and lower. */ compileSdk 33 /** * The defaultConfig block encapsulates default settings and entries for all * build variants and can override some attributes in main/AndroidManifest.xml * dynamically from the build system. You can configure product flavors to override * these values for different versions of your app. */ defaultConfig { // Uniquely identifies the package for publishing. applicationId 'com.example.myapp' // Defines the minimum API level required to run the app. minSdk 21 // Specifies the API level used to test the app. targetSdk 33 // Defines the version number of your app. versionCode 1 // Defines a user-friendly version name for your app. versionName "1.0" } /** * The buildTypes block is where you can configure multiple build types. * By default, the build system defines two build types: debug and release. The * debug build type is not explicitly shown in the default build configuration, * but it includes debugging tools and is signed with the debug key. The release * build type applies ProGuard settings and is not signed by default. */ buildTypes { /** * By default, Android Studio configures the release build type to enable code * shrinking, using minifyEnabled, and specifies the default ProGuard rules file. */ release { minifyEnabled true // Enables code shrinking for the release build type. proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } /** * The productFlavors block is where you can configure multiple product flavors. * This lets you create different versions of your app that can * override the defaultConfig block with their own settings. Product flavors * are optional, and the build system does not create them by default. * * This example creates a free and paid product flavor. Each product flavor * then specifies its own application ID, so that they can exist on the Google * Play Store or an Android device simultaneously. * * If you declare product flavors, you must also declare flavor dimensions * and assign each flavor to a flavor dimension. */ flavorDimensions "tier" productFlavors { free { dimension "tier" applicationId 'com.example.myapp.free' } paid { dimension "tier" applicationId 'com.example.myapp.paid' } } /** * To override source and target compatibility (if different from the * tool chain JDK version), add the following. All of these * default to the same value as kotlin.jvmToolchain. If you're using the * same version for these values and kotlin.jvmToolchain, you can * remove these blocks. */ //compileOptions { // sourceCompatibility JavaVersion.VERSION_11 // targetCompatibility JavaVersion.VERSION_11 //} //kotlinOptions { // jvmTarget = '11' //} } /** * The dependencies block in the module-level build configuration file * specifies dependencies required to build only the module itself. * To learn more, go to Add build dependencies. */ dependencies { implementation project(":lib") implementation 'androidx.appcompat:appcompat:1.7.0' implementation fileTree(dir: 'libs', include: ['*.jar']) }
Pliki właściwości Gradle
Gradle zawiera też 2 pliki właściwości znajdujące się w katalogu głównym projektu, których możesz używać do określania ustawień samego pakietu narzędzi kompilacji Gradle:
-
gradle.properties
- Tutaj możesz skonfigurować ustawienia Gradle na poziomie projektu, takie jak maksymalny rozmiar stosu demona Gradle. Więcej informacji znajdziesz w artykule Środowisko kompilacji.
-
local.properties
-
Skonfiguruj właściwości środowiska lokalnego dla systemu kompilacji, w tym:
ndk.dir
– ścieżka do NDK. Ta usługa została wycofana. Wszystkie pobrane wersje NDK są instalowane w katalogundk
w katalogu pakietu Android SDK.sdk.dir
– ścieżka do pakietu Android SDK.cmake.dir
– ścieżka do CMake.ndk.symlinkdir
– w Android Studio 3.5 i nowszych wersjach tworzy symboliczny link do NDK, który może być krótszy niż ścieżka do zainstalowanego NDK.
Przypisz NDK do krótszej ścieżki (tylko w systemie Windows)
W systemie Windows narzędzia w zainstalowanym folderze NDK, takie jak ld.exe
, mają długie ścieżki. Narzędzia nie obsługują dobrze długich ścieżek.
Aby utworzyć krótszą ścieżkę, w pliku local.properties
ustaw właściwość ndk.symlinkdir
, aby poprosić wtyczkę Android Gradle o utworzenie symbolicznego linku do NDK. Ścieżka do tego linku symbolicznego może być krótsza niż istniejący folder NDK.
Na przykład ndk.symlinkdir = C:\
powoduje utworzenie tego symbolicznego linku:C:\ndk\19.0.5232133
Synchronizacja projektu z plikami Gradle
Gdy wprowadzasz zmiany w plikach konfiguracji kompilacji w projekcie, Android Studio wymaga zsynchronizowania plików projektu, aby móc zaimportować zmiany w konfiguracji kompilacji i przeprowadzić kilka kontroli, które mają na celu sprawdzenie, czy konfiguracja nie powoduje błędów kompilacji.
Aby zsynchronizować pliki projektu, kliknij Synchronizuj teraz na pasku powiadomień, który pojawi się po wprowadzeniu zmiany (patrz rysunek 2), lub kliknij Synchronizuj projekt na pasku menu. Jeśli Android Studio wykryje błędy w konfiguracji (np. kod źródłowy używa funkcji interfejsu API, które są dostępne tylko na poziomie interfejsu API wyższego niż compileSdkVersion
), w oknie Wiadomości pojawi się opis problemu.
Zestawy źródeł
Android Studio logicznie grupowanie kodu źródłowego i zasobów dla poszczególnych modułów w zestawy źródeł. Gdy utworzysz nowy moduł, Android Studio utworzy w nim main/
zestaw źródeł. Zestaw źródeł main/
modułu zawiera kod i zasoby używane przez wszystkie jego warianty kompilacji.
Dodatkowe katalogi zbiorów źródeł są opcjonalne, a Android Studio nie tworzy ich automatycznie podczas konfigurowania nowych wariantów kompilacji. Jednak tworzenie zbiorów źródeł, podobnie jak w przypadku main/
, ułatwia porządkowanie plików i zasobów, których Gradle powinien używać tylko podczas kompilowania określonych wersji aplikacji:
-
src/main/
- Ten zestaw źródeł zawiera kod i zasoby wspólne dla wszystkich wariantów kompilacji.
-
src/buildType/
- Utwórz ten zestaw źródeł, aby uwzględnić kod i zasoby tylko dla określonego typu kompilacji.
-
src/productFlavor/
-
Utwórz ten zestaw źródeł, aby uwzględnić kod i zasoby tylko dla konkretnej wersji produktu.
Uwaga: jeśli skompilujesz wersję, która łączy kilka wersji produktu, możesz utworzyć katalogi zestawów źródeł dla każdej kombinacji wersji produktu między wymiarami wersji:
src/productFlavor1ProductFlavor2/
. -
src/productFlavorBuildType/
- Utwórz ten zestaw źródeł, aby uwzględnić kod i zasoby tylko dla konkretnej wersji.
Na przykład aby wygenerować wersję „fullDebug” aplikacji, system kompilacji scala kod, ustawienia i zasoby z tych zbiorów źródłowych:
-
src/fullDebug/
(zbiór źródeł wariantu kompilacji) -
src/debug/
(zbiór źródeł typu kompilacji) -
src/full/
(zestaw źródeł smaku produktu) -
src/main/
(główny zbiór źródeł)
Uwaga: podczas tworzenia nowego pliku lub katalogu w Android Studio użyj opcji menu Plik > Nowy, aby utworzyć go dla konkretnego zestawu źródeł. Dostępne zestawy źródeł zależą od konfiguracji kompilacji, a Android Studio automatycznie tworzy wymagane katalogi, jeśli jeszcze nie istnieją.
Jeśli różne zestawy źródłowe zawierają różne wersje tego samego pliku, Gradle używa tej kolejności priorytetów, aby zdecydować, którego pliku użyć. Pliki i ustawienia zbiorów źródeł po lewej stronie zastępują pliki i ustawienia zbiorów źródeł po prawej stronie:
wariant kompilacji > typ kompilacji > wersja produktu > główny zestaw źródeł > zależności biblioteki
Dzięki temu Gradle może używać plików, które są specyficzne dla wariantu kompilacji, który próbujesz skompilować, jednocześnie wykorzystując ponownie aktywności, logikę aplikacji i zasoby, które są wspólne dla innych wersji aplikacji.
Podczas łączenia wielu plików manifestu Gradle używa tego samego porządku priorytetów, aby każda wersja kompilacji mogła definiować różne komponenty lub uprawnienia w pliku manifestu końcowego. Więcej informacji o tworzeniu niestandardowych zestawów źródeł znajdziesz w artykule [GA4] Tworzenie zestawów źródeł.
Katalogi wersji
Jeśli kompilacja zawiera wiele modułów z współnymi zależnościami lub masz wiele niezależnych projektów z współnymi zależnościami, zalecamy użycie katalogu wersji lub specyfikacji materiałów (BOM), aby określić wspólne wersje.
Inne systemy kompilacji
Tworzenie aplikacji na Androida za pomocą Bazel jest możliwe, ale nie jest oficjalnie obsługiwane. Android Studio nie obsługuje oficjalnie projektów Bazel.
Aby dowiedzieć się więcej o obecnych ograniczeniach tworzenia aplikacji za pomocą Bazel, zapoznaj się z znanymi problemami.