เมื่อการขึ้นต่อกันไม่ใช่ไลบรารีในเครื่องหรือโครงสร้างไฟล์
Gradle จะค้นหาไฟล์ในที่เก็บข้อมูลออนไลน์ที่ระบุไว้ในบล็อก dependencyResolutionManagement { repositories {...} }
ของไฟล์ settings.gradle
ลำดับที่คุณแสดงรายการที่เก็บแต่ละรายการจะเป็นตัวกำหนด
ลำดับที่ Gradle ค้นหาที่เก็บสำหรับการขึ้นต่อกันของแต่ละโปรเจ็กต์
ตัวอย่างเช่น หากมีทรัพยากร Dependency จากทั้งที่เก็บ A และ B และคุณ
แสดงรายการ A ก่อน Gradle จะดาวน์โหลดทรัพยากร Dependency จากที่เก็บ A
โดยค่าเริ่มต้น โปรเจ็กต์ Android Studio ใหม่จะระบุที่เก็บ Maven ของ Google และที่เก็บ Maven Central เป็นตำแหน่งที่เก็บในไฟล์ settings.gradle
ของโปรเจ็กต์ ดังที่แสดงด้านล่าง
Kotlin
dependencyResolutionManagement { repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { google() mavenCentral() } }
Groovy
dependencyResolutionManagement { repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { google() mavenCentral() } }
หากต้องการใช้บางอย่างจากที่เก็บข้อมูลในเครื่อง ให้ใช้ mavenLocal()
:
Kotlin
dependencyResolutionManagement { repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { google() mavenCentral() mavenLocal() } }
Groovy
dependencyResolutionManagement { repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { google() mavenCentral() mavenLocal() } }
หรือจะประกาศที่เก็บ Maven หรือ Ivy ที่เฉพาะเจาะจงก็ได้ ดังนี้
Kotlin
dependencyResolutionManagement { repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { maven(url = "https://repo.example.com/maven2") maven(url = "file://local/repo/") ivy(url = "https://repo.example.com/ivy") } }
Groovy
dependencyResolutionManagement { repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { maven { url 'https://repo.example.com/maven2' } maven { url 'file://local/repo/' } ivy { url 'https://repo.example.com/ivy' } } }
ดูข้อมูลเพิ่มเติมได้ในคู่มือที่เก็บ Gradle
ที่เก็บ Maven ของ Google
ไลบรารี Android ต่อไปนี้เวอร์ชันล่าสุดพร้อมให้ใช้งานจากที่เก็บ Maven ของ Google
- ไลบรารี AndroidX
- ไลบรารีคอมโพเนนต์สถาปัตยกรรม
- ไลบรารีการออกแบบจุดยึด
- AndroidX Test
- ไลบรารีการเชื่อมโยงข้อมูล
- คลัง Android Instant Apps
- Wear OS
- บริการ Google Play
- คลังการเรียกเก็บเงินของ Google Play
- Firebase
คุณดูอาร์ติแฟกต์ทั้งหมดที่มีได้ที่ ดัชนีที่เก็บ Maven ของ Google (ดูการเข้าถึงแบบเป็นโปรแกรมด้านล่าง)
หากต้องการเพิ่มไลบรารีเหล่านี้ลงในการบิลด์ ให้รวมที่เก็บ Maven ของ Google
ไว้ในไฟล์ build.gradle.kts
ระดับบนสุด
Kotlin
dependencyResolutionManagement { repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { google() // If you're using a version of Gradle lower than 4.1, you must instead use: // maven { // url = "https://maven.google.com" // } // An alternative URL is "https://dl.google.com/dl/android/maven2/". } }
Groovy
dependencyResolutionManagement { repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { google() // If you're using a version of Gradle lower than 4.1, you must instead use: // maven { // url 'https://maven.google.com' // } // An alternative URL is 'https://dl.google.com/dl/android/maven2/'. } }
จากนั้นเพิ่มไลบรารีที่ต้องการลงในบล็อก dependencies
ของโมดูล
ตัวอย่างเช่น appcompat library
มีลักษณะดังนี้
Kotlin
dependencies { implementation("com.android.support:appcompat-v7:28.0.0") }
Groovy
dependencies { implementation 'androidx.appcompat:appcompat:1.7.0' }
อย่างไรก็ตาม หากคุณพยายามใช้ไลบรารีเวอร์ชันเก่ากว่าที่ระบุไว้ข้างต้น และขึ้นอยู่กับไลบรารีดังกล่าวไม่ได้ แสดงว่าไลบรารีนั้นไม่มีในที่เก็บ Maven และคุณต้องรับไลบรารีจากที่เก็บแบบออฟไลน์แทน
การเข้าถึงแบบเป็นโปรแกรม
หากต้องการเข้าถึงอาร์ติแฟกต์ Maven ของ Google แบบเป็นโปรแกรม คุณสามารถรับ รายการ XML ของกลุ่มอาร์ติแฟกต์ได้จาก maven.google.com/master-index.xml จากนั้นคุณจะดูชื่อและเวอร์ชันของไลบรารีของกลุ่มได้ที่
maven.google.com/group_path/group-index.xml
เช่น ไลบรารีในกลุ่ม android.arch.lifecycle จะแสดงอยู่ที่ maven.google.com/android/arch/lifecycle/group-index.xml
นอกจากนี้ คุณยังดาวน์โหลดไฟล์ POM และ JAR ได้ที่
maven.google.com/group_path/library/version /library-version.ext
เช่น maven.google.com/android/arch/lifecycle/compiler/1.0.0/compiler-1. 0.0.pom
ที่เก็บแบบออฟไลน์จากเครื่องมือจัดการ SDK
สำหรับไลบรารีที่ไม่มีในที่เก็บ Maven ของ Google (โดยปกติจะเป็นไลบรารีเวอร์ชันเก่ากว่า) คุณต้องดาวน์โหลดแพ็กเกจที่เก็บของ Google แบบออฟไลน์จาก SDK Manager
จากนั้นคุณจะเพิ่มไลบรารีเหล่านี้ลงในบล็อก dependencies
ได้ตามปกติ
ระบบจะบันทึกไลบรารีออฟไลน์ไว้ใน
android_sdk/extras/