Derlemenizi yapılandırma

Android derleme sistemi, uygulama kaynaklarını ve kaynak kodunu derleyip test edebileceğiniz, dağıtabileceğiniz, imzalayabileceğiniz ve dağıtabileceğiniz APK'lar veya Android App Bundle'lar halinde paketler.

Gradle derlemesine genel bakış ve Android derleme yapısı başlıklı makalelerde derleme kavramlarını ve Android uygulamasının yapısını ele aldık. Şimdi derlemeyi yapılandırma zamanı.

Android derleme sözlüğü

Gradle ve Android Gradle eklentisi, derlemenizin aşağıdaki özelliklerini yapılandırmanıza yardımcı olur:

Derleme türleri

Derleme türleri, Gradle'ın uygulamanızı derleyip paketlerken kullandığı belirli özellikleri tanımlar. Derleme türleri genellikle geliştirme yaşam döngünüzün farklı aşamaları için yapılandırılır.

Örneğin, hata ayıklama derleme türü hata ayıklama seçeneklerini etkinleştirir ve uygulamayı hata ayıklama anahtarıyla imzalar. Yayın derleme türü ise dağıtım için uygulamanızı küçültebilir, karartabilir ve bir sürüm anahtarıyla imzalayabilir.

Uygulamanızı derlemek için en az bir derleme türü tanımlamanız gerekir. Android Studio, hata ayıklama ve sürüm derleme türlerini varsayılan olarak oluşturur. Uygulamanızın paketleme ayarlarını özelleştirmeye başlamak için derleme türlerini nasıl yapılandıracağınızı öğrenin.

Ürün varyantları
Ürün varyantları, uygulamanızın kullanıcılara sunabileceğiniz farklı sürümlerini (ör. ücretsiz ve ücretli sürümler) temsil eder. Ürün varyantlarını, uygulamanızın tüm sürümlerinde ortak olan bölümleri paylaşırken ve yeniden kullanırken farklı kod ve kaynaklar kullanacak şekilde özelleştirebilirsiniz. Ürün varyantları isteğe bağlıdır ve bunları manuel olarak oluşturmanız gerekir. Uygulamanızın farklı sürümlerini oluşturmaya başlamak için ürün aromalarını nasıl yapılandıracağınızı öğrenin.
Varyant oluşturma
Derleme varyantı, derleme türü ile ürün çeşidinin kesişimidir ve Gradle'ın uygulamanızı derlemek için kullandığı yapılandırmadır. Derleme varyantlarını kullanarak, geliştirme sırasında ürün çeşidinizi hata ayıklama sürümünü ve dağıtım için ürün çeşidinizi imzalanan sürümlerini derleyebilirsiniz. Derleme varyantlarını doğrudan yapılandırmasanız da bunları oluşturan derleme türlerini ve ürün varyantlarını yapılandırırsınız. Ek derleme türleri veya ürün varyantları oluşturmak da ek derleme varyantları oluşturur. Derleme varyantlarını nasıl oluşturacağınızı ve yöneteceğinizi öğrenmek için Derleme varyantlarını yapılandırma başlıklı genel bakış makalesini inceleyin.
Manifest girişleri
Derleme varyantı yapılandırmasında manifest dosyasının bazı özelliklerinin değerlerini belirtebilirsiniz. Bu derleme değerleri, manifest dosyasında mevcut değerleri geçersiz kılar. Bu, uygulamanızın farklı bir uygulama adıyla, minimum SDK sürümüyle veya hedef SDK sürümüyle birden fazla varyantını oluşturmak istiyorsanız kullanışlıdır. Birden fazla manifest olduğunda manifest birleştirme aracı manifest ayarlarını birleştirir.
Bağımlılar
Derleme sistemi, yerel dosya sisteminizden ve uzak depolardan proje bağımlılıkları yönetir. Yani bağımlılıklarınızın ikili paketlerini manuel olarak aramanız, indirmeniz ve proje dizininize kopyalamanız gerekmez. Daha fazla bilgi için Derleme bağımlılıklarını ekleme başlıklı makaleyi inceleyin.
İmza
Derleme sistemi, derleme yapılandırmasında imzalama ayarlarını belirtmenize olanak tanır ve derleme işlemi sırasında uygulamanızı otomatik olarak imzalayabilir. Derleme sistemi, derleme sırasında şifre istemi gösterilmesini önlemek için bilinen kimlik bilgilerini kullanarak hata ayıklama sürümünü varsayılan bir anahtar ve sertifikayla imzalar. Bu derleme için açıkça bir imzalama yapılandırması tanımlamadığınız sürece derleme sistemi sürümünü imzalamaz. Sürüm anahtarınız yoksa Uygulamanızı imzalama bölümünde açıklandığı şekilde bir anahtar oluşturabilirsiniz. Uygulamaların çoğu uygulama mağazasında dağıtılması için imzalanmış sürüm derlemeleri gerekir.
Kod ve kaynak küçültme
Derleme sistemi, her derleme varyantı için farklı bir ProGuard kural dosyası belirtmenize olanak tanır. Derleme sistemi, uygulamanızı derlerken R8 gibi yerleşik sıkıştırma araçlarını kullanarak kodunuzu ve kaynaklarınızı sıkıştırmak için uygun kural grubunu uygular. Kodunuzu ve kaynaklarınızı küçültmek, APK veya AAB boyutunuzu küçültmenize yardımcı olabilir.
Birden fazla APK desteği
Derleme sistemi, her biri yalnızca belirli bir ekran yoğunluğu veya Uygulama İkili Arayüzü (ABI) için gereken kod ve kaynakları içeren farklı APK'ları otomatik olarak oluşturmanıza olanak tanır. Daha fazla bilgi için Birden fazla APK oluşturma başlıklı makaleyi inceleyin. Ancak tek bir AAB yayınlamak, ekran yoğunluğu ve ABI'ye ek olarak dile göre bölme olanağı sunarken Google Play'e birden fazla yapı yükleme ihtiyacını ortadan kaldırdığı için önerilen yaklaşımdır. Ağustos 2021'den sonra gönderilen tüm yeni uygulamaların AAB kullanması gerekir.

Android derlemelerindeki Java sürümleri

Kaynak kodunuz Java, Kotlin veya her ikisi ile yazılmış olsun, derleme işleminiz için bir JDK veya Java dil sürümü seçmeniz gereken birkaç yer vardır. Ayrıntılar için Android derlemelerindeki Java sürümleri başlıklı makaleyi inceleyin.

Derleme yapılandırma dosyaları

Özel derleme yapılandırmaları oluşturmak için bir veya daha fazla derleme yapılandırma dosyasında değişiklik yapmanız gerekir. Bu düz metin dosyaları, Kotlin dilinin bir çeşidi olan Kotlin komut dosyasını kullanarak derleme mantığını tanımlamak ve değiştirmek için alana özgü bir dil (DSL) kullanır. Derlemelerinizi yapılandırmak için Java Sanal Makinesi (JVM) için dinamik bir dil olan Groovy'yi de kullanabilirsiniz.

Android Gradle eklentisi, ihtiyacınız olan DSL öğelerinin çoğunu kullanıma sunduğundan derlemenizi yapılandırmaya başlamak için Kotlin komut dosyası veya Groovy bilmenize gerek yoktur. Android Gradle eklentisi DSL'si hakkında daha fazla bilgi edinmek için DSL referans belgelerini inceleyin. Kotlin komut dosyası, temel Gradle Kotlin DSL'yi de kullanır.

Android Studio, yeni bir proje başlattığınızda bu dosyaların bazılarını sizin için otomatik olarak oluşturur ve makul varsayılanlara göre doldurur. Oluşturulan dosyalara genel bakış için Android derleme yapısı başlıklı makaleyi inceleyin.

Gradle Wrapper dosyası

Gradle sarmalayıcısı (gradlew), kaynak kodunuza dahil edilmiş ve Gradle'ı indirip başlatan küçük bir uygulamadır. Bu sayede daha tutarlı bir derleme yürütme işlemi gerçekleşir. Geliştiriciler uygulama kaynağını indirip gradlew'ü çalıştırır. Bu işlem, gerekli Gradle dağıtımını indirir ve uygulamanızı derlemek için Gradle'i başlatır.

gradle/wrapper/gradle-wrapper.properties dosyası, derlemenizi çalıştırmak için Gradle'in hangi sürümünün kullanıldığını açıklayan distributionUrl adlı bir özellik içerir.

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

Gradle ayarları dosyası

settings.gradle.kts dosyası (Kotlin DSL için) veya settings.gradle dosyası (Groovy DSL için) proje kök dizininde bulunur. Bu ayarlar dosyası, proje düzeyinde depo ayarlarını tanımlar ve Gradle'e uygulamanızı derleyirken hangi modülleri dahil etmesi gerektiğini bildirir. Çok modüllü projelerde, nihai derlemeye dahil edilecek her modülün belirtilmesi gerekir.

Çoğu projede dosya varsayılan olarak aşağıdaki gibi görünür:

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'

Üst düzey derleme dosyası

Üst düzey build.gradle.kts dosyası (Kotlin DSL için) veya build.gradle dosyası (Groovy DSL için) proje kök dizininde bulunur. Genellikle projenizdeki modüller tarafından kullanılan eklentilerin yaygın sürümlerini tanımlar.

Aşağıdaki kod örneğinde, yeni bir proje oluşturulduktan sonra üst düzey derleme komut dosyasında varsayılan ayarlar ve DSL öğeleri açıklanmaktadır:

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.7.0" apply false
    id("com.android.library") version "8.7.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.7.0' apply false
    id 'com.android.library' version '8.7.0' apply false
    id 'org.jetbrains.kotlin.android' version '2.0.20' apply false
}