Zum Hauptinhalt springen

Wie man AAR-Dateien in Capacitor-Plugins verwendet

Lernen Sie, wie Sie AAR-Dateien in Capacitor-Plugins integrieren können, um Ihre Web-Anwendungen mit nativen Android-Funktionen zu verfeinern, indem Sie einen klaren, Schritt-für-Schritt-Leitfaden verwenden.

Martin Donadieu

Martin Donadieu

Content-Marketing-Manager

Wie man AAR-Dateien in Capacitor-Plugins verwendet

Möchten Sie Android-Funktionen in Ihre __CAPGO_KEEP_0__-Anwendungen integrieren? Capacitor app? Diese Anleitung erklärt, wie man AAR-Dateien (Android Archive) in Capacitor-Plugins verwendet, um native Android-Funktionen mit cross-plattformen Web-Anwendungen zu kombinieren.

Hauptpunkte:

  • Was sind AAR-Dateien? Vorverpackte Android-Bibliotheken, die code, Ressourcen und native Dateien enthalten.
  • Warum sollten sie verwendet werden? AAR-Dateien ermöglichen die code-Wiederverwendung, vereinfachen die Wartung und schützen geheime Funktionen.
  • Was ist erforderlich? Tools wie Android Studio, Gradle, und Node.js, plus eine ordnungsgemäße Projektierung.
  • Wie kann ich integrieren? Legen Sie AAR-Dateien in libs, konfigurieren Sie Gradle und verbinden Sie sie mit Capacitor-Plugins.

Rasche Schritte:

  1. Konfigurieren Sie Ihre Umgebung: Installieren Sie erforderliche Tools und konfigurieren Sie Android Studio.
  2. Organisieren Sie Ihr Projekt: Erstellen Sie eine klare Struktur für Ihr Capacitor Plugin.
  3. Hinzufügen von AAR-Dateien: Platzieren Sie sie in android/libs und aktualisieren Sie die Gradle-Abhängigkeiten.
  4. Schreiben Sie den Plugin code: Verknüpfen Sie die AAR-Funktionalität mit JavaScript mit Capacitor’s API.
  5. Sorgfältig testen: Verwenden Sie Android Studios Debugger, um eine glatte Integration sicherzustellen.

Durch das Befolgen dieser Anleitung können Sie AAR-Dateien problemlos in Ihre Capacitor-Plugins einbetten und so native Android-Funktionen für Ihre Web-Apps freischalten.

Wie Sie eine Android-Bibliothek (AAR-Datei) in ein capacitor Erweiterung

capacitor

Anforderungen für die Entwicklungsumgebung

Bevor Sie mit AAR-Dateien arbeiten, stellen Sie sicher, dass Ihre Entwicklungsumgebung ordnungsgemäß konfiguriert ist, um eventuelle Probleme zu vermeiden.

Erforderliche Software

Hier ist die erforderliche Software, um mit AAR-Dateien in Capacitor-Erweiterungen zu arbeiten:

SoftwareMindestversionZweck
Android Studio2022.1.1 oder höherHaupt-IDE für Android-Entwicklung
Java-Entwicklungskit11 oder höherFür die Android-Entwicklung erforderlich
Node.js14.0 oder höherFür die Verwaltung von Capacitor und npm-Paketen
Gradle7.3 oder höherAndroids Build-Tool
Git2.30 oder höherFür Versionskontrolle und Paketverwaltung

Zusätzlich stellen Sie sicher, dass die folgenden Komponenten in Ihrem SDK-Manager enthalten sind:

  • Android SDK-Plattform 33 (Android 13.0)
  • Android SDK-Build-Tools 33.0.0
  • Android SDK-Command-line-Tools
  • Android-Emulator
  • Android SDK-Plattform-Tools

Projekt-Einrichtungs-Schritte

1. Initialisieren Sie Ihre Entwicklungsumgebung

Beginnen Sie mit der Erstellung eines neuen Verzeichnisses mit dieser Struktur:

my-plugin/
├── android/
│   ├── src/
│   └── build.gradle
├── src/
│   └── definitions.ts
└── package.json

2. Konfigurieren Sie die Einstellungen von Android Studio

Starten Sie Android Studio und passen Sie die folgenden Einstellungen an:

  • Setzen Sie die Gradle JDK-Version auf 11 oder höher.
  • Aktivieren Sie die automatische Herunterladen-Funktion für Android-Komponenten SDK.
  • Aktualisieren Sie Ihre Systemumgebungsvariablen mit dem korrekten Android-Pfad SDK.

3. Vorbereiten Sie Ihre Plugin-Struktur.

Aktualisieren Sie das android/build.gradle Datei mit diesen Einstellungen, um AAR-Datei-Unterstützung zu aktivieren:

android {
    compileSdkVersion 33
    defaultConfig {
        minSdkVersion 22
        targetSdkVersion 33
    }

    repositories {
        flatDir {
            dirs 'libs'
        }
    }
}

4. Einrichten Sie die Versionskontrolle.

Initialisieren Sie Git in Ihrem Projektverzeichnis und erstellen Sie ein .gitignore Datei, um unnötige Dateien auszuschließen. Hier ist ein Beispiel: .gitignore:

android/build/
node_modules/
dist/
*.iml
.idea/
.gradle/
local.properties

Sobald diese Schritte abgeschlossen sind, sind Sie bereit, Ihre AAR-Dateien hinzuzufügen.

Hinzufügen von AAR-Dateien zu Ihrem Plugin

Abliefern von AAR-Dateien

AAR-Dateien können aus drittbezogenen SDKs, benutzerdefinierten Bibliotheken oder Maven-Abhängigkeiten stammen. Es ist eine gute Idee, ihre Quelle, Version und Zweck in einem README __CAPGO_KEEP_0__ libs dokumentieren.

QuellartBeschreibungGute Praxis
Drittbezogene SDKsVorverarbeitete Bibliotheken von AnbieternDokumentieren Sie die Versionsdetails des Anbieters in einer README
Benutzerdefinierte Android-BibliothekenSelbst entwickelte Android-ModuleDokumentieren Sie den Build-Prozess
Maven-AbhängigkeitenVon Remote-Repositories konvertiertLokal im Cache speichern für Offline-Builds

Sobald Ihre AAR-Dateien bereit und dokumentiert sind, können Sie Ihre Plugin konfigurieren, um sie einzubinden.

Einstellungen für Plugin-Dateien

Ordnen Sie Ihre Plugin-Dateien so an, dass eine glatte Integration von AAR-Abhängigkeiten gewährleistet ist. Hier ist ein Beispiel dafür, wie Ihre Plugin-Struktur aussehen könnte:

my-plugin/
├── android/
│   ├── libs/        # AAR files with README
│   ├── src/
│   └── build.gradle
├── src/
│   └── definitions.ts
└── package.json
{
    "files": [
        "android/libs/*.aar",
        "android/src/**/*",
        "src/**/*"
    ]
}

Platzierung von AAR-Dateien

Um AAR-Funktionen zu aktivieren, legen Sie die Dateien im android/libs Verzeichnis Ihres Plugins an, indem Sie diese Schritte befolgen:

  • Wählen Sie einen klaren und konsistenten Namensformat, wie z.B. libraryname-version.aar.
  • Verwalten Sie Versionen in einem versions.properties Datei. Zum Beispiel:
library1=1.2.3
library2=2.0.0
  • Ein Datei für andere Abhängigkeiten hinzufügen: dependencies.gradle Organisieren Sie Dateien für Hersteller-spezifische Dateien in Unterordnern für eine bessere Verwaltung:
dependencies {
    implementation fileTree(dir: 'libs', include: ['*.aar'])
    implementation 'com.example:dependency:1.0.0'
}
  • Das Halten von Konfigurationsdateien in Hersteller-spezifischen Unterordnern hilft bei der Aufrechterhaltung der Ordnung und vermeidet Konflikte bei der Erstellung, wenn mit mehreren AAR-Abhängigkeiten gearbeitet wird.
android/libs/
├── vendor1/
│   ├── feature.aar
│   └── config.json
└── vendor2/
    ├── module.aar
    └── settings.xml

Gradle

KonfigurationsSchritte Gradle Build Tool Interface

Die build.gradle aktualisieren

Um AAR-Dateien in Ihr __CAPGO_KEEP_0__-Plugin zu integrieren, müssen Sie Gradle entsprechend konfigurieren. Beginnen Sie damit, diese Repository-Einstellungen hinzuzufügen:

To integrate AAR files into your Capacitor plugin, you need to configure Gradle appropriately. Start by adding these repository settings to android/build.gradle:

repositories {
    google()
    mavenCentral()
    flatDir {
        dirs 'libs'
    }
}

Block ein: dependencies Für eine bessere Versionsverwaltung erstellen Sie ein

dependencies {
    implementation files('libs/your-library.aar')
    implementation fileTree(dir: 'libs', include: ['**/*.aar'])
    implementation "com.getcapacitor:core:${capacitorVersion}"
    implementation "androidx.appcompat:appcompat:1.6.1"
}

block gradle.properties Datei in Ihrem Projekt-Root und definieren Sie Ihre Bibliotheksversionen:

# Library versions
MY_LIBRARY_VERSION=1.2.3
CAPACITOR_VERSION=5.5.0

Wenn das AAR-Datei zusätzliche Abhängigkeiten enthält, deklarieren Sie sie in android/build.gradle wie folgt:

android {
    defaultConfig {
        minSdkVersion 21
        targetSdkVersion 33
    }

    packagingOptions {
        exclude 'META-INF/DEPENDENCIES'
        exclude 'META-INF/LICENSE'
    }
}

Nachdem Sie diese Änderungen vorgenommen haben, synchronisieren Sie Ihr Projekt, um sie anzuwenden.

Gradle Sync ausführen

Öffnen Sie Ihr Projekt in Android Studio und warten Sie, bis Gradle automatisch synchronisiert. Wenn es nicht startet, klicken Sie auf die Schaltfläche "Projekt synchronisieren mit Gradle-Dateien" in der Werkzeugleiste.

Nach der Synchronisierung überprüfen Sie Folgendes:

Überprüfen Sie den PunktErwartetes ErgebnisHäufige Probleme
Build-AusgabeKeine AAR-bezogenen FehlerFehlende Abhängigkeiten
BibliotheksaufschlüsselungAAR-Dateien werden korrekt verlinktFalsche Pfadverweise
VersionenkonflikteKeine Versionsprobleme für AbhängigkeitenInkompatible Versionen

Wenn der Synchronisierungsversuch fehlschlägt, überprüfen Sie bitte Ihre Konfiguration. Zum Beispiel sollten diese Einstellungen vorliegen:

android {
    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }

    lintOptions {
        abortOnError false
    }
}

Für große AAR-Dateien müssen Sie möglicherweise die Gradle-Memory-Allokation erhöhen in gradle.properties:

org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m

Sobald der Synchronisierungsprozess erfolgreich abgeschlossen ist, sollten Ihre AAR-Dateien vollständig integriert und für die Testphase bereit sein.

Verbindung von AAR-Funktionen zu Capacitor

Erstellung der Plugin-Klasse

Sobald Ihre Gradle-Dateien synchronisiert sind, ist es Zeit, Ihre AAR-Funktionen zu verbinden, indem Sie die Plugin-Klasse erweitern. Dieser Schritt verbindet JavaScript mit der nativen Android code.

@NativePlugin(
    permissions = {
        Manifest.permission.REQUIRED_PERMISSION
    }
)
public class YourPlugin extends Plugin {
    private YourAARLibrary libraryInstance;

    @Override
    public void load() {
        super.load();
        libraryInstance = new YourAARLibrary(getContext());
    }
}

Hier sind die erforderlichen Informationen für die Initialisierung der AAR-Bibliothek:

KomponenteZweckImplementierungsanmerkung
KontextAndroid-Anwendungs-KontextVerwendung getContext() aus der Plugin-Klasse
KonfigurationBibliotheks-EinstellungenOptionen vom Plugin übergeben
LebenszyklusVerwaltung des Plugin-ZustandsÜberschreiben load() und handleOnDestroy()

Erstellung von Plugin-Methode

Als Nächstes definieren Sie Methoden in Ihrem Plugin mithilfe der @PluginMethod Diese Methoden handhaben den Datenaustausch zwischen JavaScript und Java.

@PluginMethod
public void performAction(PluginCall call) {
    try {
        // Get data from JavaScript
        String inputData = call.getString("inputKey");

        // Call AAR library method
        YourLibraryResult result = libraryInstance.processData(inputData);

        // Return result to JavaScript
        JSObject ret = new JSObject();
        ret.put("value", result.getValue());
        call.resolve(ret);
    } catch (Exception e) {
        call.reject("Error processing data", e);
    }
}

Für Aufgaben, die asynchron ausgeführt werden müssen:

@PluginMethod(returnType = PluginMethod.RETURN_CALLBACK)
public void startContinuousOperation(PluginCall call) {
    call.setKeepAlive(true);

    libraryInstance.setCallback(new LibraryCallback() {
        @Override
        public void onUpdate(String data) {
            JSObject ret = new JSObject();
            ret.put("data", data);
            call.resolve(ret);
        }
    });
}

Hier sind die häufigsten Typen, die zwischen JavaScript und Java konvertiert werden:

JavaScript-TypJava-TypUmwandlungsmethode
ObjektJS-Objektcall.getObject()
ArrayJS-Arraycall.getArray()
ZeichenfolgeZeichenfolgecall.getString()
ZahlGanzzahl/Doppeltescall.getInt()/call.getDouble()
BooleschBooleschcall.getBoolean()

Für die Ressourcenaufreinigung überschreiben Sie den handleOnDestroy Methode:

@Override
protected void handleOnDestroy() {
    if (libraryInstance != null) {
        libraryInstance.cleanup();
        libraryInstance = null;
    }
    super.handleOnDestroy();
}

Mit diesen Methoden ist Ihr Native-Bridge bereit. Testen Sie Ihre Implementierung im Debug-Modus von Android Studio, um sicherzustellen, dass alles wie erwartet funktioniert.

Testen und Probleme beheben

Debuggen in Android Studio

Android Studio

Um Ihr AAR-Integration in Android Studio zu debuggen, beginnen Sie damit, den Debug-Modus in Ihrem Projekts build.gradle Datei:

android {
    buildTypes {
        debug {
            debuggable true
            minifyEnabled false
        }
    }
}

Fügen Sie in Ihren Pluginmethoden Ausbrüche ein, um den Datenfluss zu verfolgen und potenzielle Probleme zu identifizieren:

@PluginMethod
public void yourMethod(PluginCall call) {
    // Set a breakpoint here to inspect input data
    String inputValue = call.getString("key");
    // Another breakpoint here to check method calls to the AAR
    libraryInstance.someMethod(inputValue);
}

Verwenden Sie das Debug-Panel in Android Studio, um wichtige Bereiche zu überwachen:

Debug-BereichWas zu überprüfen istHäufige Probleme
LogcatAAR-InitialisierungsmitteilungenFehlende Berechtigungen oder falscher Kontext
VariablenDatenkonvertierungenNulleinträge oder Typmismatches
Stack-SpurenAufrufablauf von MethodenUngültige Methdaufrufe oder Synchronisationsprobleme
SpeicherRessourcenverbrauchSpeicherverluste

__CAPGO_KEEP_0__

Fehlersuche

Wenn die Fehlersuche nicht ausreicht, folgen Sie den Schritten zur Fehlersuche in der nächsten Abschnitt.

Schritte zur Fehlersuche

Wenn die Fehlersuche allein nicht ausreicht, verwenden Sie diese Schritte, um häufige Probleme anzugehen: build.gradle 1. Abhängigkeitskonflikte

configurations.all {
    resolutionStrategy {
        force 'com.google.android:android:4.1.1.4'
        // Add other forced versions as needed
    }
}

Überprüfen Sie nach Versionenkonflikten in Ihrem

Datei. Sie können spezifische Versionen zwingen, um Konflikte zu lösen: .so 2. Fehlende Native Bibliotheken

  • jniLibs/armeabi-v7a/
  • jniLibs/arm64-v8a/
  • jniLibs/x86/
  • jniLibs/x86_64/

Stellen Sie sicher, dass die AAR die erforderlichen in den entsprechenden Verzeichnissen, wie z.B. enthält:

Wenn Sie Manifest-Konflikte begegnen, fügen Sie den folgenden Inhalt in Ihrem AndroidManifest.xml Datei ein, um problematische Bibliotheken zu überschreiben:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    package="your.plugin.package">
    <uses-sdk tools:overrideLibrary="conflicting.library.package"/>
</manifest>

4. Laufzeitstörungen und Speichermanagement

Verwenden Sie die Leistungsoberfläche in Android Studio, um die Laufzeitstabilität zu überwachen. Für Initialisierungsprobleme behandeln Sie Ausnahmen vorsichtig:

try {
    libraryInstance = new YourAARLibrary(getContext());
} catch (Exception e) {
    Log.e("PluginError", "Failed to initialize library: " + e.getMessage());
    return;
}

Um Speicherverluste zu verhindern, stellen Sie sicher, dass Ressourcen ordnungsgemäß freigegeben werden. Verwenden Sie den Speichermanager in Android Studio, um den Heap-Verbrauch zu überwachen und etwaige Lecks zu identifizieren.

Zusammenfassung

Um AAR-Dateien in Capacitor-Plugins zu integrieren, müssen Sie die Android-Umgebung einrichten, AAR-Dateien korrekt platzieren, Gradle genau konfigurieren und gründlich testen.

Schlüsselimplementierungsphasen

PhaseAnforderungenIndikatoren für Erfolg
EntwicklungssetupAndroid Studio 4.0+, Gradle 7.0+Der Build schließt ohne Fehler ab
AAR-IntegrationOrdnungsgemäße Dateiplatzierung, korrekte AbhängigkeitenKeine Manifest-Konflikte
Plugin-EntwicklungKlare Plugin-Struktur, genaue MethodezuweisungMethode ausführen wie erwartet
TestenDebug-Modus aktiv, effektive FehlerbehandlungKeine Laufzeitcrashes

Wenn Sie diese Grundlagen beherrschen, können Sie sich mit fortgeschrittenen Techniken beschäftigen.

Weiterführende Schritte

Um Ihr Plugin zu verbessern, konzentrieren Sie sich auf diese Bereiche:

  • Leistungsoptimierung
    Verwenden Sie Android Studios Profiler, um den Speicherbedarf zu überwachen und sicherzustellen, dass Ressourcen ordnungsgemäß aufgeräumt werden.

  • Vorbereitung für die Verteilung
    Dokumentieren Sie alle AAR-Konfigurationen, generieren Sie API-Dokumentation und testen Sie die Kompatibilität mit Android API-Versionen 29–34.

  • Wartungssstrategie
    Automatisieren Sie die Tests, verwalten Sie AAR-Versionen mit der Versionskontrolle, führen Sie einen Changelog durch und setzen Sie eine Fehlerberichterstattung ein, um Produktionsprobleme anzugehen.

Wenn Sie beabsichtigen, Ihr Plugin öffentlich zu teilen, stellen Sie sicher, dass Sie detaillierte Dokumentation zu AAR-spezifischen Einstellungen und etwaigen Plattformbeschränkungen bereitstellen. Dies wird es anderen Entwicklern erleichtern, Ihr Plugin effektiv zu adoptieren und zu verwenden.

Bleiben Sie bei How to Use AAR Files in Capacitor-Plugins

Wenn Sie How to Use AAR Files in Capacitor-Plugins für die native Plugin-Arbeit zu planen, verbinden Sie es mit Capgo Plugin-Verzeichnis für den Produktworkflow in Capgo Plugin-Verzeichnis Capacitor Plugins von Capgo für die Implementierungsdetails in Capacitor Plugins von Capgo, Hinzufügen oder Aktualisieren von Plugins für die Implementierungsdetails in Hinzufügen oder Aktualisieren von Plugins Ionic Enterprise Plugin Alternativen für den Produktworkflow in Ionic Enterprise Plugin Alternativen, und Capgo Native Builds für den Produktworkflow in Capgo Native Builds.

Echtzeit-Updates für Capacitor-Anwendungen

Wenn ein Bug im Web-Schicht lebt, liefern Sie die Reparatur über Capgo anstatt Tage für die Genehmigung des App-Store abzuwarten. Die Benutzer erhalten das Update im Hintergrund, während native Änderungen im normalen Review-Prozess bleiben.

Los geht's jetzt

Neuestes aus unserem Blog

Capgo bietet Ihnen die besten Einblicke, die Sie benötigen, um eine wirklich professionelle mobile App zu erstellen.