เมื่อทรัพยากร Dependency เป็นอย่างอื่นที่ไม่ใช่ไลบรารีในเครื่องหรือแผนผังไฟล์
Gradle จะค้นหาไฟล์ในที่เก็บออนไลน์ใดก็ตามที่ระบุไว้ใน
บล็อก dependencyResolutionManagement { repositories {...} }
จาก
settings.gradle
ลำดับที่คุณแสดงรายการที่เก็บแต่ละรายการจะกำหนด
ลำดับที่ Gradle ค้นหาที่เก็บสำหรับทรัพยากร Dependency ของแต่ละโปรเจ็กต์
เช่น หากทรัพยากร Dependency พร้อมใช้งานจากทั้งที่เก็บ A และ B และคุณ
รายการแรก Gradle ดาวน์โหลดทรัพยากร Dependency จากที่เก็บ A
โดยค่าเริ่มต้น โปรเจ็กต์ Android Studio ใหม่จะระบุที่เก็บ Maven ของ Google และ
ที่เก็บส่วนกลางของ Maven ในชื่อ
ตำแหน่งที่เก็บในไฟล์ settings.gradle
ของโปรเจ็กต์ดังที่แสดงด้านล่าง
Kotlin
dependencyResolutionManagement { repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { google() mavenCentral() } }
ดึงดูด
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() } }
ดึงดูด
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") } }
ดึงดูด
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
- ไลบรารีการเชื่อมโยงข้อมูล
- คลัง Android Instant App
- Wear OS
- บริการ Google Play
- Google Play Billing Library
- 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/". } }
ดึงดูด
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
ซึ่งมีลักษณะดังนี้
Kotlin
dependencies { implementation("com.android.support:appcompat-v7:28.0.0") }
ดึงดูด
dependencies { implementation 'androidx.appcompat:appcompat:1.6.1' }
แต่ถ้าคุณพยายามใช้เวอร์ชันเก่า ของเวอร์ชันข้างต้น ไลบรารีและ Dependency ล้มเหลว ก็ไม่มีใน 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/rch/lifecycle/group-index.xml
คุณยังสามารถดาวน์โหลดไฟล์ POM และ JAR ได้ที่
maven.google.com/group_path/library/version /library-versionext
เช่น maven.google.com/android/Arc/lifecycle/compiler/1.0.0/compiler-1 0.0.pom
ที่เก็บแบบออฟไลน์จาก SDK Manager
สำหรับไลบรารีที่ไม่พร้อมใช้งานจากที่เก็บของ Google Maven (โดยทั่วไปจะเก่ากว่า เวอร์ชันไลบรารี) คุณต้องดาวน์โหลดแพ็กเกจ Google Repository แบบออฟไลน์ จาก SDK Manager
จากนั้นคุณจะเพิ่มไลบรารีเหล่านี้ไปยังบล็อก dependencies
ได้ตามปกติ
ไลบรารีออฟไลน์จะบันทึกไว้ใน
android_sdk/extras/