观心静

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

版权声明

本文来自博客园,作者:观心静 ,转载请注明原文链接:https://www.cnblogs.com/guanxinjing/p/12830087.html

本文版权归作者和博客园共有,欢迎转载,但必须给出原文链接,并保留此段声明,否则保留追究法律责任的权利。

前言

  在前面的博客Android 开发 VectorDrawable 矢量图 (三)矢量图动画里,了解了group动画与path动画的实现。但是,可能有些人会觉得这些动画的实现的xml文件实在是太多了。此篇博客就将说明如何将所有的矢量图与动画全放到一个xml中。我们将还是用举例的方式说明。

 

颜色渐变group动画

效果图:

1.首先,老规矩找一个现成的矢量图,我们在Android studio自带的矢量图库里找一个矢量图

        

2.在drawable文件夹里,创建一个我们要放矢量图加动画组合的一个xml。并且先写入下面这些属性。

请注意!

xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:aapt="http://schemas.android.com/aapt

这2个属性不是默认的,并且没有代码提示,需要你手动输入或者复制黏贴,取代默认的xmlns:android 属性。 另外 aapt:attr  这个属性也是没有代码提示的。

ic_color_anim.xml

 

<animated-vector
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:aapt="http://schemas.android.com/aapt">
    <aapt:attr name="android:drawable">

    </aapt:attr>

</animated-vector>

 

3.将矢量图的xml代码复制到<aapt:attr > 属性里

 

<?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="24dp"
            android:viewportHeight="24.0"
            android:viewportWidth="24.0"
            android:width="24dp">

            <path
                android:name="path"
                android:fillColor="#F44336"
                android:pathData="
                    M12,2
                    C6.48,2 2,6.48 2,12s4.48,10 10,10 10,-4.48 10,-10S17.52,2 12,2
                    z
                    M13,17
                    h-2v-2h2v2zM13,13h-2L11,7h2v6
                    z"/>

        </vector>

    </aapt:attr>

</animated-vector>

 

4.实现颜色渐变动画

<?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="24dp"
            android:viewportHeight="24.0"
            android:viewportWidth="24.0"
            android:width="24dp">

            <path
                android:name="path"
                android:fillColor="#F44336"
                android:pathData="
                    M12,2
                    C6.48,2 2,6.48 2,12s4.48,10 10,10 10,-4.48 10,-10S17.52,2 12,2
                    z
                    M13,17
                    h-2v-2h2v2zM13,13h-2L11,7h2v6
                    z"/>

        </vector>

    </aapt:attr>

    <target
        android:name="path">
        <aapt:attr name="android:animation">
            <objectAnimator
                android:propertyName="fillColor"
                android:valueFrom="#F44336"
                android:valueTo="#FF9800"
                android:duration="3000"
                android:valueType="colorType"
                android:interpolator="@android:interpolator/fast_out_slow_in"/>
        </aapt:attr>
    </target>

</animated-vector>

请注意,<target android:name="path_1"> 因为fillColor算是属性动画,所以直接使用path的名称

5.在Activity的布局里使用它

    <ImageView
        android:id="@+id/image_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:src="@drawable/ic_color_anim"/>

只能用src属性设置

6.代码里启动动画

        mImageView = findViewById(R.id.image_view);
        mImageView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Drawable drawable = mImageView.getDrawable();
                if (drawable instanceof Animatable) {
                    ((Animatable) drawable).start();

                }
            }
        });

 

360度旋转动画

 

<animated-vector
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:aapt="http://schemas.android.com/aapt">
    <aapt:attr name="android:drawable">
        <vector xmlns:android="http://schemas.android.com/apk/res/android"
            android:width="32dp"
            android:height="32dp"
            android:viewportWidth="32"
            android:viewportHeight="32">
            <!--别忘记需要使用group包裹,且名称需要与下面的 <target android:name="wrapper">一致-->
            <group
                android:name="wrapper"
                android:pivotX="16"
                android:pivotY="16">
            <path
                android:pathData="M16,24A1.333,1.333 0,0 1,17.333 25.333v5.333a1.333,1.333 0,1 1,-2.667 0v-5.333A1.333,1.333 0,0 1,16 24Z"
                android:fillColor="#d5d5d5"/>
            <path
                android:pathData="M16,0A1.333,1.333 0,0 1,17.333 1.333L17.333,6.667a1.333,1.333 0,0 1,-2.667 0L14.666,1.333A1.333,1.333 0,0 1,16 0Z"
                android:fillColor="#999"/>
            <path
                android:pathData="M24,16a1.333,1.333 0,0 1,1.333 -1.333L30.667,14.667a1.333,1.333 0,0 1,0 2.667L25.333,17.334A1.333,1.333 0,0 1,24 16Z"
                android:fillColor="#bbb"/>
            <path
                android:pathData="M1.333,14.666h5.333a1.333,1.333 0,1 1,0 2.667h-5.333a1.333,1.333 0,0 1,0 -2.667Z"
                android:fillColor="#f2f2f2"/>
            <path
                android:pathData="M25.428,4.687a1.333,1.333 0,0 1,1.885 1.885l-3.771,3.771a1.333,1.333 0,0 1,-1.885 -1.885Z"
                android:fillColor="#aaa"/>
            <path
                android:pathData="M8.456,21.658a1.333,1.333 0,0 1,1.885 1.885l-3.771,3.771a1.333,1.333 0,0 1,-1.885 -1.885Z"
                android:fillColor="#e6e6e6"/>
            <path
                android:pathData="M8.456,10.343l-3.771,-3.771a1.333,1.333 0,1 1,1.885 -1.885l3.771,3.771a1.333,1.333 0,0 1,-1.885 1.885Z"
                android:fillColor="#fff"/>
            <path
                android:pathData="M23.542,21.658l3.771,3.771a1.333,1.333 0,1 1,-1.885 1.885l-3.771,-3.771a1.333,1.333 0,0 1,1.885 -1.885Z"
                android:fillColor="#ccc"/>
            </group>
        </vector>
    </aapt:attr>
    <target android:name="wrapper">
        <aapt:attr name="android:animation">
            <objectAnimator
                android:propertyName="rotation"
                android:duration="1500"
                android:valueFrom="0"
                android:valueTo="360"
                android:valueType="floatType"
                android:repeatMode="restart"
                android:repeatCount="infinite"
                android:interpolator="@android:interpolator/linear"/>
        </aapt:attr>
    </target>
</animated-vector>

 

 

 

 

 

End

posted on 2020-05-05 11:53  观心静  阅读(569)  评论(0编辑  收藏  举报