Komplexe XML-Ressourcen inline einbinden

Bestimmte Ressourcentypen setzen sich aus mehreren komplexen Ressourcen zusammen, die durch XML-Dateien dargestellt werden. Ein Beispiel ist ein animiertes Vektor-Drawable, eine Drawable-Ressource, die einen Vektor einschließt. und eine Animation. Dazu ist die Verwendung von mindestens drei XML-Dateien erforderlich, wie in den Follower Beispiele.

res/drawable/avd.xml
<?xml version="1.0" encoding="utf-8"?>
<animated-vector xmlns:android="http://schemas.android.com/apk/res/android"
   
android:drawable="@drawable/vectordrawable" >
   
<target
       
android:name="rotationGroup"
       
android:animation="@anim/rotation" />
</animated-vector>
res/drawable/vectordrawable.xml
<?xml version="1.0" encoding="utf-8"?>
<vector xmlns:android="http://schemas.android.com/apk/res/android"
   
android:height="64dp"
   
android:width="64dp"
   
android:viewportHeight="600"
   
android:viewportWidth="600" >
   
<group
       
android:name="rotationGroup"
       
android:pivotX="300.0"
       
android:pivotY="300.0"
       
android:rotation="45.0" >
       
<path
           
android:fillColor="#000000"
           
android:pathData="M300,70 l 0,-70 70,70 0,0 -70,70z" />
   
</group>
</vector>
res/anim/rotation.xml
<?xml version="1.0" encoding="utf-8"?>
<objectAnimator xmlns:android="http://schemas.android.com/apk/android"
   
android:duration="6000"
   
android:propertyName="rotation"
   
android:valueFrom="0"
   
android:valueTo="360" />

Wenn das Vektor-Drawable und die Animationen an anderer Stelle wiederverwendet werden, ist dies die beste Methode zur Implementierung eines Animiertes Vektor-Drawable. Wenn diese Dateien jedoch nur für dieses animierte Vektor-Drawable verwendet werden, gibt es eine kompaktere Art, sie zu implementieren.

Mit dem Inline-Ressourcenformat von AAPT können Sie alle drei Ressourcen in derselben XML-Datei definieren: wie im folgenden Beispiel dargestellt. Lege die Datei für ein animiertes Vektor-Drawable unter res/drawable/ ab.

res/drawable/avd.xml
<?xml version="1.0" encoding="utf-8"?>
<animated-vector xmlns:android="http://schemas.android.com/apk/res/android"
   
xmlns:aapt="http://schemas.android.com/aapt" >

   
<aapt:attr name="android:drawable" >
       
<vector
           
android:height="64dp"
           
android:width="64dp"
           
android:viewportHeight="600"
           
android:viewportWidth="600" >
           
<group
               
android:name="rotationGroup"
               
android:pivotX="300.0"
               
android:pivotY="300.0"
               
android:rotation="45.0" >
               
<path
                   
android:fillColor="#000000"
                   
android:pathData="M300,70 l 0,-70 70,70 0,0 -70,70z" />
           
</group>
       
</vector>
   
</aapt:attr>

   
<target android:name="rotationGroup">
       
<aapt:attr name="android:animation" >
           
<objectAnimator
               
android:duration="6000"
               
android:propertyName="rotation"
               
android:valueFrom="0"
               
android:valueTo="360" />
       
</aapt:attr>
   
</target>
</animated-vector>

Das XML-Tag <aapt:attr > weist AAPT an, das untergeordnete Element des Tags als und extrahieren Sie sie in eine eigene Ressourcendatei. Der Wert im Attributnamen gibt an, um die Inline-Ressource im übergeordneten Tag zu verwenden.

AAPT generiert Ressourcendateien und Namen für alle Inline-Ressourcen. Apps, die in diesem Inline-Format erstellt wurden, sind mit allen Android-Versionen kompatibel.