Android屬性動畫簡單剖析

來源:互聯網
上載者:User

標籤:數組   分享   dem   src   java代碼   功能   animation   admin   launch   

運行:

先看布局檔案吧,activity_main.xml:

 1 <?xml version="1.0" encoding="utf-8"?> 2 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 3     xmlns:tools="http://schemas.android.com/tools" 4     android:layout_width="match_parent" 5     android:layout_height="match_parent" 6     tools:context="com.example.administrator.animatordemo.MainActivity"> 7  8     <ImageView 9         android:id="@+id/iv_icon"10         android:layout_width="wrap_content"11         android:layout_height="wrap_content"12         android:layout_marginLeft="10dp"13         android:layout_marginTop="10dp"14         android:scaleType="centerCrop"15         android:src="@mipmap/ic_launcher_round" />16 17     <LinearLayout18         android:layout_width="wrap_content"19         android:layout_height="wrap_content"20         android:layout_alignParentBottom="true"21         android:layout_centerHorizontal="true"22         android:orientation="vertical">23 24         <Button25             android:id="@+id/btn_click1"26             android:layout_width="wrap_content"27             android:layout_height="wrap_content"28             android:layout_centerInParent="true"29             android:layout_gravity="center"30             android:text="startAnimator1" />31 32         <Button33             android:id="@+id/btn_click2"34             android:layout_width="wrap_content"35             android:layout_height="wrap_content"36             android:layout_centerInParent="true"37             android:layout_gravity="center"38             android:text="startAnimator2" />39 40         <Button41             android:id="@+id/btn_click3"42             android:layout_width="wrap_content"43             android:layout_height="wrap_content"44             android:layout_centerInParent="true"45             android:layout_gravity="center"46             android:text="startAnimator3" />47 48     </LinearLayout>49 50 </RelativeLayout>

然後看JAVA代碼,MainActivity.java:

 1 package com.example.administrator.animatordemo; 2  3 import android.animation.AnimatorSet; 4 import android.animation.ObjectAnimator; 5 import android.animation.PropertyValuesHolder; 6 import android.os.Bundle; 7 import android.support.v7.app.AppCompatActivity; 8 import android.view.View; 9 import android.widget.Button;10 import android.widget.ImageView;11 12 public class MainActivity extends AppCompatActivity implements View.OnClickListener {13 14     private Button btn_click1;15     private Button btn_click2;16     private Button btn_click3;17     private ImageView iv_icon;18 19     @Override20     protected void onCreate(Bundle savedInstanceState) {21         super.onCreate(savedInstanceState);22         setContentView(R.layout.activity_main);23         initView();24     }25 26     private void initView() {27         iv_icon = (ImageView) findViewById(R.id.iv_icon);28         btn_click1 = (Button) findViewById(R.id.btn_click1);29         btn_click1.setOnClickListener(this);30         btn_click2 = (Button) findViewById(R.id.btn_click2);31         btn_click2.setOnClickListener(this);32         btn_click3 = (Button) findViewById(R.id.btn_click3);33         btn_click3.setOnClickListener(this);34     }35 36     @Override37     public void onClick(View v) {38         switch (v.getId()) {39             case R.id.btn_click1:40                 startAnimator1();//這樣寫,三個動畫會同時執行41                 break;42             case R.id.btn_click2:43                 startAnimator2();//效果同startAnimator1()一致,要是和第一種相比較,更推薦此方法44                 break;45             case R.id.btn_click3:46                 startAnimator3();47                 break;48         }49     }50 51     /**52      * 旋轉動畫:rotation53      * 水平動畫:translationX54      * 垂直動畫:translationY55      */56     private void startAnimator1() {57         ObjectAnimator.ofFloat(iv_icon, "rotation", 0F, 200F).setDuration(1000).start();58         ObjectAnimator.ofFloat(iv_icon, "translationX", 0F, 200F).setDuration(1000).start();59         ObjectAnimator.ofFloat(iv_icon, "translationY", 0F, 200F).setDuration(1000).start();60     }61 62     private void startAnimator2() {63         PropertyValuesHolder p1 = PropertyValuesHolder.ofFloat("rotation", 0F, 200F);64         PropertyValuesHolder p2 = PropertyValuesHolder.ofFloat("translationX", 0F, 200F);65         PropertyValuesHolder p3 = PropertyValuesHolder.ofFloat("translationY", 0F, 200F);66         ObjectAnimator.ofPropertyValuesHolder(iv_icon, p1, p2, p3).setDuration(1000).start();//第一個參數是控制項對象,後面參數是可變長數組67     }68 69     private void startAnimator3() {70         ObjectAnimator animator1 = ObjectAnimator.ofFloat(iv_icon, "rotation", 0F, 200F);71         ObjectAnimator animator2 = ObjectAnimator.ofFloat(iv_icon, "translationX", 0F, 200F);72         ObjectAnimator animator3 = ObjectAnimator.ofFloat(iv_icon, "translationY", 0F, 200F);73         AnimatorSet set = new AnimatorSet();74 //        set.playTogether(animator1, animator2, animator3);//三個動畫同時執行75         set.playSequentially(animator1, animator2, animator3);//三個動畫按順序執行76         set.setDuration(1000);77         set.start();78     }79 }

說明一下,在startAnimator3()這個方法當中,AnimatorSet集合除了playTogether和playSequentially兩個方法外,還有play方法。比如它可以這樣使用:

set.paly(animator2).with(animator3);set.play(animator1).after(animator2);

這種效果的話,則是會先進行“水平動畫和垂直動畫”同時執行,然後再執行旋轉動畫。通過with(),after(),甚至還有before()方法這樣一些方法,我們就可以做到這樣一個屬性集合詳細的順序處理。

是不是強大的功能呢?這種方式,也是屬性動畫裡面使用最多的一種方式。

Android屬性動畫簡單剖析

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.